X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/439ddeba9dcb2bb020ba70da81dab76746dc0081..9470921fbb927af3a4432a27d52c372998311964:/src/mac/control.cpp diff --git a/src/mac/control.cpp b/src/mac/control.cpp index 49be26a16c..f44ff6bc7f 100644 --- a/src/mac/control.cpp +++ b/src/mac/control.cpp @@ -196,6 +196,8 @@ wxControl::~wxControl() } if ( (ControlHandle) m_macControl ) { + // in case the callback might be called during destruction + ::SetControlColorProc( (ControlHandle) m_macControl , NULL ) ; ::DisposeControl( (ControlHandle) m_macControl ) ; m_macControl = NULL ; } @@ -311,7 +313,8 @@ void wxControl::MacPreControlCreate( wxWindow *parent, wxWindowID id, wxString l void wxControl::MacPostControlCreate() { wxASSERT_MSG( (ControlHandle) m_macControl != NULL , wxT("No valid mac control") ) ; - + DoSetWindowVariant( m_windowVariant ) ; + /* if ( IsKindOf( CLASSINFO( wxScrollBar ) ) ) { // no font @@ -336,6 +339,7 @@ void wxControl::MacPostControlCreate() ::SetControlFontStyle( (ControlHandle) m_macControl , &controlstyle ) ; } + */ ControlHandle container = (ControlHandle) GetParent()->MacGetContainerForEmbedding() ; wxASSERT_MSG( container != NULL , wxT("No valid mac container control") ) ; ::EmbedControl( (ControlHandle) m_macControl , container ) ; @@ -748,3 +752,58 @@ void wxControl::MacHandleControlClick( WXWidget control , wxInt16 controlpart , wxASSERT_MSG( (ControlHandle) m_macControl != NULL , wxT("No valid mac control") ) ; } +void wxControl::DoSetWindowVariant( wxWindowVariant variant ) +{ + if ( m_macControl == NULL ) + { + wxWindow::SetWindowVariant( variant ) ; + return ; + + } + m_windowVariant = variant ; + + ControlSize size ; + ControlFontStyleRec fontStyle; + fontStyle.flags = kControlUseFontMask ; + + // we will get that from the settings later + // and make this NORMAL later, but first + // we have a few calculations that we must fix + + if ( variant == wxWINDOW_VARIANT_DEFAULT ) + variant = wxWINDOW_VARIANT_SMALL ; + + switch ( variant ) + { + case wxWINDOW_VARIANT_NORMAL : + size = kControlSizeNormal; + fontStyle.font = kControlFontBigSystemFont; + break ; + case wxWINDOW_VARIANT_SMALL : + size = kControlSizeSmall; + fontStyle.font = kControlFontSmallSystemFont; + break ; + case wxWINDOW_VARIANT_MINI : + if (UMAGetSystemVersion() >= 0x1030 ) + { + size = 3 ; // not always defined in the header + fontStyle.font = -5 ; // not always defined in the header + } + else + { + size = kControlSizeSmall; + fontStyle.font = kControlFontSmallSystemFont; + } + break; + break ; + case wxWINDOW_VARIANT_LARGE : + size = kControlSizeLarge; + fontStyle.font = kControlFontBigSystemFont; + break ; + default: + wxFAIL_MSG(_T("unexpected window variant")); + break ; + } + ::SetControlData( (ControlHandle) m_macControl , kControlEntireControl, kControlSizeTag, sizeof( ControlSize ), &size ); + ::SetControlFontStyle( (ControlHandle) m_macControl , &fontStyle ); +}