X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/0906c58d0533380cd706b4de2a88615f0f187995..42b1fb630d94b919d455c1f0f2212bc6bcc04d46:/src/generic/propdlg.cpp diff --git a/src/generic/propdlg.cpp b/src/generic/propdlg.cpp index f94ec74a30..5c7c51b26d 100644 --- a/src/generic/propdlg.cpp +++ b/src/generic/propdlg.cpp @@ -22,6 +22,8 @@ #include "wx/defs.h" +#if wxUSE_BOOKCTRL + #ifndef WX_PRECOMP #include "wx/button.h" #include "wx/sizer.h" @@ -39,23 +41,24 @@ IMPLEMENT_DYNAMIC_CLASS(wxPropertySheetDialog, wxDialog) -bool wxPropertySheetDialog::Create(wxWindow* parent, wxWindowID id, const wxString& title, +BEGIN_EVENT_TABLE(wxPropertySheetDialog, wxDialog) + EVT_ACTIVATE(wxPropertySheetDialog::OnActivate) +END_EVENT_TABLE() + +bool wxPropertySheetDialog::Create(wxWindow* parent, wxWindowID id, const wxString& title, const wxPoint& pos, const wxSize& sz, long style, const wxString& name) { -#if defined(__SMARTPHONE__) || defined(__POCKETPC__) - style = wxNO_BORDER; -#endif - if (!wxDialog::Create(parent, id, title, pos, sz, style, name)) + if (!wxDialog::Create(parent, id, title, pos, sz, style|wxCLIP_CHILDREN, name)) return false; - + wxBoxSizer *topSizer = new wxBoxSizer( wxVERTICAL ); SetSizer(topSizer); // This gives more space around the edges m_innerSizer = new wxBoxSizer( wxVERTICAL ); - int extraSpace = 5; + int extraSpace = 2; #if defined(__SMARTPHONE__) || defined(__POCKETPC__) extraSpace=0; #endif @@ -78,8 +81,13 @@ void wxPropertySheetDialog::LayoutDialog() { #if !defined(__SMARTPHONE__) && !defined(__POCKETPC__) GetSizer()->Fit(this); + GetSizer()->SetSizeHints(this); Centre(wxBOTH); #endif +#if defined(__SMARTPHONE__) + if (m_bookCtrl) + m_bookCtrl->SetFocus(); +#endif } // Creates the buttons, if any @@ -90,18 +98,21 @@ void wxPropertySheetDialog::CreateButtons(int flags) // Perhaps that could be embedded in CreateButtonSizer() directly. SetRightMenu(wxID_CANCEL); SetLeftMenu(wxID_OK); + wxUnusedVar(flags); #elif defined(__POCKETPC__) // Do nothing + wxUnusedVar(flags); #else wxSizer* sizer = CreateButtonSizer(flags); - m_innerSizer->Add( sizer, 0, wxGROW|wxALIGN_CENTER_VERTICAL|wxTOP|wxBOTTOM, 5); + m_innerSizer->Add( sizer, 0, wxGROW|wxALIGN_CENTER_VERTICAL|wxTOP|wxBOTTOM|wxLEFT|wxRIGHT, 2); + m_innerSizer->AddSpacer(2); #endif } // Creates the book control wxBookCtrlBase* wxPropertySheetDialog::CreateBookCtrl() { - int style = 0; + int style = wxCLIP_CHILDREN; #if defined(__POCKETPC__) && wxUSE_NOTEBOOK style |= wxNB_BOTTOM|wxNB_FLAT; #else @@ -123,3 +134,22 @@ void wxPropertySheetDialog::AddBookCtrl(wxSizer* sizer) #endif } +void wxPropertySheetDialog::OnActivate(wxActivateEvent& event) +{ +#if defined(__SMARTPHONE__) + // Attempt to focus the choice control: not yet working, but might + // be a step in the right direction. OnActivate overrides the default + // handler in toplevel.cpp that sets the focus for the first child of + // of the dialog (the choicebook). + if (event.GetActive()) + { + wxChoicebook* choiceBook = wxDynamicCast(GetBookCtrl(), wxChoicebook); + if (choiceBook) + choiceBook->SetFocus(); + } + else +#endif + event.Skip(); +} + +#endif // wxUSE_BOOKCTRL