///
/// 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 "MatWiz.h"
MatWiz::MatWiz(wxWindow* parent, int id, const wxString& title,
int type, int w, int h,
const wxPoint& pos, const wxSize& size, long style):
wxDialog(parent, id, title, pos, size, wxDEFAULT_DIALOG_STYLE)
{
m_height = h;
m_width = w;
m_matrixType = type;
label_1 = new wxStaticText(this, -1, title);
int width = 50 > 400 / m_width ? 50 : 400 / m_width;
for (int i = 0; i < h*w; i++)
{
m_inputs.push_back(new BTextCtrl(this, -1, wxT("0"), wxDefaultPosition,
wxSize(width, -1)));
}
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
set_properties();
do_layout();
}
void MatWiz::set_properties()
{
label_1->SetFont(wxFont(20, wxROMAN, wxITALIC, wxNORMAL, 0, wxEmptyString));
button_1->SetDefault();
if (m_matrixType == MATRIX_ANTISYMETRIC)
{
for (int i = 0; i < m_height; i++)
for (int j = 0; j <= i; j++)
m_inputs[i*m_width + j]->Enable(false);
}
else if (m_matrixType == MATRIX_SYMETRIC)
{
for (int i = 0; i < m_height; i++)
for (int j = 0; j < i; j++)
m_inputs[i*m_width + j]->Enable(false);
}
else if (m_matrixType == MATRIX_DIAGONAL)
{
for (int i = 0; i < m_height; i++)
for (int j = 0; j < m_width; j++)
if (i != j)
m_inputs[i*m_width + j]->Enable(false);
}
#if defined __WXMSW__
button_1->SetDefault();
#else
button_2->SetDefault();
#endif
m_inputs[0]->SetFocus();
m_inputs[0]->SetSelection(-1, -1);
}
void MatWiz::do_layout()
{
wxFlexGridSizer* grid_sizer_1 = new wxFlexGridSizer(4, 1, 3, 3);
wxFlexGridSizer* grid_sizer_2 = new wxFlexGridSizer(m_height + 1, m_width + 1, 1, 1);
wxBoxSizer* sizer_1 = new wxBoxSizer(wxHORIZONTAL);
wxStaticText* text;
grid_sizer_2->Add(20, 20, 0, 0);
for (int i = 1; i <= m_width; i++)
{
text = new wxStaticText(this, -1, wxString::Format(wxT("%d"), i),
wxDefaultPosition, wxDefaultSize, wxALIGN_CENTRE);
grid_sizer_2->Add(text, 0,
wxALIGN_CENTER_HORIZONTAL | wxALIGN_CENTER_VERTICAL, 0);
}
for (int j = 0; j < m_height; j++)
{
text = new wxStaticText(this, -1, wxString::Format(wxT("%d"), j + 1),
wxDefaultPosition, wxDefaultSize, wxALIGN_CENTRE);
grid_sizer_2->Add(text, 0,
wxALIGN_CENTER_HORIZONTAL | wxALIGN_CENTER_VERTICAL, 0);
for (int i = 0; i < m_width; i++)
{
grid_sizer_2->Add(m_inputs[j*m_width + i], 0, wxALL, 1);
}
}
grid_sizer_1->Add(label_1, 0, wxALL | wxALIGN_CENTER_HORIZONTAL, 1);
grid_sizer_1->Add(grid_sizer_2, 1, wxALL | wxALIGN_CENTER_HORIZONTAL, 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();
}
wxString MatWiz::GetValue()
{
wxString cmd = wxT("matrix(");
for (int i = 0; i < m_height; i++)
{
cmd += wxT("\n [");
for (int j = 0; j < m_width; j++)
{
if (m_matrixType == MATRIX_SYMETRIC && i > j)
cmd += m_inputs[j * m_width + i]->GetValue();
else if (m_matrixType == MATRIX_ANTISYMETRIC && i > j)
cmd += wxT("-(") + m_inputs[j * m_width + i]->GetValue() + wxT(")");
else
cmd += m_inputs[i * m_width + j]->GetValue();
if (j < m_width - 1)
cmd += wxT(",");
else
cmd += wxT("]");
}
if (i < m_height - 1)
cmd += wxT(", ");
}
if (m_width > 7 || m_height > 7)
cmd += wxT("\n)$");
else
cmd += wxT("\n);");
return cmd;
}
MatDim::MatDim(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, title);
label_2 = new wxStaticText(this, -1, _("Rows:"));
text_ctrl_1 = new BTextCtrl(this, -1, wxT("3"), wxDefaultPosition,
wxSize(150, -1));
label_3 = new wxStaticText(this, -1, _("Columns:"));
text_ctrl_2 = new BTextCtrl(this, -1, wxT("3"), wxDefaultPosition,
wxSize(150, -1));
label_4 = new wxStaticText(this, -1, _("Type:"));
const wxString combo_box_1_choices[] =
{
_("general"),
_("diagonal"),
_("symmetric"),
_("antisymmetric")
};
combo_box_1 = new wxComboBox(this, -1, wxEmptyString, wxDefaultPosition,
wxSize(150, -1), 4,
combo_box_1_choices,
wxCB_DROPDOWN | wxCB_READONLY);
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
set_properties();
do_layout();
}
void MatDim::set_properties()
{
label_1->SetFont(wxFont(20, wxROMAN, wxITALIC, wxNORMAL, 0, wxEmptyString));
#if defined __WXMSW__
button_1->SetDefault();
#else
button_2->SetDefault();
#endif
combo_box_1->SetSelection(0);
text_ctrl_1->SetFocus();
text_ctrl_1->SetSelection(-1, -1);
}
void MatDim::do_layout()
{
wxFlexGridSizer* grid_sizer_1 = new wxFlexGridSizer(4, 1, 3, 3);
wxBoxSizer* sizer_1 = new wxBoxSizer(wxHORIZONTAL);
wxFlexGridSizer* grid_sizer_2 = new wxFlexGridSizer(3, 2, 3, 3);
grid_sizer_1->Add(label_1, 0, wxALL | wxALIGN_CENTER_HORIZONTAL, 1);
grid_sizer_2->Add(label_2, 0, wxALL | wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL, 2);
grid_sizer_2->Add(text_ctrl_1, 0, wxALL, 2);
grid_sizer_2->Add(label_3, 0, wxALL | wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL, 2);
grid_sizer_2->Add(text_ctrl_2, 0, wxALL, 2);
grid_sizer_2->Add(label_4, 0, wxALL | wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL, 2);
grid_sizer_2->Add(combo_box_1, 0, wxALL, 2);
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 | wxBOTTOM, 3);
SetAutoLayout(true);
SetSizer(grid_sizer_1);
grid_sizer_1->Fit(this);
grid_sizer_1->SetSizeHints(this);
Layout();
}
int MatDim::GetMatrixType()
{
int type = combo_box_1->GetSelection();
if (type == 0)
return MATRIX_GENERAL;
if (type == 1)
return MATRIX_DIAGONAL;
if (type == 2)
return MATRIX_SYMETRIC;
return MATRIX_ANTISYMETRIC;
}
syntax highlighted by Code2HTML, v. 0.9.1