///////////////////////////////////////////////////////////////////////////////
-// Name: palmos/toplevel.cpp
+// Name: src/palmos/toplevel.cpp
// Purpose: implements wxTopLevelWindow for Palm OS
-// Author: William Osborne
-// Modified by:
+// Author: William Osborne - minimal working wxPalmOS port
+// Modified by: Wlodzimierz ABX Skiba - more than minimal functionality
// Created: 10/13/04
-// RCS-ID: $Id:
-// Copyright: (c) William Osborne <wbo@freeshell.org>
+// RCS-ID: $Id$
+// Copyright: (c) William Osborne <wbo@freeshell.org>, Wlodzimierz Skiba
// Licence: wxWindows licence
///////////////////////////////////////////////////////////////////////////////
#endif //WX_PRECOMP
#include "wx/module.h"
-
#include "wx/display.h"
-#ifndef ICON_BIG
- #define ICON_BIG 1
-#endif
-
-#ifndef ICON_SMALL
- #define ICON_SMALL 0
-#endif
-
+// controls for sending select event
+#include "wx/button.h"
+#include "wx/checkbox.h"
+#include "wx/radiobut.h"
+#include "wx/tglbtn.h"
+#include "wx/slider.h"
// ----------------------------------------------------------------------------
// globals
extern const wxChar *wxCanvasClassName;
// Pointer to the currently active frame for the form event handler.
-wxFrame* ActiveParentFrame;
+wxTopLevelWindowPalm* ActiveParentFrame;
// ============================================================================
// wxTopLevelWindowPalm implementation
return NULL;
}
-bool wxTopLevelWindowPalm::CreateDialog(const void *dlgTemplate,
- const wxString& title,
- const wxPoint& pos,
- const wxSize& size)
-{
- return false;
-}
-
-bool wxTopLevelWindowPalm::CreateFrame(const wxString& title,
- const wxPoint& pos,
- const wxSize& size)
-{
- return false;
-}
-
bool wxTopLevelWindowPalm::Create(wxWindow *parent,
- wxWindowID id,
- const wxString& title,
- const wxPoint& pos,
- const wxSize& size,
- long style,
- const wxString& name)
+ wxWindowID id,
+ const wxString& title,
+ const wxPoint& pos,
+ const wxSize& size,
+ long style,
+ const wxString& name)
{
- ActiveParentFrame=NULL;
-
- wxTopLevelWindows.Append(this);
-
- if ( parent )
- parent->AddChild(this);
-
- m_windowId = id == -1 ? NewControlId() : id;
-
- FrameForm=FrmNewForm(m_windowId,title,0,0,160,160,false,0,NULL,0,NULL,0);
- if(FrameForm==0)
+ // this is a check for limitation mentioned before FrameFormHandleEvent() code
+ if(wxTopLevelWindows.GetCount()>0)
return false;
- FrmSetEventHandler(FrameForm,FrameFormHandleEvent);
-
- return true;
-}
+ ActiveParentFrame=NULL;
-bool wxTopLevelWindowPalm::Create(wxWindow *parent,
- wxWindowID id,
- const wxString& title,
- const wxPoint& pos,
- const wxSize& size,
- long style,
- const wxString& name,
- wxFrame* PFrame)
-{
wxTopLevelWindows.Append(this);
if ( parent )
parent->AddChild(this);
- m_windowId = id == -1 ? NewControlId() : id;
-
- FrameForm=FrmNewForm(m_windowId,title,0,0,160,160,false,0,NULL,0,NULL,0);
- if(FrameForm==0)
+ SetId( id == wxID_ANY ? NewControlId() : id );
+
+ WinConstraintsType constraints;
+ memset(&constraints, 0, sizeof(WinConstraintsType));
+ // position
+ constraints.x_pos = ( pos.x == wxDefaultCoord ) ? winUndefConstraint : pos.x;
+ constraints.y_pos = ( pos.y == wxDefaultCoord ) ? winUndefConstraint : pos.y;
+ // size
+ constraints.x_min = winUndefConstraint;
+ constraints.x_max = winMaxConstraint;
+ constraints.x_pref = ( size.x == wxDefaultCoord ) ? winUndefConstraint : size.x;
+ constraints.y_min = winUndefConstraint;
+ constraints.y_max = winMaxConstraint;
+ constraints.y_pref = ( size.y == wxDefaultCoord ) ? winUndefConstraint : size.y;
+
+ FrameForm = FrmNewFormWithConstraints(
+ GetId(),
+ title.c_str(),
+ winFlagBackBuffer,
+ &constraints,
+ 0,
+ NULL,
+ 0,
+ NULL,
+ 0
+ );
+
+ if(FrameForm==NULL)
return false;
FrmSetEventHandler(FrameForm,FrameFormHandleEvent);
-
+
FrmSetActiveForm(FrameForm);
-
- ActiveParentFrame=PFrame;
-
+
+ ActiveParentFrame=this;
+
return true;
}
bool wxTopLevelWindowPalm::Show(bool show)
{
FrmDrawForm(FrameForm);
-
+
wxPaintEvent event(m_windowId);
event.SetEventObject(this);
- GetEventHandler()->ProcessEvent(event);
-
+ GetEventHandler()->ProcessEvent(event);
+
return true;
}
{
}
+void wxTopLevelWindowPalm::DoGetSize( int *width, int *height ) const
+{
+ RectangleType rect;
+ FrmGetFormBounds( GetForm() , &rect );
+ if(width)
+ *width = rect.extent.x;
+ if(height)
+ *height = rect.extent.y;
+}
+
// ----------------------------------------------------------------------------
// wxTopLevelWindowPalm fullscreen
// ----------------------------------------------------------------------------
return false;
}
+FormType *wxTopLevelWindowPalm::GetForm() const
+{
+ return FrmGetActiveForm();
+}
+
#ifndef __WXWINCE__
bool wxTopLevelWindowPalm::SetShape(const wxRegion& region)
// wxTopLevelWindow event handling
// ----------------------------------------------------------------------------
+bool wxTopLevelWindowPalm::HandleControlSelect(EventType* event)
+{
+ int id = event->data.ctlSelect.controlID;
+ wxWindow* win = FindWindowById(id,this);
+ if(win==NULL)
+ return false;
+
+ wxButton* button = wxDynamicCast(win,wxButton);
+ if(button)
+ return button->SendClickEvent();
+
+ wxCheckBox* checkbox = wxDynamicCast(win,wxCheckBox);
+ if(checkbox)
+ return checkbox->SendClickEvent();
+
+ wxToggleButton* toggle = wxDynamicCast(win,wxToggleButton);
+ if(toggle)
+ return toggle->SendClickEvent();
+
+ wxRadioButton* radio = wxDynamicCast(win,wxRadioButton);
+ if(radio)
+ return radio->SendClickEvent();
+
+ wxSlider* slider = wxDynamicCast(win,wxSlider);
+ if(slider)
+ return slider->SendUpdatedEvent();
+
+ return false;
+}
+
void wxTopLevelWindowPalm::OnActivate(wxActivateEvent& event)
{
}
/* Palm OS Event handler for the window
- *
- * This function *must* be located outside of the wxTopLevelWindow class because
- * the Palm OS API expects a standalone C function as a callback. You cannot
- * pass a pointer to a member function of a C++ class as a callback because the
- * prototypes don't match. (A member function has a hidden "this" pointer as
+ *
+ * This function *must* be located outside of the wxTopLevelWindow class because
+ * the Palm OS API expects a standalone C function as a callback. You cannot
+ * pass a pointer to a member function of a C++ class as a callback because the
+ * prototypes don't match. (A member function has a hidden "this" pointer as
* its first parameter).
- *
- * This event handler uses a global pointer to the current wxFrame to process
- * the events generated by the Palm OS form API. I know this is ugly, but right
- * now I can't think of any other way to deal with this problem. If someone
- * finds a better solution, please let me know. My email address is
+ *
+ * This event handler uses a global pointer to the current wxFrame to process
+ * the events generated by the Palm OS form API. I know this is ugly, but right
+ * now I can't think of any other way to deal with this problem. If someone
+ * finds a better solution, please let me know. My email address is
* wbo@freeshell.org
*/
-static Boolean FrameFormHandleEvent(EventType* pEvent)
+static Boolean FrameFormHandleEvent(EventType* event)
{
- Boolean fHandled = false;
- FormType* pForm;
- WinHandle hWindow;
- int ItemID=0;
-
- switch (pEvent->eType) {
+ wxFrame* frame = wxDynamicCast(ActiveParentFrame,wxFrame);
+ Boolean handled = false;
+
+ switch (event->eType) {
case ctlSelectEvent:
+ handled = frame->HandleControlSelect(event);
break;
#if wxUSE_MENUS_NATIVE
case menuOpenEvent:
- fHandled=ActiveParentFrame->HandleMenuOpen();
- break;
+ handled = frame->HandleMenuOpen();
+ break;
case menuEvent:
- ItemID=pEvent->data.menu.itemID;
- fHandled=ActiveParentFrame->HandleMenuSelect(ItemID);
+ handled = frame->HandleMenuSelect(event);
break;
#endif
default:
break;
}
-
- return fHandled;
+
+ return handled;
}