X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/a152561c76dbed50d23f28d6e5761b4ece968156..b3adca1e989f5520461c1e63ee6fcafcd0c7cd8e:/src/palmos/toplevel.cpp diff --git a/src/palmos/toplevel.cpp b/src/palmos/toplevel.cpp index 78e34bc01f..2093565f33 100644 --- a/src/palmos/toplevel.cpp +++ b/src/palmos/toplevel.cpp @@ -17,10 +17,6 @@ // headers // ---------------------------------------------------------------------------- -#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA) - #pragma implementation "toplevel.h" -#endif - // For compilers that support precompilation, includes "wx.h". #include "wx/wxprec.h" @@ -28,25 +24,31 @@ #pragma hdrstop #endif +#include "wx/toplevel.h" + #ifndef WX_PRECOMP #include "wx/app.h" - #include "wx/toplevel.h" #include "wx/dialog.h" #include "wx/string.h" #include "wx/log.h" #include "wx/intl.h" #include "wx/frame.h" #include "wx/containr.h" // wxSetFocusToChild() + #include "wx/button.h" + #include "wx/checkbox.h" + #include "wx/radiobut.h" + #include "wx/slider.h" + #include "wx/module.h" #endif //WX_PRECOMP -#include "wx/module.h" #include "wx/display.h" // controls for sending select event -#include "wx/button.h" -#include "wx/checkbox.h" -#include "wx/radiobut.h" #include "wx/tglbtn.h" +#include "wx/datectrl.h" + +#include +#include // ---------------------------------------------------------------------------- // globals @@ -58,6 +60,8 @@ extern const wxChar *wxCanvasClassName; // Pointer to the currently active frame for the form event handler. wxTopLevelWindowPalm* ActiveParentFrame; +static Boolean FrameFormHandleEvent(EventType *event); + // ============================================================================ // wxTopLevelWindowPalm implementation // ============================================================================ @@ -79,11 +83,6 @@ WXDWORD wxTopLevelWindowPalm::PalmGetStyle(long style, WXDWORD *exflags) const return 0; } -WXHWND wxTopLevelWindowPalm::PalmGetParent() const -{ - return NULL; -} - bool wxTopLevelWindowPalm::Create(wxWindow *parent, wxWindowID id, const wxString& title, @@ -133,9 +132,9 @@ bool wxTopLevelWindowPalm::Create(wxWindow *parent, if(FrameForm==NULL) return false; - FrmSetEventHandler(FrameForm,FrameFormHandleEvent); + FrmSetEventHandler((FormType *)FrameForm,FrameFormHandleEvent); - FrmSetActiveForm(FrameForm); + FrmSetActiveForm((FormType *)FrameForm); ActiveParentFrame=this; @@ -146,6 +145,18 @@ wxTopLevelWindowPalm::~wxTopLevelWindowPalm() { } +// --------------------------------------------------------------------------- +// implementation +// --------------------------------------------------------------------------- + +WXWINHANDLE wxTopLevelWindowPalm::GetWinHandle() const +{ + FormType *form = (FormType *)GetForm(); + if(form) + return FrmGetWindowHandle(form); + return NULL; +} + // ---------------------------------------------------------------------------- // wxTopLevelWindowPalm showing // ---------------------------------------------------------------------------- @@ -156,7 +167,7 @@ void wxTopLevelWindowPalm::DoShowWindow(int nShowCmd) bool wxTopLevelWindowPalm::Show(bool show) { - FrmDrawForm(FrameForm); + FrmDrawForm((FormType *)FrameForm); wxPaintEvent event(m_windowId); event.SetEventObject(this); @@ -194,7 +205,7 @@ void wxTopLevelWindowPalm::Restore() void wxTopLevelWindowPalm::DoGetSize( int *width, int *height ) const { RectangleType rect; - FrmGetFormBounds( GetForm() , &rect ); + FrmGetFormBounds( (FormType *)GetForm() , &rect ); if(width) *width = rect.extent.x; if(height) @@ -214,10 +225,15 @@ bool wxTopLevelWindowPalm::ShowFullScreen(bool show, long style) // wxTopLevelWindowPalm misc // ---------------------------------------------------------------------------- -void wxTopLevelWindowPalm::SetIcon(const wxIcon& icon) +void wxTopLevelWindowPalm::SetTitle( const wxString& WXUNUSED(title)) { } +wxString wxTopLevelWindowPalm::GetTitle() const +{ + return wxEmptyString; +} + void wxTopLevelWindowPalm::SetIcons(const wxIconBundle& icons) { } @@ -227,50 +243,96 @@ bool wxTopLevelWindowPalm::EnableCloseButton(bool enable) return false; } -FormType *wxTopLevelWindowPalm::GetForm() const +WXFORMPTR wxTopLevelWindowPalm::GetForm() const { return FrmGetActiveForm(); } -#ifndef __WXWINCE__ - bool wxTopLevelWindowPalm::SetShape(const wxRegion& region) { return false; } -#endif // !__WXWINCE__ - // ---------------------------------------------------------------------------- -// wxTopLevelWindow event handling +// wxTopLevelWindow native event handling // ---------------------------------------------------------------------------- -bool wxTopLevelWindowPalm::HandleControlSelect(EventType* event) +bool wxTopLevelWindowPalm::HandleControlSelect(WXEVENTPTR event) { - int id = event->data.ctlSelect.controlID; + const EventType *palmEvent = (EventType *)event; + const int id = palmEvent->data.ctlSelect.controlID; + wxWindow* win = FindWindowById(id,this); if(win==NULL) return false; +#if wxUSE_BUTTON wxButton* button = wxDynamicCast(win,wxButton); if(button) return button->SendClickEvent(); +#endif // wxUSE_BUTTON +#if wxUSE_CHECKBOX wxCheckBox* checkbox = wxDynamicCast(win,wxCheckBox); if(checkbox) return checkbox->SendClickEvent(); +#endif // wxUSE_CHECKBOX +#if wxUSE_TOGGLEBTN wxToggleButton* toggle = wxDynamicCast(win,wxToggleButton); if(toggle) return toggle->SendClickEvent(); +#endif // wxUSE_TOGGLEBTN +#if wxUSE_RADIOBTN wxRadioButton* radio = wxDynamicCast(win,wxRadioButton); if(radio) return radio->SendClickEvent(); +#endif // wxUSE_RADIOBTN + +#if wxUSE_DATEPICKCTRL + wxDatePickerCtrl* datepicker = wxDynamicCast(win,wxDatePickerCtrl); + if(datepicker) + return datepicker->SendClickEvent(); +#endif // wxUSE_DATEPICKCTRL + +#if wxUSE_SLIDER + wxSlider* slider = wxDynamicCast(win,wxSlider); + if(slider) + return slider->SendUpdatedEvent(); +#endif // wxUSE_SLIDER + + return false; +} + +bool wxTopLevelWindowPalm::HandleControlRepeat(WXEVENTPTR event) +{ + const EventType *palmEvent = (EventType *)event; + const int id = palmEvent->data.ctlRepeat.controlID; + + wxWindow* win = FindWindowById(id, this); + if(win==NULL) + return false; + +#if wxUSE_SLIDER + wxSlider* slider = wxDynamicCast(win,wxSlider); + if(slider) + return slider->SendScrollEvent(event); +#endif // wxUSE_SLIDER return false; } +bool wxTopLevelWindowPalm::HandleSize(WXEVENTPTR event) +{ + const EventType *palmEvent = (EventType *)event; + wxSize newSize(palmEvent->data.winResized.newBounds.extent.x, + palmEvent->data.winResized.newBounds.extent.y); + wxSizeEvent eventWx(newSize,GetId()); + eventWx.SetEventObject(this); + return GetEventHandler()->ProcessEvent(eventWx); +} + void wxTopLevelWindowPalm::OnActivate(wxActivateEvent& event) { } @@ -289,14 +351,23 @@ void wxTopLevelWindowPalm::OnActivate(wxActivateEvent& event) * finds a better solution, please let me know. My email address is * wbo@freeshell.org */ -static Boolean FrameFormHandleEvent(EventType* event) +static Boolean FrameFormHandleEvent(EventType *event) { - wxFrame* frame = wxDynamicCast(ActiveParentFrame,wxFrame); + // frame and tlw point to the same object but they are for convenience + // of calling proper structure withiout later dynamic typcasting + wxFrame* frame = wxDynamicCast(ActiveParentFrame,wxFrame); + wxTopLevelWindowPalm* tlw = ActiveParentFrame; Boolean handled = false; switch (event->eType) { case ctlSelectEvent: - handled = frame->HandleControlSelect(event); + handled = tlw->HandleControlSelect(event); + break; + case ctlRepeatEvent: + handled = tlw->HandleControlRepeat(event); + break; + case winResizedEvent: + handled = tlw->HandleSize(event); break; #if wxUSE_MENUS_NATIVE case menuOpenEvent: