X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/6239ee05567eac71754f56c2a154222d10b57ff1..850df2d78866c3edcf848103b5dbc7e7fa1ee5fa:/src/mac/carbon/toplevel.cpp?ds=sidebyside diff --git a/src/mac/carbon/toplevel.cpp b/src/mac/carbon/toplevel.cpp index 6cab8c7543..135bf7aa61 100644 --- a/src/mac/carbon/toplevel.cpp +++ b/src/mac/carbon/toplevel.cpp @@ -314,11 +314,11 @@ void SetupMouseEvent( wxMouseEvent &wxevent , wxMacCarbonEvent &cEvent ) if( thisButtonIsFakeRight && ( mouseChord & 1U ) ) mouseChord = ((mouseChord & ~1U) | 2U); - if(mouseChord & 1U) + if(mouseChord & 1U) wxevent.m_leftDown = true ; - if(mouseChord & 2U) + if(mouseChord & 2U) wxevent.m_rightDown = true ; - if(mouseChord & 4U) + if(mouseChord & 4U) wxevent.m_middleDown = true ; // translate into wx types @@ -442,18 +442,6 @@ ControlRef wxMacFindSubControl( wxTopLevelWindowMac* toplevelWindow, const Point return NULL ; } -ControlRef wxMacFindControlUnderMouse( wxTopLevelWindowMac* toplevelWindow , const Point& location , WindowRef window , ControlPartCode *outPart ) -{ -#if TARGET_API_MAC_OSX - if ( UMAGetSystemVersion() >= 0x1030 ) - return FindControlUnderMouse( location , window , outPart ) ; -#endif - - ControlRef rootControl = NULL ; - verify_noerr( GetRootControl( window , &rootControl ) ) ; - - return wxMacFindSubControl( toplevelWindow , location , rootControl , outPart ) ; -} #define NEW_CAPTURE_HANDLING 1 @@ -616,17 +604,10 @@ wxMacTopLevelMouseEventHandler(EventHandlerCallRef WXUNUSED(handler), currentMouseWindow->SetFocus(); } - ControlPartCode dummyPart ; // if built-in find control is finding the wrong control (ie static box instead of overlaid // button, we cannot let the standard handler do its job, but must handle manually - if ( ( cEvent.GetKind() == kEventMouseDown ) -#ifdef __WXMAC_OSX__ - && - (FindControlUnderMouse(windowMouseLocation , window , &dummyPart) != - wxMacFindControlUnderMouse( toplevelWindow , windowMouseLocation , window , &dummyPart ) ) -#endif - ) + if ( cEvent.GetKind() == kEventMouseDown ) { if ( currentMouseWindow->MacIsReallyEnabled() ) { @@ -677,14 +658,13 @@ wxMacTopLevelMouseEventHandler(EventHandlerCallRef WXUNUSED(handler), { EventModifiers modifiers = cEvent.GetParameter(kEventParamKeyModifiers, typeUInt32) ; Point clickLocation = windowMouseLocation ; -#if TARGET_API_MAC_OSX + HIPoint hiPoint ; hiPoint.x = clickLocation.h ; hiPoint.y = clickLocation.v ; HIViewConvertPoint( &hiPoint , (ControlRef) toplevelWindow->GetHandle() , control ) ; clickLocation.h = (int)hiPoint.x ; clickLocation.v = (int)hiPoint.y ; -#endif // TARGET_API_MAC_OSX HandleControlClick( control , clickLocation , modifiers , (ControlActionUPP ) -1 ) ; result = noErr ; @@ -1083,13 +1063,6 @@ wxPoint wxTopLevelWindowMac::GetClientAreaOrigin() const return wxPoint(0, 0) ; } -#ifndef __WXUNIVERSAL__ -void wxTopLevelWindowMac::SetIcons( const wxIconBundle& icons ) -{ -// { SetIcon( icons.GetIcon( -1 ) ); } -} -#endif - void wxTopLevelWindowMac::MacSetBackgroundBrush( const wxBrush &brush ) { wxTopLevelWindowBase::MacSetBackgroundBrush( brush ) ; @@ -1126,7 +1099,7 @@ void wxTopLevelWindowMac::MacCreateRealWindow( } void wxTopLevelWindowMac::DoMacCreateRealWindow( - wxWindow* parent, + wxWindow* parent, const wxString& title, const wxPoint& pos, const wxSize& size, @@ -1160,8 +1133,8 @@ void wxTopLevelWindowMac::DoMacCreateRealWindow( WindowClass wclass = 0; WindowAttributes attr = kWindowNoAttributes ; WindowGroupRef group = NULL ; - bool activationScopeSet = false; - WindowActivationScope activationScope = kWindowActivationScopeNone; + bool activationScopeSet = false; + WindowActivationScope activationScope = kWindowActivationScopeNone; if ( HasFlag( wxFRAME_TOOL_WINDOW) ) { @@ -1182,8 +1155,8 @@ void wxTopLevelWindowMac::DoMacCreateRealWindow( else { wclass = kPlainWindowClass ; - activationScopeSet = true; - activationScope = kWindowActivationScopeNone; + activationScopeSet = true; + activationScope = kWindowActivationScopeNone; } } else if ( HasFlag( wxPOPUP_WINDOW ) ) @@ -1205,12 +1178,10 @@ void wxTopLevelWindowMac::DoMacCreateRealWindow( wclass = kDocumentWindowClass ; attr |= kWindowInWindowMenuAttribute ; } -#if defined( __WXMAC__ ) && TARGET_API_MAC_OSX && ( MAC_OS_X_VERSION_MAX_ALLOWED >= MAC_OS_X_VERSION_10_2 ) else if ( HasFlag( wxFRAME_DRAWER ) ) { wclass = kDrawerWindowClass; } -#endif //10.2 and up else { if ( HasFlag( wxMINIMIZE_BOX ) || HasFlag( wxMAXIMIZE_BOX ) || @@ -1242,10 +1213,7 @@ void wxTopLevelWindowMac::DoMacCreateRealWindow( if ( HasFlag( wxCLOSE_BOX) ) attr |= kWindowCloseBoxAttribute ; } - - // turn on live resizing (OS X only) - if (UMAGetSystemVersion() >= 0x1000) - attr |= kWindowLiveResizeAttribute; + attr |= kWindowLiveResizeAttribute; if ( HasFlag(wxSTAY_ON_TOP) ) group = GetWindowGroupOfClass(kUtilityWindowClass) ; @@ -1259,7 +1227,7 @@ void wxTopLevelWindowMac::DoMacCreateRealWindow( if( parenttlw ) group = GetWindowGroupParent( GetWindowGroup( parenttlw ) ); } - + attr |= kWindowCompositingAttribute; #if 0 // wxMAC_USE_CORE_GRAPHICS ; TODO : decide on overall handling of high dpi screens (pixel vs userscale) attr |= kWindowFrameworkScaledAttribute; @@ -1290,16 +1258,16 @@ void wxTopLevelWindowMac::DoMacCreateRealWindow( wxCHECK_RET( err == noErr, wxT("Mac OS error when trying to create new window") ); // setup a separate group for each window, so that overlays can be handled easily - + WindowGroupRef overlaygroup = NULL; verify_noerr( CreateWindowGroup( kWindowGroupAttrMoveTogether | kWindowGroupAttrLayerTogether | kWindowGroupAttrHideOnCollapse, &overlaygroup )); verify_noerr( SetWindowGroupParent( overlaygroup, GetWindowGroup( (WindowRef) m_macWindow ))); verify_noerr( SetWindowGroup( (WindowRef) m_macWindow , overlaygroup )); - - if ( activationScopeSet ) - { - verify_noerr( SetWindowActivationScope( (WindowRef) m_macWindow , activationScope )); - } + + if ( activationScopeSet ) + { + verify_noerr( SetWindowActivationScope( (WindowRef) m_macWindow , activationScope )); + } // the create commands are only for content rect, // so we have to set the size again as structure bounds @@ -1332,12 +1300,10 @@ void wxTopLevelWindowMac::DoMacCreateRealWindow( } #endif -#if TARGET_API_MAC_OSX if ( m_macWindow != NULL ) { MacSetUnifiedAppearance( true ) ; } -#endif HIViewRef growBoxRef = 0 ; err = HIViewFindByID( HIViewGetRoot( (WindowRef)m_macWindow ), kHIViewWindowGrowBoxID, &growBoxRef ); @@ -1419,11 +1385,9 @@ bool wxTopLevelWindowMac::Show(bool show) if ( !wxTopLevelWindowBase::Show(show) ) return false; - bool plainTransition = false; + bool plainTransition = true; #if wxUSE_SYSTEM_OPTIONS - // code contributed by Ryan Wilcox December 18, 2003 - plainTransition = UMAGetSystemVersion() >= 0x1000 ; if ( wxSystemOptions::HasOption(wxMAC_WINDOW_PLAIN_TRANSITION) ) plainTransition = ( wxSystemOptions::GetOptionInt( wxMAC_WINDOW_PLAIN_TRANSITION ) == 1 ) ; #endif @@ -1552,7 +1516,6 @@ void wxTopLevelWindowMac::SetExtraStyle(long exStyle) wxTopLevelWindowBase::SetExtraStyle( exStyle ) ; -#if TARGET_API_MAC_OSX if ( m_macWindow != NULL ) { bool metal = GetExtraStyle() & wxFRAME_EX_METAL ; @@ -1565,7 +1528,6 @@ void wxTopLevelWindowMac::SetExtraStyle(long exStyle) MacSetMetalAppearance( metal ) ; } } -#endif } bool wxTopLevelWindowMac::SetBackgroundStyle(wxBackgroundStyle style) @@ -1654,53 +1616,37 @@ void wxTopLevelWindowMac::DoCentre(int dir) void wxTopLevelWindowMac::MacSetMetalAppearance( bool set ) { -#if TARGET_API_MAC_OSX if ( MacGetUnifiedAppearance() ) MacSetUnifiedAppearance( false ) ; MacChangeWindowAttributes( set ? kWindowMetalAttribute : kWindowNoAttributes , set ? kWindowNoAttributes : kWindowMetalAttribute ) ; -#endif } bool wxTopLevelWindowMac::MacGetMetalAppearance() const { -#if TARGET_API_MAC_OSX return MacGetWindowAttributes() & kWindowMetalAttribute ; -#else - return false; -#endif } void wxTopLevelWindowMac::MacSetUnifiedAppearance( bool set ) { -#if TARGET_API_MAC_OSX - if ( UMAGetSystemVersion() >= 0x1040 ) - { - if ( MacGetMetalAppearance() ) - MacSetMetalAppearance( false ) ; - - MacChangeWindowAttributes( set ? kWindowUnifiedTitleAndToolbarAttribute : kWindowNoAttributes , - set ? kWindowNoAttributes : kWindowUnifiedTitleAndToolbarAttribute) ; - - // For some reason, Tiger uses white as the background color for this appearance, - // while most apps using it use the typical striped background. Restore that behavior - // for wx. - // TODO: Determine if we need this on Leopard as well. (should be harmless either way, - // though) - SetBackgroundColour( wxSYS_COLOUR_WINDOW ) ; - } -#endif + if ( MacGetMetalAppearance() ) + MacSetMetalAppearance( false ) ; + + MacChangeWindowAttributes( set ? kWindowUnifiedTitleAndToolbarAttribute : kWindowNoAttributes , + set ? kWindowNoAttributes : kWindowUnifiedTitleAndToolbarAttribute) ; + + // For some reason, Tiger uses white as the background color for this appearance, + // while most apps using it use the typical striped background. Restore that behavior + // for wx. + // TODO: Determine if we need this on Leopard as well. (should be harmless either way, + // though) + SetBackgroundColour( wxSYS_COLOUR_WINDOW ) ; } bool wxTopLevelWindowMac::MacGetUnifiedAppearance() const { -#if TARGET_API_MAC_OSX - if ( UMAGetSystemVersion() >= 0x1040 ) - return MacGetWindowAttributes() & kWindowUnifiedTitleAndToolbarAttribute ; - else -#endif - return false; + return MacGetWindowAttributes() & kWindowUnifiedTitleAndToolbarAttribute ; } void wxTopLevelWindowMac::MacChangeWindowAttributes( wxUint32 attributesToSet , wxUint32 attributesToClear ) @@ -1718,32 +1664,9 @@ wxUint32 wxTopLevelWindowMac::MacGetWindowAttributes() const void wxTopLevelWindowMac::MacPerformUpdates() { -#if MAC_OS_X_VERSION_MAX_ALLOWED >= MAC_OS_X_VERSION_10_3 // for composited windows this also triggers a redraw of all // invalid views in the window - if ( UMAGetSystemVersion() >= 0x1030 ) - HIWindowFlush((WindowRef) m_macWindow) ; - else -#endif - { - // the only way to trigger the redrawing on earlier systems is to call - // ReceiveNextEvent - - EventRef currentEvent = (EventRef) wxTheApp->MacGetCurrentEvent() ; - UInt32 currentEventClass = 0 ; - if ( currentEvent != NULL ) - { - currentEventClass = ::GetEventClass( currentEvent ) ; - ::GetEventKind( currentEvent ) ; - } - - if ( currentEventClass != kEventClassMenu ) - { - // when tracking a menu, strange redraw errors occur if we flush now, so leave.. - EventRef theEvent; - ReceiveNextEvent( 0 , NULL , kEventDurationNoWait , false , &theEvent ) ; - } - } + HIWindowFlush((WindowRef) m_macWindow) ; } // Attracts the users attention to this window if the application is