#ifndef WX_PRECOMP
#include "wx/log.h"
+ #include "wx/bitmap.h"
#include "wx/button.h"
#include "wx/checkbox.h"
#include "wx/radiobox.h"
#include "wx/statline.h"
#include "widgets.h"
-
#include "icons/statbox.xpm"
// ----------------------------------------------------------------------------
StaticVAlign_Max
};
+// ----------------------------------------------------------------------------
+// MyStaticText and MyStaticBox
+// ----------------------------------------------------------------------------
+
+// these 2 classes simply show that the static controls can get the mouse
+// clicks too -- this used to be broken under MSW but works now
+
+class MyStaticText : public wxStaticText
+{
+public:
+ MyStaticText(wxWindow* parent,
+ wxWindowID id,
+ const wxString& label,
+ const wxPoint& pos = wxDefaultPosition,
+ const wxSize& size = wxDefaultSize,
+ long style = 0)
+ : wxStaticText(parent, id, label, pos, size, style)
+ {
+ }
+
+protected:
+ void OnMouseEvent(wxMouseEvent& event)
+ {
+ wxLogMessage(wxT("Clicked on static text"));
+ }
+
+ DECLARE_EVENT_TABLE()
+};
+
+class MyStaticBox : public wxStaticBox
+{
+public:
+ MyStaticBox(wxWindow* parent,
+ wxWindowID id,
+ const wxString& label,
+ const wxPoint& pos = wxDefaultPosition,
+ const wxSize& size = wxDefaultSize,
+ long style = 0)
+ : wxStaticBox(parent, id, label, pos, size, style)
+ {
+ }
+
+protected:
+ void OnMouseEvent(wxMouseEvent& event)
+ {
+ wxLogMessage(wxT("Clicked on static box"));
+ }
+
+ DECLARE_EVENT_TABLE()
+};
+
+BEGIN_EVENT_TABLE(MyStaticText, wxStaticText)
+ EVT_LEFT_UP(MyStaticText::OnMouseEvent)
+END_EVENT_TABLE()
+
+BEGIN_EVENT_TABLE(MyStaticBox, wxStaticBox)
+ EVT_LEFT_UP(MyStaticBox::OnMouseEvent)
+END_EVENT_TABLE()
+
// ----------------------------------------------------------------------------
// StaticWidgetsPage
// ----------------------------------------------------------------------------
*m_radioVAlign;
// the controls and the sizer containing them
+ wxStaticBox *m_staticBox;
wxStaticBoxSizer *m_sizerStatBox;
wxStaticText *m_statText;
wxStaticLine *m_statLine;
*m_textLabel;
private:
- DECLARE_EVENT_TABLE();
- DECLARE_WIDGETS_PAGE(StaticWidgetsPage);
+ DECLARE_EVENT_TABLE()
+ DECLARE_WIDGETS_PAGE(StaticWidgetsPage)
};
// ----------------------------------------------------------------------------
m_statLine = (wxStaticLine *)NULL;
m_statText = (wxStaticText *)NULL;
+ m_staticBox = (wxStaticBox *)NULL;
m_sizerStatBox = (wxStaticBoxSizer *)NULL;
m_sizerStatic = (wxSizer *)NULL;
// right pane
wxSizer *sizerRight = new wxBoxSizer(wxHORIZONTAL);
- sizerRight->SetMinSize(250, 0);
+ sizerRight->SetMinSize(150, 0);
m_sizerStatic = sizerRight;
CreateStatic();
// the 3 panes panes compose the window
sizerTop->Add(sizerLeft, 0, wxGROW | (wxALL & ~wxLEFT), 10);
- sizerTop->Add(sizerMiddle, 1, wxGROW | wxALL, 10);
+ sizerTop->Add(sizerMiddle, 0, wxGROW | wxALL, 10);
sizerTop->Add(sizerRight, 1, wxGROW | (wxALL & ~wxRIGHT), 10);
// final initializations
if ( m_sizerStatBox )
{
- m_sizerStatic->Remove(m_sizerStatBox);
-
+ delete m_staticBox;
// delete m_sizerStatBox; -- deleted by Remove()
+ m_sizerStatic->Remove(m_sizerStatBox);
delete m_statText;
delete m_statLine;
}
flagsText |= align;
flagsBox |= align;
- wxStaticBox *box = new wxStaticBox(this, -1, m_textBox->GetValue(),
- wxDefaultPosition, wxDefaultSize,
- flagsBox);
- m_sizerStatBox = new wxStaticBoxSizer(box, isVert ? wxHORIZONTAL
- : wxVERTICAL);
+ m_staticBox = new MyStaticBox(this, -1, m_textBox->GetValue(),
+ wxDefaultPosition, wxDefaultSize,
+ flagsBox);
+ m_sizerStatBox = new wxStaticBoxSizer(m_staticBox, isVert ? wxHORIZONTAL
+ : wxVERTICAL);
- m_statText = new wxStaticText(this, -1, m_textLabel->GetValue(),
+ m_statText = new MyStaticText(this, -1, m_textLabel->GetValue(),
wxDefaultPosition, wxDefaultSize,
flagsText);