///
/// Copyright (C) 2004-2007 Andrej Vodopivec <andrejv@users.sourceforge.net>
///
/// This program is free software; you can redistribute it and/or modify
/// it under the terms of the GNU General Public License as published by
/// the Free Software Foundation; either version 2 of the License, or
/// (at your option) any later version.
///
/// This program is distributed in the hope that it will be useful,
/// but WITHOUT ANY WARRANTY; without even the implied warranty of
/// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
/// GNU General Public License for more details.
///
///
/// You should have received a copy of the GNU General Public License
/// along with this program; if not, write to the Free Software
/// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
///
#include "Plot3dWiz.h"
#include <wx/config.h>
#include <wx/artprov.h>
enum {
combobox,
file_browse_3d
};
enum {
cartesian,
cylindrical,
spherical
};
Plot3DWiz::Plot3DWiz(wxWindow* parent, int id,
const wxString& title, const wxPoint& pos,
const wxSize& size, long style):
wxDialog(parent, id, title, pos, size, wxDEFAULT_DIALOG_STYLE)
{
label_1 = new wxStaticText(this, -1, _("Plot 3D"));
label_2 = new wxStaticText(this, -1, _("Expression"));
text_ctrl_1 = new BTextCtrl(this, -1, wxEmptyString, wxDefaultPosition);
label_3 = new wxStaticText(this, -1, _("Variable:"));
text_ctrl_2 = new BTextCtrl(this, -1, wxT("x"), wxDefaultPosition,
wxSize(40, -1));
label_4 = new wxStaticText(this, -1, _("from:"));
text_ctrl_3 = new BTextCtrl(this, -1, wxEmptyString, wxDefaultPosition,
wxSize(70, -1));
label_5 = new wxStaticText(this, -1, _("to:"));
text_ctrl_4 = new BTextCtrl(this, -1, wxEmptyString, wxDefaultPosition,
wxSize(70, -1));
label_6 = new wxStaticText(this, -1, _("Variable:"));
text_ctrl_5 = new BTextCtrl(this, -1, wxT("y"), wxDefaultPosition,
wxSize(40, -1));
label_7 = new wxStaticText(this, -1, _("from:"));
text_ctrl_6 = new BTextCtrl(this, -1, wxEmptyString, wxDefaultPosition,
wxSize(70, -1));
label_8 = new wxStaticText(this, -1, _("to:"));
text_ctrl_7 = new BTextCtrl(this, -1, wxEmptyString, wxDefaultPosition,
wxSize(70, -1));
label_9 = new wxStaticText(this, -1, _("Grid:"));
text_ctrl_8 = new wxSpinCtrl(this, -1, wxEmptyString, wxDefaultPosition,
wxSize(70, -1), wxSP_ARROW_KEYS, 0, 100);
label_10 = new wxStaticText(this, -1, wxT("x"));
text_ctrl_9 = new wxSpinCtrl(this, -1, wxEmptyString, wxDefaultPosition,
wxSize(70, -1), wxSP_ARROW_KEYS, 0, 100);
label_11 = new wxStaticText(this, -1, _("Format:"));
const wxString combo_box_1_choices[] =
{
_("default"),
_("inline"),
wxT("gnuplot"),
wxT("openmath")
};
combo_box_1 = new wxComboBox(this, -1, wxEmptyString, wxDefaultPosition,
wxSize(150, -1), 4, combo_box_1_choices,
wxCB_DROPDOWN);
label_12 = new wxStaticText(this, -1, _("Options:"));
const wxString combo_box_2_choices[] =
{
wxT("set pm3d at b"),
wxT("set pm3d at s; unset surf; unset colorbox"),
wxT("set pm3d map; unset surf"),
wxT("set hidden3d"),
wxT("set mapping spherical"),
wxT("set mapping cylindrical")
};
combo_box_2 = new wxComboBox(this, combobox, wxEmptyString, wxDefaultPosition,
wxSize(250, -1), 6, combo_box_2_choices,
wxCB_DROPDOWN);
check_box_1 = new wxCheckBox(this, -1, _("&pm3d"));
label_13 = new wxStaticText(this, -1, _("Plot to file:"));
text_ctrl_10 = new BTextCtrl(this, -1, wxEmptyString, wxDefaultPosition,
wxSize(250, -1));
button_3 = new wxBitmapButton(this, file_browse_3d,
wxArtProvider::GetBitmap(wxART_FILE_OPEN,
wxART_HELP_BROWSER));
static_line_1 = new wxStaticLine(this, -1);
#if defined __WXMSW__
button_1 = new wxButton(this, wxID_OK, _("OK"));
button_2 = new wxButton(this, wxID_CANCEL, _("Cancel"));
#else
button_1 = new wxButton(this, wxID_CANCEL, _("Cancel"));
button_2 = new wxButton(this, wxID_OK, _("OK"));
#endif
type = cartesian;
set_properties();
do_layout();
}
void Plot3DWiz::set_properties()
{
SetTitle(_("Plot 3D"));
label_1->SetFont(wxFont(20, wxROMAN, wxITALIC, wxNORMAL, 0, wxEmptyString));
text_ctrl_3->SetValue(wxT("-5"));
text_ctrl_4->SetValue(wxT("5"));
text_ctrl_6->SetValue(wxT("-5"));
text_ctrl_7->SetValue(wxT("5"));
text_ctrl_8->SetValue(wxT("30"));
text_ctrl_9->SetValue(wxT("30"));
button_3->SetToolTip(_("Browse"));
bool pm3dValue = false;
#if defined __WXMSW__
button_1->SetDefault();
pm3dValue = true;
#else
button_2->SetDefault();
#endif
int selection = 1;
wxConfig::Get()->Read(wxT("Wiz/Plot3D/format"), &selection);
wxConfig::Get()->Read(wxT("Wiz/Plot3D/pm3d"), &pm3dValue);
combo_box_1->SetSelection(selection);
check_box_1->SetValue(pm3dValue);
text_ctrl_1->SetFocus();
}
void Plot3DWiz::do_layout()
{
wxFlexGridSizer* grid_sizer_1 = new wxFlexGridSizer(4, 1, 3, 3);
wxBoxSizer* sizer_1 = new wxBoxSizer(wxHORIZONTAL);
wxFlexGridSizer* grid_sizer_2 = new wxFlexGridSizer(7, 2, 3, 3);
wxBoxSizer* sizer_2 = new wxBoxSizer(wxHORIZONTAL);
wxBoxSizer* sizer_3 = new wxBoxSizer(wxHORIZONTAL);
wxBoxSizer* sizer_4 = new wxBoxSizer(wxHORIZONTAL);
wxBoxSizer* sizer_5 = new wxBoxSizer(wxHORIZONTAL);
wxBoxSizer* sizer_6 = new wxBoxSizer(wxHORIZONTAL);
grid_sizer_1->Add(label_1, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 2);
grid_sizer_2->Add(label_2, 0, wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL | wxALL, 2);
grid_sizer_2->Add(text_ctrl_1, 1, wxEXPAND | wxALL, 2);
grid_sizer_2->Add(label_3, 0, wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL | wxALL, 2);
sizer_2->Add(text_ctrl_2, 0, wxALL, 2);
sizer_2->Add(label_4, 0, wxALL | wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL, 2);
sizer_2->Add(text_ctrl_3, 0, wxALL, 2);
sizer_2->Add(label_5, 0, wxALL | wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL, 2);
sizer_2->Add(text_ctrl_4, 0, wxALL, 2);
grid_sizer_2->Add(sizer_2, 1, wxEXPAND, 0);
grid_sizer_2->Add(label_6, 0, wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL | wxALL, 2);
sizer_3->Add(text_ctrl_5, 0, wxALL, 2);
sizer_3->Add(label_7, 0, wxALL | wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL, 2);
sizer_3->Add(text_ctrl_6, 0, wxALL, 2);
sizer_3->Add(label_8, 0, wxALL | wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL, 2);
sizer_3->Add(text_ctrl_7, 0, wxALL, 2);
grid_sizer_2->Add(sizer_3, 1, wxEXPAND, 0);
grid_sizer_2->Add(label_9, 0, wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL | wxALL, 2);
sizer_4->Add(text_ctrl_8, 0, wxALL, 2);
sizer_4->Add(label_10, 0, wxALIGN_CENTER_VERTICAL | wxALIGN_CENTER_HORIZONTAL | wxALL, 2);
sizer_4->Add(text_ctrl_9, 0, wxALL, 2);
grid_sizer_2->Add(sizer_4, 1, wxEXPAND, 0);
grid_sizer_2->Add(label_11, 0, wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL | wxALL, 2);
grid_sizer_2->Add(combo_box_1, 0, wxALL, 2);
grid_sizer_2->Add(label_12, 0, wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL | wxALL, 2);
sizer_5->Add(combo_box_2, 0, wxALL, 2);
sizer_5->Add(check_box_1, 0, wxALL | wxALIGN_CENTER_VERTICAL, 2);
grid_sizer_2->Add(sizer_5, 1, wxEXPAND, 0);
grid_sizer_2->Add(label_13, 0, wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL | wxALL, 2);
sizer_6->Add(text_ctrl_10, 0, wxALL | wxALIGN_CENTER_VERTICAL, 2);
sizer_6->Add(button_3, 0, wxALL, 2);
grid_sizer_2->Add(sizer_6, 1, wxEXPAND, 0);
grid_sizer_1->Add(grid_sizer_2, 1, wxEXPAND, 0);
grid_sizer_1->Add(static_line_1, 0, wxEXPAND | wxLEFT | wxRIGHT, 2);
sizer_1->Add(button_1, 0, wxLEFT | wxRIGHT, 5);
sizer_1->Add(button_2, 0, wxLEFT | wxRIGHT, 5);
grid_sizer_1->Add(sizer_1, 1, wxALIGN_RIGHT | wxTOP | wxBOTTOM, 3);
SetAutoLayout(true);
SetSizer(grid_sizer_1);
grid_sizer_1->Fit(this);
grid_sizer_1->SetSizeHints(this);
Layout();
}
void Plot3DWiz::SetValue(wxString s)
{
if (s.StartsWith(wxT("plot3d")))
Parse(s);
else if (s.StartsWith(wxT("wxplot3d")))
{
Parse(s.SubString(2, s.Length()));
combo_box_1->SetValue(_("inline"));
}
else
text_ctrl_1->SetValue(s);
text_ctrl_1->SetSelection(-1, -1);
}
void Plot3DWiz::Parse(wxString s)
{
int depth = 0;
unsigned int i = 0;
wxString curr;
s = s.SubString(7, s.Length());
// Function to plot
if (s.StartsWith(wxT("[")))
{
do
{
if (s.GetChar(i) == '[')
{
depth++;
if (depth > 1)
curr += s.GetChar(i);
}
else if (s.GetChar(i) == ']')
{
depth--;
if (depth > 0)
curr += s.GetChar(i);
}
else
curr += s.GetChar(i);
i++;
}
while (depth > 0);
}
else
{
while (i < s.Length() && s.GetChar(i) != ',')
{
curr += s.GetChar(i);
i++;
}
}
text_ctrl_1->SetValue(curr);
// Independent variable 1
while (i < s.Length() && s.GetChar(i) != '[')
i++;
i++;
curr = wxEmptyString;
while (i < s.Length() && s.GetChar(i) != ',')
{
curr += s.GetChar(i);
i++;
}
text_ctrl_2->SetValue(curr);
i++;
curr = wxEmptyString;
while (i < s.Length() && s.GetChar(i) != ',')
{
curr += s.GetChar(i);
i++;
}
text_ctrl_3->SetValue(curr);
i++;
curr = wxEmptyString;
while (i < s.Length() && s.GetChar(i) != ']')
{
curr += s.GetChar(i);
i++;
}
text_ctrl_4->SetValue(curr);
i++;
// Independent variable 2
while (i < s.Length() && s.GetChar(i) != '[')
i++;
i++;
curr = wxEmptyString;
while (i < s.Length() && s.GetChar(i) != ',')
{
curr += s.GetChar(i);
i++;
}
text_ctrl_5->SetValue(curr);
i++;
curr = wxEmptyString;
while (i < s.Length() && s.GetChar(i) != ',')
{
curr += s.GetChar(i);
i++;
}
text_ctrl_6->SetValue(curr);
i++;
curr = wxEmptyString;
while (i < s.Length() && s.GetChar(i) != ']')
{
curr += s.GetChar(i);
i++;
}
text_ctrl_7->SetValue(curr);
i++;
// Optional parameters
while (i < s.Length())
{
if (s.GetChar(i) == '[')
{
i++;
curr = wxEmptyString;
while (i < s.Length() && s.GetChar(i) != ',')
{
curr += s.GetChar(i);
i++;
}
curr.Trim();
curr.Trim(false);
if (curr == wxT("gnuplot_preamble"))
{
while (i < s.Length() && s.GetChar(i) != '"')
i++;
i++;
curr = wxEmptyString;
while (i < s.Length() && s.GetChar(i) != '"')
{
curr += s.GetChar(i);
i++;
}
combo_box_2->SetValue(curr);
}
else if (curr == wxT("gnuplot_out_file"))
{
while (i < s.Length() && s.GetChar(i) != '"')
i++;
i++;
curr = wxEmptyString;
while (i < s.Length() && s.GetChar(i) != '"')
{
curr += s.GetChar(i);
i++;
}
text_ctrl_10->SetValue(curr);
}
else if (curr == wxT("gnuplot_pm3d"))
{
curr = wxEmptyString;
while (i < s.Length() && s.GetChar(i) != ']')
{
curr += s.GetChar(i);
i++;
}
if (curr.Find(wxT("true")) > -1)
check_box_1->SetValue(true);
else if (curr.Find(wxT("false")) > -1)
check_box_1->SetValue(false);
}
}
i++;
}
}
wxString Plot3DWiz::GetValue()
{
wxString s = wxT("plot3d(");
wxString p = combo_box_2->GetValue();
wxString pl = text_ctrl_1->GetValue();
wxString f = combo_box_1->GetValue();
wxString file = text_ctrl_10->GetValue();
int xg = text_ctrl_8->GetValue();
int yg = text_ctrl_8->GetValue();
if (pl.Contains(wxT(", ")))
pl = wxT("[") + pl + wxT("]");
s += pl;
s += wxT(", [");
s += text_ctrl_2->GetValue();
s += wxT(",") + text_ctrl_3->GetValue();
s += wxT(",") + text_ctrl_4->GetValue();
;
s += wxT("], [");
s += text_ctrl_5->GetValue();
s += wxT(",") + text_ctrl_6->GetValue();
s += wxT(",") + text_ctrl_7->GetValue();
s += wxT("]");
if (f != _("default") && f != _("inline"))
s += wxT(", [plot_format,") + f + wxT("]");
if (xg != 30 || yg != 30)
{
s += wxT(",\n [grid,");
s += wxString::Format(wxT("%d"), xg);
s += wxT(",");
s += wxString::Format(wxT("%d"), yg);
s += wxT("]");
}
#if defined (__WXMSW__)
if (!check_box_1->IsChecked())
s += wxT(",\n [gnuplot_pm3d,false]");
#else
if (check_box_1->IsChecked())
s += wxT(",\n [gnuplot_pm3d,true]");
#endif
if (p.Length() > 0)
s += wxT(",\n [gnuplot_preamble, \"") + p + wxT("\"]");
if (file.Length())
{
s += wxT(",\n [gnuplot_term, ps]");
#if defined (__WXMSW__)
file.Replace(wxT("\\"), wxT("/"));
#endif
if (file.Right(4) != wxT(".eps") && file.Right(3) != wxT(".ps"))
file = file + wxT(".eps");
s += wxT(",\n [gnuplot_out_file, \"") + file + wxT("\"]");
}
else if (f == _("inline"))
s = wxT("wx") + s;
s += wxT(")$");
wxConfig::Get()->Write(wxT("Wiz/Plot3D/format"), combo_box_1->GetSelection());
wxConfig::Get()->Write(wxT("Wiz/Plot3D/pm3d"), check_box_1->GetValue());
return s;
}
void Plot3DWiz::OnCombobox(wxCommandEvent &event)
{
wxString selection = combo_box_2->GetStringSelection();
if (selection.StartsWith(wxT("set mapping cylindrical")))
{
text_ctrl_2->SetValue(wxT("ph"));
text_ctrl_3->SetValue(wxT("0"));
text_ctrl_4->SetValue(wxT("2*%pi"));
text_ctrl_5->SetValue(wxT("z"));
text_ctrl_6->SetValue(wxT("0"));
text_ctrl_7->SetValue(wxT("5"));
type = cylindrical;
}
else if (selection.StartsWith(wxT("set mapping spherical")))
{
text_ctrl_2->SetValue(wxT("th"));
text_ctrl_3->SetValue(wxT("0"));
text_ctrl_4->SetValue(wxT("2*%pi"));
text_ctrl_5->SetValue(wxT("ph"));
text_ctrl_6->SetValue(wxT("-%pi/2"));
text_ctrl_7->SetValue(wxT("%pi/2"));
type = spherical;
}
else
type = cartesian;
}
void Plot3DWiz::OnFileBrowse(wxCommandEvent& event)
{
wxString file = wxFileSelector(_("Save plot to file"), wxEmptyString,
wxT("plot3d.eps"), wxT("eps"),
_("Postscript file (*.eps)|*.eps|All|*"),
wxSAVE | wxOVERWRITE_PROMPT);
if (file.Length() > 0)
text_ctrl_10->SetValue(file);
}
BEGIN_EVENT_TABLE(Plot3DWiz, wxDialog)
EVT_COMBOBOX(combobox, Plot3DWiz::OnCombobox)
EVT_BUTTON(file_browse_3d, Plot3DWiz::OnFileBrowse)
END_EVENT_TABLE()
syntax highlighted by Code2HTML, v. 0.9.1