#define wxWINDOW_VSCROLL 5997
#define MAC_SCROLLBAR_SIZE 16
-#include <wx/mac/uma.h>
+#include "wx/mac/uma.h"
#if wxUSE_DRAG_AND_DROP
#include "wx/dnd.h"
}
#endif // wxUSE_CARET
// panel wants to track the window which was the last to have focus in it
- wxPanel *panel = wxDynamicCast(GetParent(), wxPanel);
- if ( panel )
- {
- panel->SetLastFocus((wxWindow*)this);
- }
+ wxChildFocusEvent eventFocus(this);
+ (void)GetEventHandler()->ProcessEvent(eventFocus);
+
#ifndef __WXUNIVERSAL__
wxControl* control = wxDynamicCast( gFocusWindow , wxControl ) ;
if ( control && control->GetMacControl() )
{
if ( m_macWindowData == NULL)
{
- if(x) *x += m_x ;
- if(y) *y += m_y ;
+ if(x) *x += m_x + MacGetLeftBorderSize();
+ if(y) *y += m_y + MacGetTopBorderSize();
GetParent()->MacClientToRootWindow( x , y ) ;
}
}
{
if ( m_macWindowData == NULL)
{
- if(x) *x -= m_x ;
- if(y) *y -= m_y ;
+ if(x) *x -= m_x + MacGetLeftBorderSize();
+ if(y) *y -= m_y + MacGetTopBorderSize();
GetParent()->MacRootWindowToClient( x , y ) ;
}
}
frame->PositionStatusBar();
frame->PositionToolBar();
}
+ if ( doMove )
+ wxWindowMac::MacTopLevelWindowChangedPosition() ; // like this only children will be notified
}
else
{
{
if (show)
{
- UMAShowWindow( m_macWindowData->m_macWindow ) ;
- UMASelectWindow( m_macWindowData->m_macWindow ) ;
+ ::ShowWindow( m_macWindowData->m_macWindow ) ;
+ ::SelectWindow( m_macWindowData->m_macWindow ) ;
// no need to generate events here, they will get them triggered by macos
// actually they should be , but apparently they are not
wxSize size(m_width, m_height);
}
else
{
- UMAHideWindow( m_macWindowData->m_macWindow ) ;
+ ::HideWindow( m_macWindowData->m_macWindow ) ;
}
}
MacSuperShown( show ) ;
attr |= kWindowCloseBoxAttribute ;
}
- UMACreateNewWindow( wclass , attr , &theBoundsRect , &m_macWindowData->m_macWindow ) ;
+ ::CreateNewWindow( wclass , attr , &theBoundsRect , &m_macWindowData->m_macWindow ) ;
wxAssociateWinWithMacWindow( m_macWindowData->m_macWindow , this ) ;
wxString label ;
if( wxApp::s_macDefaultEncodingIsPC )
else
label = title ;
UMASetWTitleC( m_macWindowData->m_macWindow , label ) ;
- UMACreateRootControl( m_macWindowData->m_macWindow , &m_macWindowData->m_macRootControl ) ;
+ ::CreateRootControl( m_macWindowData->m_macWindow , &m_macWindowData->m_macRootControl ) ;
m_macWindowData->m_macFocus = NULL ;
m_macWindowData->m_macHasReceivedFirstActivate = true ;
if (HasFlag(wxRAISED_BORDER) || HasFlag( wxSUNKEN_BORDER) || HasFlag(wxDOUBLE_BORDER) )
{
bool sunken = HasFlag( wxSUNKEN_BORDER ) ;
- RGBColor pen1 = sunken ? white : black ;
- RGBColor pen2 = sunken ? shadow : face ;
- RGBColor pen3 = sunken ? face : shadow ;
- RGBColor pen4 = sunken ? black : white ;
-
- RGBForeColor( &pen1 ) ;
- {
- Rect rect = { 0 , 0 , m_height , m_width } ;
- FrameRect( &rect ) ;
- }
- RGBForeColor( &pen2 ) ;
- {
- Rect rect = { 1 , 1 , m_height -1 , m_width -1} ;
- FrameRect( &rect ) ;
- }
- RGBForeColor( &pen3 ) ;
- {
- Rect rect = { 0 , 0 , m_height -2 , m_width -2} ;
- FrameRect( &rect ) ;
- }
- RGBForeColor( &pen4 ) ;
- {
- MoveTo( 0 , 0 ) ;
- LineTo( m_width - 3 , 0 ) ;
- MoveTo( 0 , 0 ) ;
- LineTo( 0 , m_height - 3 ) ;
- }
+ RGBForeColor( &face );
+ MoveTo( 0 , m_height - 2 );
+ LineTo( 0 , 0 );
+ LineTo( m_width - 2 , 0 );
+
+ MoveTo( 2 , m_height - 3 );
+ LineTo( m_width - 3 , m_height - 3 );
+ LineTo( m_width - 3 , 2 );
+
+ RGBForeColor( sunken ? &face : &black );
+ MoveTo( 0 , m_height - 1 );
+ LineTo( m_width - 1 , m_height - 1 );
+ LineTo( m_width - 1 , 0 );
+
+ RGBForeColor( sunken ? &shadow : &white );
+ MoveTo( 1 , m_height - 3 );
+ LineTo( 1, 1 );
+ LineTo( m_width - 3 , 1 );
+
+ RGBForeColor( sunken ? &white : &shadow );
+ MoveTo( 1 , m_height - 2 );
+ LineTo( m_width - 2 , m_height - 2 );
+ LineTo( m_width - 2 , 1 );
+
+ RGBForeColor( sunken ? &black : &face );
+ MoveTo( 2 , m_height - 4 );
+ LineTo( 2 , 2 );
+ LineTo( m_width - 4 , 2 );
}
else if (HasFlag(wxSIMPLE_BORDER))
{
RGBForeColor( &black ) ;
FrameRect( &rect ) ;
}
-/*
- if ( this->GetParent() )
- {
- wxPaintDC dc(GetParent());
- GetParent()->PrepareDC(dc);
-
- if (HasFlag(wxRAISED_BORDER) || HasFlag( wxSUNKEN_BORDER) )
- {
- bool sunken = HasFlag( wxSUNKEN_BORDER ) ;
-
- wxPen m_penButton3DShadow( wxSystemSettings::GetSystemColour( wxSYS_COLOUR_3DSHADOW ), 1, wxSOLID ) ;
- wxPen m_penButton3DFace( wxSystemSettings::GetSystemColour( wxSYS_COLOUR_3DFACE ), 1, wxSOLID ) ;
-
- wxPen wxPen1 = sunken ? *wxWHITE_PEN : *wxBLACK_PEN;
- wxPen wxPen2 = sunken ? m_penButton3DShadow : m_penButton3DShadow;
- wxPen wxPen3 = sunken ? m_penButton3DFace : m_penButton3DShadow;
- wxPen wxPen4 = sunken ? *wxBLACK_PEN : *wxWHITE_PEN;
-
- dc.SetPen(wxPen1);
- dc.DrawRectangle(m_x, m_y, m_width, m_height); // outer - right and button
-
- dc.SetPen(wxPen2);
- dc.DrawRectangle(m_x+1, m_y+1, m_width-1, m_height-1); // outer - left and top
-
- dc.SetPen(wxPen3);
- dc.DrawRectangle(m_x, m_y, m_width-2, m_height-2); // inner - right and button
-
- dc.SetPen(wxPen4);
- dc.DrawLine(m_x, m_y, m_x + m_width-3, m_y); // inner - left and top
- dc.DrawLine(m_x, m_y, m_x, m_y + m_height-3);
- }
- else if (HasFlag(wxDOUBLE_BORDER))
- {
- bool sunken = HasFlag( wxSUNKEN_BORDER ) ;
-
- wxPen m_penButton3DShadow( wxSystemSettings::GetSystemColour( wxSYS_COLOUR_3DSHADOW ), 1, wxSOLID ) ;
- wxPen m_penButton3DFace( wxSystemSettings::GetSystemColour( wxSYS_COLOUR_3DFACE ), 1, wxSOLID ) ;
-
- wxPen wxPen1 = sunken ? *wxWHITE_PEN : *wxBLACK_PEN;
- wxPen wxPen2 = sunken ? m_penButton3DShadow : m_penButton3DShadow;
- wxPen wxPen3 = sunken ? m_penButton3DFace : m_penButton3DShadow;
- wxPen wxPen4 = sunken ? *wxBLACK_PEN : *wxWHITE_PEN;
-
- dc.SetPen(wxPen1);
- dc.DrawRectangle(m_x, m_y, m_width, m_height); // outer - right and button
-
- dc.SetPen(wxPen2);
- dc.DrawRectangle(m_x+1, m_y+1, m_width-1, m_height-1); // outer - left and top
-
- dc.SetPen(wxPen3);
- dc.DrawRectangle(m_x, m_y, m_width-2, m_height-2); // inner - right and button
-
- dc.SetPen(wxPen4);
- dc.DrawLine(m_x, m_y, m_x + m_width-3, m_y); // inner - left and top
- dc.DrawLine(m_x, m_y, m_x, m_y + m_height-3);
- }
- else if (HasFlag(wxSIMPLE_BORDER))
- {
- dc.SetPen(*wxBLACK_PEN);
- dc.DrawRectangle(m_x, m_y, m_width, m_height);
- }
- }
- */
}
// New function that will replace some of the above.
// notice that it's also important to do it upwards the tree becaus
// otherwise when the top level panel gets focus, it won't set it back to
// us, but to some other sibling
- wxWindowMac *win = this;
- while ( win )
- {
- wxWindowMac *parent = win->GetParent();
- wxPanel *panel = wxDynamicCast(parent, wxPanel);
- if ( panel )
- {
- panel->SetLastFocus(win);
- }
-
- win = parent;
- }
+
+ // CS:don't know if this is still needed:
+ //wxChildFocusEvent eventFocus(this);
+ //(void)GetEventHandler()->ProcessEvent(eventFocus);
event.Skip();
}
int w ,h ;
wxPoint origin = GetClientAreaOrigin() ;
GetClientSize( &w , &h ) ;
- UMASetThemeWindowBackground( m_macWindowData->m_macWindow , m_macWindowData->m_macWindowBackgroundTheme , false ) ;
+ ::SetThemeWindowBackground( m_macWindowData->m_macWindow , m_macWindowData->m_macWindowBackgroundTheme , false ) ;
Rect r = { origin.y , origin.x, origin.y+h , origin.x+w } ;
EraseRect( &r ) ;
}
{
if ( m_macWindowData )
{
- UMABringToFront( m_macWindowData->m_macWindow ) ;
+ ::BringToFront( m_macWindowData->m_macWindow ) ;
}
}
{
if ( m_macWindowData )
{
- UMASendBehind( m_macWindowData->m_macWindow , NULL ) ;
+ ::SendBehind( m_macWindowData->m_macWindow , NULL ) ;
}
}
eraseBackground = true ;
if ( m_backgroundColour == wxSystemSettings::GetSystemColour(wxSYS_COLOUR_APPWORKSPACE) )
{
- UMASetThemeWindowBackground( window , kThemeBrushDocumentWindowBackground , false ) ;
+ ::SetThemeWindowBackground( window , kThemeBrushDocumentWindowBackground , false ) ;
}
else if ( m_backgroundColour == wxSystemSettings::GetSystemColour(wxSYS_COLOUR_3DFACE ) )
{
{
Rect box ;
GetRegionBounds( updatergn , &box) ;
- UMAApplyThemeBackground(kThemeBackgroundTabPane, &box , kThemeStateActive,8,true);
+ ::ApplyThemeBackground(kThemeBackgroundTabPane, &box , kThemeStateActive,8,true);
break ;
}
}
if ( !parent )
{
// if there is nothing special -> use default
- UMASetThemeWindowBackground( window , kThemeBrushDialogBackgroundActive , false ) ;
+ ::SetThemeWindowBackground( window , kThemeBrushDialogBackgroundActive , false ) ;
}
}
else
}
}
+void wxWindowMac::MacTopLevelWindowChangedPosition()
+{
+ // only screen-absolute structures have to be moved i.e. glcanvas
+
+ wxNode *node = GetChildren().First();
+ while ( node )
+ {
+ wxWindowMac *child = (wxWindowMac *)node->Data();
+ child->MacTopLevelWindowChangedPosition() ;
+ node = node->Next();
+ }
+}
+
bool wxWindowMac::MacSetPortFocusParams( const Point & localOrigin, const Rect & clipRect, WindowRef window , wxWindowMac* win )
{
if ( window == NULL )
Pattern whiteColor ;
::BackPat( GetQDGlobalsWhite( &whiteColor) ) ;
- ::UMASetThemeWindowBackground( win->m_macWindowData->m_macWindow , win->m_macWindowData->m_macWindowBackgroundTheme , false ) ;
+ ::SetThemeWindowBackground( win->m_macWindowData->m_macWindow , win->m_macWindowData->m_macWindowBackgroundTheme , false ) ;
return true;
}
if (m_windowStyle & wxRAISED_BORDER || m_windowStyle & wxSUNKEN_BORDER )
{
- return 2 ;
+ return 3 ;
}
else if ( m_windowStyle &wxDOUBLE_BORDER)
{
- return 2 ;
+ return 3 ;
}
else if (m_windowStyle &wxSIMPLE_BORDER)
{
}
else if (m_windowStyle &wxSIMPLE_BORDER)
{
- return 3 ;
+ return 1 ;
}
return 0 ;
}
if (m_windowStyle & wxRAISED_BORDER || m_windowStyle & wxSUNKEN_BORDER )
{
- return 2 ;
+ return 3 ;
}
else if ( m_windowStyle &wxDOUBLE_BORDER)
{
- return 2 ;
+ return 3 ;
}
else if (m_windowStyle &wxSIMPLE_BORDER)
{
}
else if (m_windowStyle &wxSIMPLE_BORDER)
{
- return 3 ;
+ return 1 ;
}
return 0 ;
}