InvalWindowRgn( GetMacRootWindow() , updateRgn ) ;
DisposeRgn( updateRgn ) ;
}
+
+ for (wxNode *node = GetChildren().First(); node; node = node->Next())
+ {
+ wxWindow *child = (wxWindow*)node->Data();
+ if (child == m_vScrollBar) continue;
+ if (child == m_hScrollBar) continue;
+ if (child->IsTopLevel()) continue;
+ int x,y;
+ child->GetPosition( &x, &y );
+ int w,h;
+ child->GetSize( &w, &h );
+ child->SetSize( x+dx, y+dy, w, h );
+ }
+
}
void wxWindow::MacOnScroll(wxScrollEvent &event )
wevent.SetOrientation(event.GetOrientation());
wevent.m_eventObject = this;
- switch ( event.m_eventType )
- {
- case wxEVT_SCROLL_TOP:
+ if (event.m_eventType == wxEVT_SCROLL_TOP) {
wevent.m_eventType = wxEVT_SCROLLWIN_TOP;
- break;
-
- case wxEVT_SCROLL_BOTTOM:
+ } else
+ if (event.m_eventType == wxEVT_SCROLL_BOTTOM) {
wevent.m_eventType = wxEVT_SCROLLWIN_BOTTOM;
- break;
-
- case wxEVT_SCROLL_LINEUP:
+ } else
+ if (event.m_eventType == wxEVT_SCROLL_LINEUP) {
wevent.m_eventType = wxEVT_SCROLLWIN_LINEUP;
- break;
-
- case wxEVT_SCROLL_LINEDOWN:
+ } else
+ if (event.m_eventType == wxEVT_SCROLL_LINEDOWN) {
wevent.m_eventType = wxEVT_SCROLLWIN_LINEDOWN;
- break;
-
- case wxEVT_SCROLL_PAGEUP:
+ } else
+ if (event.m_eventType == wxEVT_SCROLL_PAGEUP) {
wevent.m_eventType = wxEVT_SCROLLWIN_PAGEUP;
- break;
-
- case wxEVT_SCROLL_PAGEDOWN:
+ } else
+ if (event.m_eventType == wxEVT_SCROLL_PAGEDOWN) {
wevent.m_eventType = wxEVT_SCROLLWIN_PAGEDOWN;
- break;
-
- case wxEVT_SCROLL_THUMBTRACK:
+ } else
+ if (event.m_eventType == wxEVT_SCROLL_THUMBTRACK) {
wevent.m_eventType = wxEVT_SCROLLWIN_THUMBTRACK;
- break;
-
}
GetEventHandler()->ProcessEvent(wevent);
RgnHandle newupdate = NewRgn() ;
wxSize point = GetClientSize() ;
wxPoint origin = GetClientAreaOrigin() ;
+
SetRectRgn( newupdate , origin.x , origin.y , origin.x + point.x , origin.y+point.y ) ;
SectRgn( newupdate , m_macUpdateRgn , newupdate ) ;
OffsetRgn( newupdate , -origin.x , -origin.y ) ;
event.SetEventObject(this);
GetEventHandler()->ProcessEvent(event);
}
- {
- }
-
RgnHandle childupdate = NewRgn() ;
-
+
for (wxNode *node = GetChildren().First(); node; node = node->Next())
{
wxWindow *child = (wxWindow*)node->Data();
if ( m_formerPort != m_currentPort )
SetPort( m_formerPort ) ;
}
+
+// Find the wxWindow at the current mouse position, returning the mouse
+// position.
+wxWindow* wxFindWindowAtPointer(wxPoint& pt)
+{
+ pt = wxGetMousePosition();
+ wxWindow* found = wxFindWindowAtPoint(pt);
+ return found;
+}
+
+// Get the current mouse position.
+wxPoint wxGetMousePosition()
+{
+ int x, y;
+ wxGetMousePosition(& x, & y);
+ return wxPoint(x, y);
+}
+