reformat for readability
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@36379 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -43,7 +43,7 @@
|
|||||||
// windows manager, control manager, navigation services etc. are
|
// windows manager, control manager, navigation services etc. are
|
||||||
// present
|
// present
|
||||||
|
|
||||||
static bool sUMAHasAppearance = false ;
|
static bool sUMAHasAppearance = false ;
|
||||||
static long sUMAAppearanceVersion = 0 ;
|
static long sUMAAppearanceVersion = 0 ;
|
||||||
static long sUMASystemVersion = 0 ;
|
static long sUMASystemVersion = 0 ;
|
||||||
static bool sUMAHasAquaLayout = false ;
|
static bool sUMAHasAquaLayout = false ;
|
||||||
@@ -51,11 +51,12 @@ static bool sUMAHasAquaLayout = false ;
|
|||||||
static bool sUMAHasInittedAppearance = false;
|
static bool sUMAHasInittedAppearance = false;
|
||||||
|
|
||||||
extern int gAGABackgroundColor ;
|
extern int gAGABackgroundColor ;
|
||||||
|
|
||||||
bool UMAHasAppearance() { return sUMAHasAppearance ; }
|
bool UMAHasAppearance() { return sUMAHasAppearance ; }
|
||||||
long UMAGetAppearanceVersion() { return sUMAAppearanceVersion ; }
|
long UMAGetAppearanceVersion() { return sUMAAppearanceVersion ; }
|
||||||
long UMAGetSystemVersion() { return sUMASystemVersion ; }
|
long UMAGetSystemVersion() { return sUMASystemVersion ; }
|
||||||
|
|
||||||
static bool sUMAHasWindowManager = false ;
|
static bool sUMAHasWindowManager = false ;
|
||||||
static long sUMAWindowManagerAttr = 0 ;
|
static long sUMAWindowManagerAttr = 0 ;
|
||||||
|
|
||||||
bool UMAHasWindowManager() { return sUMAHasWindowManager ; }
|
bool UMAHasWindowManager() { return sUMAHasWindowManager ; }
|
||||||
@@ -66,16 +67,15 @@ bool UMAHasAquaLayout() { return sUMAHasAquaLayout ; }
|
|||||||
void UMACleanupToolbox()
|
void UMACleanupToolbox()
|
||||||
{
|
{
|
||||||
if (sUMAHasInittedAppearance)
|
if (sUMAHasInittedAppearance)
|
||||||
{
|
|
||||||
UnregisterAppearanceClient() ;
|
UnregisterAppearanceClient() ;
|
||||||
}
|
|
||||||
if ( NavServicesAvailable() )
|
if ( NavServicesAvailable() )
|
||||||
{
|
|
||||||
NavUnload() ;
|
NavUnload() ;
|
||||||
}
|
|
||||||
if ( TXNTerminateTextension != (void*) kUnresolvedCFragSymbolAddress )
|
if ( TXNTerminateTextension != (void*) kUnresolvedCFragSymbolAddress )
|
||||||
TXNTerminateTextension( ) ;
|
TXNTerminateTextension( ) ;
|
||||||
}
|
}
|
||||||
|
|
||||||
void UMAInitToolbox( UInt16 inMoreMastersCalls, bool isEmbedded )
|
void UMAInitToolbox( UInt16 inMoreMastersCalls, bool isEmbedded )
|
||||||
{
|
{
|
||||||
#if !TARGET_CARBON
|
#if !TARGET_CARBON
|
||||||
@@ -105,12 +105,13 @@ void UMAInitToolbox( UInt16 inMoreMastersCalls, bool isEmbedded )
|
|||||||
long theAppearance ;
|
long theAppearance ;
|
||||||
if ( Gestalt( gestaltAppearanceAttr, &theAppearance ) == noErr )
|
if ( Gestalt( gestaltAppearanceAttr, &theAppearance ) == noErr )
|
||||||
{
|
{
|
||||||
sUMAHasAppearance = true ;
|
|
||||||
OSStatus status = RegisterAppearanceClient();
|
|
||||||
// If status equals appearanceProcessRegisteredErr it means the
|
// If status equals appearanceProcessRegisteredErr it means the
|
||||||
// appearance client already was registered (For example if we run
|
// appearance client already was registered (For example if we run
|
||||||
// embedded, the host might have registered it). In such a case
|
// embedded, the host might have registered it). In such a case
|
||||||
// we don't unregister it later on.
|
// we don't unregister it later on.
|
||||||
|
|
||||||
|
sUMAHasAppearance = true ;
|
||||||
|
OSStatus status = RegisterAppearanceClient();
|
||||||
if (status != appearanceProcessRegisteredErr)
|
if (status != appearanceProcessRegisteredErr)
|
||||||
{
|
{
|
||||||
// Appearance client wasn't registered yet.
|
// Appearance client wasn't registered yet.
|
||||||
@@ -118,18 +119,13 @@ void UMAInitToolbox( UInt16 inMoreMastersCalls, bool isEmbedded )
|
|||||||
}
|
}
|
||||||
|
|
||||||
if ( Gestalt( gestaltAppearanceVersion, &theAppearance ) == noErr )
|
if ( Gestalt( gestaltAppearanceVersion, &theAppearance ) == noErr )
|
||||||
{
|
|
||||||
sUMAAppearanceVersion = theAppearance ;
|
sUMAAppearanceVersion = theAppearance ;
|
||||||
}
|
|
||||||
else
|
else
|
||||||
{
|
|
||||||
sUMAAppearanceVersion = 0x0100 ;
|
sUMAAppearanceVersion = 0x0100 ;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( Gestalt( gestaltWindowMgrAttr, &sUMAWindowManagerAttr ) == noErr )
|
if ( Gestalt( gestaltWindowMgrAttr, &sUMAWindowManagerAttr ) == noErr )
|
||||||
{
|
|
||||||
sUMAHasWindowManager = sUMAWindowManagerAttr & gestaltWindowMgrPresent ;
|
sUMAHasWindowManager = sUMAWindowManagerAttr & gestaltWindowMgrPresent ;
|
||||||
}
|
|
||||||
|
|
||||||
#if TARGET_CARBON
|
#if TARGET_CARBON
|
||||||
// Call currently implicitely done : InitFloatingWindows() ;
|
// Call currently implicitely done : InitFloatingWindows() ;
|
||||||
@@ -144,52 +140,49 @@ void UMAInitToolbox( UInt16 inMoreMastersCalls, bool isEmbedded )
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
if ( NavServicesAvailable() )
|
if ( NavServicesAvailable() )
|
||||||
{
|
|
||||||
NavLoad() ;
|
NavLoad() ;
|
||||||
|
|
||||||
|
long menuMgrAttr ;
|
||||||
|
Gestalt( gestaltMenuMgrAttr , &menuMgrAttr ) ;
|
||||||
|
if ( menuMgrAttr & gestaltMenuMgrAquaLayoutMask )
|
||||||
|
sUMAHasAquaLayout = true ;
|
||||||
|
|
||||||
|
if ( TXNInitTextension != (void*) kUnresolvedCFragSymbolAddress )
|
||||||
|
{
|
||||||
|
FontFamilyID fontId ;
|
||||||
|
Str255 fontName ;
|
||||||
|
SInt16 fontSize ;
|
||||||
|
Style fontStyle ;
|
||||||
|
|
||||||
|
GetThemeFont(kThemeSmallSystemFont , GetApplicationScript() , fontName , &fontSize , &fontStyle ) ;
|
||||||
|
GetFNum( fontName, &fontId );
|
||||||
|
|
||||||
|
TXNMacOSPreferredFontDescription fontDescriptions[] =
|
||||||
|
{
|
||||||
|
{ fontId , (fontSize << 16) , kTXNDefaultFontStyle, kTXNSystemDefaultEncoding }
|
||||||
|
} ;
|
||||||
|
int noOfFontDescriptions = sizeof( fontDescriptions ) / sizeof(TXNMacOSPreferredFontDescription) ;
|
||||||
|
|
||||||
|
OptionBits options = 0 ;
|
||||||
|
|
||||||
|
if ( UMAGetSystemVersion() < 0x1000 )
|
||||||
|
options |= kTXNAlwaysUseQuickDrawTextMask ;
|
||||||
|
|
||||||
|
TXNInitTextension( fontDescriptions, noOfFontDescriptions, options );
|
||||||
}
|
}
|
||||||
|
|
||||||
long menuMgrAttr ;
|
UMASetSystemIsInitialized( true );
|
||||||
Gestalt( gestaltMenuMgrAttr , &menuMgrAttr ) ;
|
|
||||||
if ( menuMgrAttr & gestaltMenuMgrAquaLayoutMask )
|
|
||||||
sUMAHasAquaLayout = true ;
|
|
||||||
|
|
||||||
if ( TXNInitTextension != (void*) kUnresolvedCFragSymbolAddress )
|
|
||||||
{
|
|
||||||
FontFamilyID fontId ;
|
|
||||||
Str255 fontName ;
|
|
||||||
SInt16 fontSize ;
|
|
||||||
Style fontStyle ;
|
|
||||||
GetThemeFont(kThemeSmallSystemFont , GetApplicationScript() , fontName , &fontSize , &fontStyle ) ;
|
|
||||||
GetFNum( fontName, &fontId );
|
|
||||||
|
|
||||||
TXNMacOSPreferredFontDescription fontDescriptions[] =
|
|
||||||
{
|
|
||||||
{ fontId , (fontSize << 16) ,kTXNDefaultFontStyle, kTXNSystemDefaultEncoding }
|
|
||||||
} ;
|
|
||||||
int noOfFontDescriptions = sizeof( fontDescriptions ) / sizeof(TXNMacOSPreferredFontDescription) ;
|
|
||||||
|
|
||||||
OptionBits options = 0 ;
|
|
||||||
|
|
||||||
if ( UMAGetSystemVersion() < 0x1000 )
|
|
||||||
{
|
|
||||||
options |= kTXNAlwaysUseQuickDrawTextMask ;
|
|
||||||
}
|
|
||||||
TXNInitTextension(fontDescriptions, noOfFontDescriptions, options );
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
UMASetSystemIsInitialized(true);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
#if 0
|
||||||
Boolean CanUseATSUI()
|
Boolean CanUseATSUI()
|
||||||
{
|
{
|
||||||
long result;
|
long result;
|
||||||
OSErr err = Gestalt(gestaltATSUVersion, &result);
|
OSErr err = Gestalt(gestaltATSUVersion, &result);
|
||||||
return (err == noErr);
|
return (err == noErr);
|
||||||
}
|
}
|
||||||
*/
|
#endif
|
||||||
|
|
||||||
// process manager
|
// process manager
|
||||||
long UMAGetProcessMode()
|
long UMAGetProcessMode()
|
||||||
{
|
{
|
||||||
@@ -205,6 +198,7 @@ long UMAGetProcessMode()
|
|||||||
|
|
||||||
err = ::GetProcessInformation( &procno , &processinfo ) ;
|
err = ::GetProcessInformation( &procno , &processinfo ) ;
|
||||||
wxASSERT( err == noErr ) ;
|
wxASSERT( err == noErr ) ;
|
||||||
|
|
||||||
return processinfo.processMode ;
|
return processinfo.processMode ;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -219,6 +213,7 @@ MenuRef UMANewMenu( SInt16 id , const wxString& title , wxFontEncoding encoding
|
|||||||
{
|
{
|
||||||
wxString str = wxStripMenuCodes( title ) ;
|
wxString str = wxStripMenuCodes( title ) ;
|
||||||
MenuRef menu ;
|
MenuRef menu ;
|
||||||
|
|
||||||
#if TARGET_CARBON
|
#if TARGET_CARBON
|
||||||
CreateNewMenu( id , 0 , &menu ) ;
|
CreateNewMenu( id , 0 , &menu ) ;
|
||||||
SetMenuTitleWithCFString( menu , wxMacCFStringHolder(str , encoding ) ) ;
|
SetMenuTitleWithCFString( menu , wxMacCFStringHolder(str , encoding ) ) ;
|
||||||
@@ -227,14 +222,17 @@ MenuRef UMANewMenu( SInt16 id , const wxString& title , wxFontEncoding encoding
|
|||||||
wxMacStringToPascal( str , ptitle ) ;
|
wxMacStringToPascal( str , ptitle ) ;
|
||||||
menu = ::NewMenu( id , ptitle ) ;
|
menu = ::NewMenu( id , ptitle ) ;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return menu ;
|
return menu ;
|
||||||
}
|
}
|
||||||
|
|
||||||
void UMASetMenuTitle( MenuRef menu , const wxString& title , wxFontEncoding encoding)
|
void UMASetMenuTitle( MenuRef menu , const wxString& title , wxFontEncoding encoding )
|
||||||
{
|
{
|
||||||
wxString str = wxStripMenuCodes( title ) ;
|
wxString str = wxStripMenuCodes( title ) ;
|
||||||
|
|
||||||
#if TARGET_CARBON
|
#if TARGET_CARBON
|
||||||
SetMenuTitleWithCFString( menu , wxMacCFStringHolder(str , encoding) ) ;
|
SetMenuTitleWithCFString( menu , wxMacCFStringHolder(str , encoding) ) ;
|
||||||
|
|
||||||
#else
|
#else
|
||||||
Str255 ptitle ;
|
Str255 ptitle ;
|
||||||
wxMacStringToPascal( str , ptitle ) ;
|
wxMacStringToPascal( str , ptitle ) ;
|
||||||
@@ -242,11 +240,13 @@ void UMASetMenuTitle( MenuRef menu , const wxString& title , wxFontEncoding enco
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void UMASetMenuItemText( MenuRef menu, MenuItemIndex item, const wxString& title , wxFontEncoding encoding)
|
void UMASetMenuItemText( MenuRef menu, MenuItemIndex item, const wxString& title, wxFontEncoding encoding )
|
||||||
{
|
{
|
||||||
wxString str = wxStripMenuCodes( title ) ;
|
wxString str = wxStripMenuCodes( title ) ;
|
||||||
|
|
||||||
#if TARGET_CARBON
|
#if TARGET_CARBON
|
||||||
SetMenuItemTextWithCFString( menu , item , wxMacCFStringHolder(str , encoding) ) ;
|
SetMenuItemTextWithCFString( menu , item , wxMacCFStringHolder(str , encoding) ) ;
|
||||||
|
|
||||||
#else
|
#else
|
||||||
Str255 ptitle ;
|
Str255 ptitle ;
|
||||||
wxMacStringToPascal( str , ptitle ) ;
|
wxMacStringToPascal( str , ptitle ) ;
|
||||||
@@ -254,10 +254,9 @@ void UMASetMenuItemText( MenuRef menu, MenuItemIndex item, const wxString& tit
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
UInt32 UMAMenuEvent( EventRecord *inEvent )
|
UInt32 UMAMenuEvent( EventRecord *inEvent )
|
||||||
{
|
{
|
||||||
return MenuEvent( inEvent ) ;
|
return MenuEvent( inEvent ) ;
|
||||||
}
|
}
|
||||||
|
|
||||||
void UMAEnableMenuItem( MenuRef inMenu , MenuItemIndex inItem , bool enable)
|
void UMAEnableMenuItem( MenuRef inMenu , MenuItemIndex inItem , bool enable)
|
||||||
@@ -270,15 +269,15 @@ void UMAEnableMenuItem( MenuRef inMenu , MenuItemIndex inItem , bool enable)
|
|||||||
|
|
||||||
void UMAAppendSubMenuItem( MenuRef menu , const wxString& title, wxFontEncoding encoding , SInt16 id )
|
void UMAAppendSubMenuItem( MenuRef menu , const wxString& title, wxFontEncoding encoding , SInt16 id )
|
||||||
{
|
{
|
||||||
MacAppendMenu(menu, "\pA");
|
MacAppendMenu( menu, "\pA" );
|
||||||
UMASetMenuItemText(menu, (SInt16) ::CountMenuItems(menu), title , encoding );
|
UMASetMenuItemText( menu, (SInt16) ::CountMenuItems(menu), title , encoding );
|
||||||
SetMenuItemHierarchicalID( menu , CountMenuItems( menu ) , id ) ;
|
SetMenuItemHierarchicalID( menu , CountMenuItems( menu ) , id ) ;
|
||||||
}
|
}
|
||||||
|
|
||||||
void UMAInsertSubMenuItem( MenuRef menu , const wxString& title, wxFontEncoding encoding , MenuItemIndex item , SInt16 id )
|
void UMAInsertSubMenuItem( MenuRef menu , const wxString& title, wxFontEncoding encoding , MenuItemIndex item , SInt16 id )
|
||||||
{
|
{
|
||||||
MacInsertMenuItem(menu, "\pA" , item);
|
MacInsertMenuItem( menu, "\pA" , item );
|
||||||
UMASetMenuItemText(menu, item+1, title , encoding);
|
UMASetMenuItemText( menu, item+1, title , encoding );
|
||||||
SetMenuItemHierarchicalID( menu , item+1 , id ) ;
|
SetMenuItemHierarchicalID( menu , item+1 , id ) ;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -291,27 +290,21 @@ void UMASetMenuItemShortcut( MenuRef menu , MenuItemIndex item , wxAcceleratorEn
|
|||||||
SInt16 key = entry->GetKeyCode() ;
|
SInt16 key = entry->GetKeyCode() ;
|
||||||
if ( key )
|
if ( key )
|
||||||
{
|
{
|
||||||
bool explicitCommandKey = false ;
|
bool explicitCommandKey = (entry->GetFlags() & wxACCEL_CTRL);
|
||||||
|
|
||||||
if ( entry->GetFlags() & wxACCEL_CTRL )
|
if (entry->GetFlags() & wxACCEL_ALT)
|
||||||
{
|
|
||||||
explicitCommandKey = true ;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (entry->GetFlags() & wxACCEL_ALT )
|
|
||||||
{
|
|
||||||
modifiers |= kMenuOptionModifier ;
|
modifiers |= kMenuOptionModifier ;
|
||||||
}
|
|
||||||
|
|
||||||
if (entry->GetFlags() & wxACCEL_SHIFT)
|
if (entry->GetFlags() & wxACCEL_SHIFT)
|
||||||
{
|
|
||||||
modifiers |= kMenuShiftModifier ;
|
modifiers |= kMenuShiftModifier ;
|
||||||
}
|
|
||||||
|
|
||||||
SInt16 glyph = 0 ;
|
SInt16 glyph = 0 ;
|
||||||
SInt16 macKey = key ;
|
SInt16 macKey = key ;
|
||||||
if ( key >= WXK_F1 && key <= WXK_F15 )
|
if ( key >= WXK_F1 && key <= WXK_F15 )
|
||||||
{
|
{
|
||||||
|
if ( !explicitCommandKey )
|
||||||
|
modifiers |= kMenuNoCommandModifier ;
|
||||||
|
|
||||||
// for some reasons this must be 0 right now
|
// for some reasons this must be 0 right now
|
||||||
// everything else leads to just the first function key item
|
// everything else leads to just the first function key item
|
||||||
// to be selected. Thanks to Ryan Wilcox for finding out.
|
// to be selected. Thanks to Ryan Wilcox for finding out.
|
||||||
@@ -319,73 +312,86 @@ void UMASetMenuItemShortcut( MenuRef menu , MenuItemIndex item , wxAcceleratorEn
|
|||||||
glyph = kMenuF1Glyph + ( key - WXK_F1 ) ;
|
glyph = kMenuF1Glyph + ( key - WXK_F1 ) ;
|
||||||
if ( key >= WXK_F13 )
|
if ( key >= WXK_F13 )
|
||||||
glyph += 13 ;
|
glyph += 13 ;
|
||||||
if ( !explicitCommandKey )
|
|
||||||
modifiers |= kMenuNoCommandModifier ;
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
switch( key )
|
switch ( key )
|
||||||
{
|
{
|
||||||
case WXK_BACK :
|
case WXK_BACK :
|
||||||
macKey = kBackspaceCharCode ;
|
macKey = kBackspaceCharCode ;
|
||||||
glyph = kMenuDeleteLeftGlyph ;
|
glyph = kMenuDeleteLeftGlyph ;
|
||||||
break ;
|
break ;
|
||||||
|
|
||||||
case WXK_TAB :
|
case WXK_TAB :
|
||||||
macKey = kTabCharCode ;
|
macKey = kTabCharCode ;
|
||||||
glyph = kMenuTabRightGlyph ;
|
glyph = kMenuTabRightGlyph ;
|
||||||
break ;
|
break ;
|
||||||
|
|
||||||
case kEnterCharCode :
|
case kEnterCharCode :
|
||||||
macKey = kEnterCharCode ;
|
macKey = kEnterCharCode ;
|
||||||
glyph = kMenuEnterGlyph ;
|
glyph = kMenuEnterGlyph ;
|
||||||
break ;
|
break ;
|
||||||
|
|
||||||
case WXK_RETURN :
|
case WXK_RETURN :
|
||||||
macKey = kReturnCharCode ;
|
macKey = kReturnCharCode ;
|
||||||
glyph = kMenuReturnGlyph ;
|
glyph = kMenuReturnGlyph ;
|
||||||
break ;
|
break ;
|
||||||
|
|
||||||
case WXK_ESCAPE :
|
case WXK_ESCAPE :
|
||||||
macKey = kEscapeCharCode ;
|
macKey = kEscapeCharCode ;
|
||||||
glyph = kMenuEscapeGlyph ;
|
glyph = kMenuEscapeGlyph ;
|
||||||
break ;
|
break ;
|
||||||
|
|
||||||
case WXK_SPACE :
|
case WXK_SPACE :
|
||||||
macKey = ' ' ;
|
macKey = ' ' ;
|
||||||
glyph = kMenuSpaceGlyph ;
|
glyph = kMenuSpaceGlyph ;
|
||||||
break ;
|
break ;
|
||||||
|
|
||||||
case WXK_DELETE :
|
case WXK_DELETE :
|
||||||
macKey = kDeleteCharCode ;
|
macKey = kDeleteCharCode ;
|
||||||
glyph = kMenuDeleteRightGlyph ;
|
glyph = kMenuDeleteRightGlyph ;
|
||||||
break ;
|
break ;
|
||||||
|
|
||||||
case WXK_CLEAR :
|
case WXK_CLEAR :
|
||||||
macKey = kClearCharCode ;
|
macKey = kClearCharCode ;
|
||||||
glyph = kMenuClearGlyph ;
|
glyph = kMenuClearGlyph ;
|
||||||
break ;
|
break ;
|
||||||
|
|
||||||
case WXK_PRIOR : // PAGE UP
|
case WXK_PRIOR : // PAGE UP
|
||||||
macKey = kPageUpCharCode ;
|
macKey = kPageUpCharCode ;
|
||||||
glyph = kMenuPageUpGlyph ;
|
glyph = kMenuPageUpGlyph ;
|
||||||
break ;
|
break ;
|
||||||
|
|
||||||
case WXK_NEXT :
|
case WXK_NEXT :
|
||||||
macKey = kPageDownCharCode ;
|
macKey = kPageDownCharCode ;
|
||||||
glyph = kMenuPageDownGlyph ;
|
glyph = kMenuPageDownGlyph ;
|
||||||
break ;
|
break ;
|
||||||
|
|
||||||
case WXK_LEFT :
|
case WXK_LEFT :
|
||||||
macKey = kLeftArrowCharCode ;
|
macKey = kLeftArrowCharCode ;
|
||||||
glyph = kMenuLeftArrowGlyph ;
|
glyph = kMenuLeftArrowGlyph ;
|
||||||
break ;
|
break ;
|
||||||
|
|
||||||
case WXK_UP :
|
case WXK_UP :
|
||||||
macKey = kUpArrowCharCode ;
|
macKey = kUpArrowCharCode ;
|
||||||
glyph = kMenuUpArrowGlyph ;
|
glyph = kMenuUpArrowGlyph ;
|
||||||
break ;
|
break ;
|
||||||
|
|
||||||
case WXK_RIGHT :
|
case WXK_RIGHT :
|
||||||
macKey = kRightArrowCharCode ;
|
macKey = kRightArrowCharCode ;
|
||||||
glyph = kMenuRightArrowGlyph ;
|
glyph = kMenuRightArrowGlyph ;
|
||||||
break ;
|
break ;
|
||||||
|
|
||||||
case WXK_DOWN :
|
case WXK_DOWN :
|
||||||
macKey = kDownArrowCharCode ;
|
macKey = kDownArrowCharCode ;
|
||||||
glyph = kMenuDownArrowGlyph ;
|
glyph = kMenuDownArrowGlyph ;
|
||||||
break ;
|
break ;
|
||||||
|
|
||||||
default :
|
default :
|
||||||
macKey = toupper( key ) ;
|
macKey = toupper( key ) ;
|
||||||
break ;
|
break ;
|
||||||
}
|
}
|
||||||
|
|
||||||
// we now allow non command key shortcuts
|
// we now allow non command key shortcuts
|
||||||
// remove in case this gives problems
|
// remove in case this gives problems
|
||||||
if ( !explicitCommandKey )
|
if ( !explicitCommandKey )
|
||||||
@@ -397,25 +403,27 @@ void UMASetMenuItemShortcut( MenuRef menu , MenuItemIndex item , wxAcceleratorEn
|
|||||||
if (key != WXK_UP && key != WXK_RIGHT)
|
if (key != WXK_UP && key != WXK_RIGHT)
|
||||||
SetItemCmd( menu, item , macKey );
|
SetItemCmd( menu, item , macKey );
|
||||||
|
|
||||||
SetMenuItemModifiers(menu, item , modifiers ) ;
|
SetMenuItemModifiers( menu, item , modifiers ) ;
|
||||||
|
|
||||||
if ( glyph )
|
if ( glyph )
|
||||||
SetMenuItemKeyGlyph(menu, item , glyph ) ;
|
SetMenuItemKeyGlyph( menu, item , glyph ) ;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void UMAAppendMenuItem( MenuRef menu , const wxString& title, wxFontEncoding encoding , wxAcceleratorEntry *entry )
|
void UMAAppendMenuItem( MenuRef menu , const wxString& title, wxFontEncoding encoding , wxAcceleratorEntry *entry )
|
||||||
{
|
{
|
||||||
MacAppendMenu(menu, "\pA");
|
MacAppendMenu(menu, "\pA");
|
||||||
|
|
||||||
// don't attempt to interpret metacharacters like a '-' at the beginning (would become a separator otherwise)
|
// don't attempt to interpret metacharacters like a '-' at the beginning (would become a separator otherwise)
|
||||||
ChangeMenuItemAttributes( menu , ::CountMenuItems(menu), kMenuItemAttrIgnoreMeta , 0 ) ;
|
ChangeMenuItemAttributes( menu , ::CountMenuItems(menu), kMenuItemAttrIgnoreMeta , 0 ) ;
|
||||||
UMASetMenuItemText(menu, (SInt16) ::CountMenuItems(menu), title , encoding );
|
UMASetMenuItemText(menu, (SInt16) ::CountMenuItems(menu), title , encoding );
|
||||||
UMASetMenuItemShortcut( menu , (SInt16) ::CountMenuItems(menu), entry ) ;
|
UMASetMenuItemShortcut( menu , (SInt16) ::CountMenuItems(menu), entry ) ;
|
||||||
}
|
}
|
||||||
|
|
||||||
void UMAInsertMenuItem( MenuRef menu , const wxString& title, wxFontEncoding encoding , MenuItemIndex item , wxAcceleratorEntry *entry )
|
void UMAInsertMenuItem( MenuRef menu , const wxString& title, wxFontEncoding encoding , MenuItemIndex item , wxAcceleratorEntry *entry )
|
||||||
{
|
{
|
||||||
MacInsertMenuItem( menu , "\pA" , item) ;
|
MacInsertMenuItem( menu , "\pA" , item) ;
|
||||||
|
|
||||||
// don't attempt to interpret metacharacters like a '-' at the beginning (would become a separator otherwise)
|
// don't attempt to interpret metacharacters like a '-' at the beginning (would become a separator otherwise)
|
||||||
ChangeMenuItemAttributes( menu , item+1, kMenuItemAttrIgnoreMeta , 0 ) ;
|
ChangeMenuItemAttributes( menu , item+1, kMenuItemAttrIgnoreMeta , 0 ) ;
|
||||||
UMASetMenuItemText(menu, item+1 , title , encoding );
|
UMASetMenuItemText(menu, item+1 , title , encoding );
|
||||||
@@ -431,32 +439,39 @@ int gPrOpenCounter = 0 ;
|
|||||||
OSStatus UMAPrOpen()
|
OSStatus UMAPrOpen()
|
||||||
{
|
{
|
||||||
OSErr err = noErr ;
|
OSErr err = noErr ;
|
||||||
|
|
||||||
++gPrOpenCounter ;
|
++gPrOpenCounter ;
|
||||||
|
|
||||||
if ( gPrOpenCounter == 1 )
|
if ( gPrOpenCounter == 1 )
|
||||||
{
|
{
|
||||||
PrOpen() ;
|
PrOpen() ;
|
||||||
err = PrError() ;
|
err = PrError() ;
|
||||||
wxASSERT( err == noErr ) ;
|
wxASSERT( err == noErr ) ;
|
||||||
}
|
}
|
||||||
|
|
||||||
return err ;
|
return err ;
|
||||||
}
|
}
|
||||||
|
|
||||||
OSStatus UMAPrClose()
|
OSStatus UMAPrClose()
|
||||||
{
|
{
|
||||||
OSErr err = noErr ;
|
OSErr err = noErr ;
|
||||||
|
|
||||||
wxASSERT( gPrOpenCounter >= 1 ) ;
|
wxASSERT( gPrOpenCounter >= 1 ) ;
|
||||||
|
|
||||||
if ( gPrOpenCounter == 1 )
|
if ( gPrOpenCounter == 1 )
|
||||||
{
|
{
|
||||||
PrClose() ;
|
PrClose() ;
|
||||||
err = PrError() ;
|
err = PrError() ;
|
||||||
wxASSERT( err == noErr ) ;
|
wxASSERT( err == noErr ) ;
|
||||||
}
|
}
|
||||||
|
|
||||||
--gPrOpenCounter ;
|
--gPrOpenCounter ;
|
||||||
|
|
||||||
return err ;
|
return err ;
|
||||||
}
|
}
|
||||||
|
|
||||||
pascal QDGlobalsPtr GetQDGlobalsPtr (void) ;
|
pascal QDGlobalsPtr GetQDGlobalsPtr() ;
|
||||||
pascal QDGlobalsPtr GetQDGlobalsPtr (void)
|
pascal QDGlobalsPtr GetQDGlobalsPtr()
|
||||||
{
|
{
|
||||||
return QDGlobalsPtr (* (Ptr*) LMGetCurrentA5 ( ) - 0xCA);
|
return QDGlobalsPtr (* (Ptr*) LMGetCurrentA5 ( ) - 0xCA);
|
||||||
}
|
}
|
||||||
@@ -467,30 +482,32 @@ void UMAShowWatchCursor()
|
|||||||
{
|
{
|
||||||
OSErr err = noErr;
|
OSErr err = noErr;
|
||||||
|
|
||||||
CursHandle watchFob = GetCursor (watchCursor);
|
CursHandle watchFob = GetCursor(watchCursor);
|
||||||
|
|
||||||
if (!watchFob)
|
if (watchFob == NULL)
|
||||||
|
{
|
||||||
err = nilHandleErr;
|
err = nilHandleErr;
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
#if TARGET_CARBON
|
#if TARGET_CARBON
|
||||||
// Cursor preservedArrow;
|
// Cursor preservedArrow;
|
||||||
// GetQDGlobalsArrow (&preservedArrow);
|
// GetQDGlobalsArrow(&preservedArrow);
|
||||||
// SetQDGlobalsArrow (*watchFob);
|
// SetQDGlobalsArrow(*watchFob);
|
||||||
// InitCursor ( );
|
// InitCursor();
|
||||||
// SetQDGlobalsArrow (&preservedArrow);
|
// SetQDGlobalsArrow(&preservedArrow);
|
||||||
SetCursor (*watchFob);
|
SetCursor(*watchFob);
|
||||||
#else
|
#else
|
||||||
SetCursor (*watchFob);
|
SetCursor(*watchFob);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void UMAShowArrowCursor()
|
void UMAShowArrowCursor()
|
||||||
{
|
{
|
||||||
#if TARGET_CARBON
|
#if TARGET_CARBON
|
||||||
Cursor arrow;
|
Cursor arrow;
|
||||||
SetCursor (GetQDGlobalsArrow (&arrow));
|
SetCursor( GetQDGlobalsArrow(&arrow) );
|
||||||
#else
|
#else
|
||||||
SetCursor (&(qd.arrow));
|
SetCursor (&(qd.arrow));
|
||||||
#endif
|
#endif
|
||||||
@@ -498,9 +515,10 @@ void UMAShowArrowCursor()
|
|||||||
|
|
||||||
// window manager
|
// window manager
|
||||||
|
|
||||||
GrafPtr UMAGetWindowPort( WindowRef inWindowRef )
|
GrafPtr UMAGetWindowPort( WindowRef inWindowRef )
|
||||||
{
|
{
|
||||||
wxASSERT( inWindowRef != NULL ) ;
|
wxASSERT( inWindowRef != NULL ) ;
|
||||||
|
|
||||||
#if TARGET_CARBON
|
#if TARGET_CARBON
|
||||||
return (GrafPtr) GetWindowPort( inWindowRef ) ;
|
return (GrafPtr) GetWindowPort( inWindowRef ) ;
|
||||||
#else
|
#else
|
||||||
@@ -508,16 +526,18 @@ GrafPtr UMAGetWindowPort( WindowRef inWindowRef )
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void UMADisposeWindow( WindowRef inWindowRef )
|
void UMADisposeWindow( WindowRef inWindowRef )
|
||||||
{
|
{
|
||||||
wxASSERT( inWindowRef != NULL ) ;
|
wxASSERT( inWindowRef != NULL ) ;
|
||||||
|
|
||||||
DisposeWindow( inWindowRef ) ;
|
DisposeWindow( inWindowRef ) ;
|
||||||
}
|
}
|
||||||
|
|
||||||
void UMASetWTitle( WindowRef inWindowRef , const wxString& title , wxFontEncoding encoding)
|
void UMASetWTitle( WindowRef inWindowRef , const wxString& title , wxFontEncoding encoding )
|
||||||
{
|
{
|
||||||
#if TARGET_CARBON
|
#if TARGET_CARBON
|
||||||
SetWindowTitleWithCFString( inWindowRef , wxMacCFStringHolder(title , encoding) ) ;
|
SetWindowTitleWithCFString( inWindowRef , wxMacCFStringHolder(title , encoding) ) ;
|
||||||
|
|
||||||
#else
|
#else
|
||||||
Str255 ptitle ;
|
Str255 ptitle ;
|
||||||
wxMacStringToPascal( title , ptitle ) ;
|
wxMacStringToPascal( title , ptitle ) ;
|
||||||
@@ -527,10 +547,11 @@ void UMASetWTitle( WindowRef inWindowRef , const wxString& title , wxFontEncodin
|
|||||||
|
|
||||||
// appearance additions
|
// appearance additions
|
||||||
|
|
||||||
void UMASetControlTitle( ControlRef inControl , const wxString& title , wxFontEncoding encoding)
|
void UMASetControlTitle( ControlRef inControl , const wxString& title , wxFontEncoding encoding )
|
||||||
{
|
{
|
||||||
#if TARGET_CARBON
|
#if TARGET_CARBON
|
||||||
SetControlTitleWithCFString( inControl , wxMacCFStringHolder(title , encoding) ) ;
|
SetControlTitleWithCFString( inControl , wxMacCFStringHolder(title , encoding) ) ;
|
||||||
|
|
||||||
#else
|
#else
|
||||||
Str255 ptitle ;
|
Str255 ptitle ;
|
||||||
wxMacStringToPascal( title , ptitle ) ;
|
wxMacStringToPascal( title , ptitle ) ;
|
||||||
@@ -540,7 +561,10 @@ void UMASetControlTitle( ControlRef inControl , const wxString& title , wxFontEn
|
|||||||
|
|
||||||
void UMAActivateControl( ControlRef inControl )
|
void UMAActivateControl( ControlRef inControl )
|
||||||
{
|
{
|
||||||
#if !TARGET_API_MAC_OSX
|
#if TARGET_API_MAC_OSX
|
||||||
|
::ActivateControl( inControl ) ;
|
||||||
|
|
||||||
|
#else
|
||||||
// we have to add the control after again to the update rgn
|
// we have to add the control after again to the update rgn
|
||||||
// otherwise updates get lost
|
// otherwise updates get lost
|
||||||
if ( !IsControlActive( inControl ) )
|
if ( !IsControlActive( inControl ) )
|
||||||
@@ -548,14 +572,15 @@ void UMAActivateControl( ControlRef inControl )
|
|||||||
bool visible = IsControlVisible( inControl ) ;
|
bool visible = IsControlVisible( inControl ) ;
|
||||||
if ( visible )
|
if ( visible )
|
||||||
SetControlVisibility( inControl , false , false ) ;
|
SetControlVisibility( inControl , false , false ) ;
|
||||||
#endif
|
|
||||||
::ActivateControl( inControl ) ;
|
::ActivateControl( inControl ) ;
|
||||||
#if !TARGET_API_MAC_OSX
|
|
||||||
if ( visible ) {
|
if ( visible )
|
||||||
|
{
|
||||||
SetControlVisibility( inControl , true , false ) ;
|
SetControlVisibility( inControl , true , false ) ;
|
||||||
|
|
||||||
Rect ctrlBounds ;
|
Rect ctrlBounds ;
|
||||||
InvalWindowRect(GetControlOwner(inControl),UMAGetControlBoundsInWindowCoords(inControl,&ctrlBounds) ) ;
|
InvalWindowRect( GetControlOwner(inControl), UMAGetControlBoundsInWindowCoords(inControl, &ctrlBounds) ) ;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@@ -563,90 +588,107 @@ void UMAActivateControl( ControlRef inControl )
|
|||||||
|
|
||||||
void UMAMoveControl( ControlRef inControl , short x , short y )
|
void UMAMoveControl( ControlRef inControl , short x , short y )
|
||||||
{
|
{
|
||||||
#if !TARGET_API_MAC_OSX
|
#if TARGET_API_MAC_OSX
|
||||||
|
::MoveControl( inControl , x , y ) ;
|
||||||
|
|
||||||
|
#else
|
||||||
bool visible = IsControlVisible( inControl ) ;
|
bool visible = IsControlVisible( inControl ) ;
|
||||||
if ( visible ) {
|
if ( visible )
|
||||||
|
{
|
||||||
SetControlVisibility( inControl , false , false ) ;
|
SetControlVisibility( inControl , false , false ) ;
|
||||||
Rect ctrlBounds ;
|
Rect ctrlBounds ;
|
||||||
InvalWindowRect(GetControlOwner(inControl),GetControlBounds(inControl,&ctrlBounds) ) ;
|
InvalWindowRect( GetControlOwner(inControl), GetControlBounds(inControl, &ctrlBounds) ) ;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
::MoveControl( inControl , x , y ) ;
|
::MoveControl( inControl , x , y ) ;
|
||||||
#if !TARGET_API_MAC_OSX
|
|
||||||
if ( visible ) {
|
if ( visible )
|
||||||
|
{
|
||||||
SetControlVisibility( inControl , true , false ) ;
|
SetControlVisibility( inControl , true , false ) ;
|
||||||
Rect ctrlBounds ;
|
Rect ctrlBounds ;
|
||||||
InvalWindowRect(GetControlOwner(inControl),GetControlBounds(inControl,&ctrlBounds) ) ;
|
InvalWindowRect( GetControlOwner(inControl), GetControlBounds(inControl, &ctrlBounds) ) ;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void UMASizeControl( ControlRef inControl , short x , short y )
|
void UMASizeControl( ControlRef inControl , short x , short y )
|
||||||
{
|
{
|
||||||
#if !TARGET_API_MAC_OSX
|
#if TARGET_API_MAC_OSX
|
||||||
|
::SizeControl( inControl , x , y ) ;
|
||||||
|
|
||||||
|
#else
|
||||||
bool visible = IsControlVisible( inControl ) ;
|
bool visible = IsControlVisible( inControl ) ;
|
||||||
if ( visible ) {
|
if ( visible )
|
||||||
|
{
|
||||||
SetControlVisibility( inControl , false , false ) ;
|
SetControlVisibility( inControl , false , false ) ;
|
||||||
Rect ctrlBounds ;
|
Rect ctrlBounds ;
|
||||||
InvalWindowRect(GetControlOwner(inControl),GetControlBounds(inControl,&ctrlBounds) ) ;
|
InvalWindowRect( GetControlOwner(inControl), GetControlBounds(inControl, &ctrlBounds) ) ;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
::SizeControl( inControl , x , y ) ;
|
::SizeControl( inControl , x , y ) ;
|
||||||
#if !TARGET_API_MAC_OSX
|
|
||||||
if ( visible ) {
|
if ( visible )
|
||||||
|
{
|
||||||
SetControlVisibility( inControl , true , false ) ;
|
SetControlVisibility( inControl , true , false ) ;
|
||||||
Rect ctrlBounds ;
|
Rect ctrlBounds ;
|
||||||
InvalWindowRect(GetControlOwner(inControl),GetControlBounds(inControl,&ctrlBounds) ) ;
|
InvalWindowRect( GetControlOwner(inControl), GetControlBounds(inControl, &ctrlBounds) ) ;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void UMADeactivateControl( ControlRef inControl )
|
void UMADeactivateControl( ControlRef inControl )
|
||||||
{
|
{
|
||||||
#if !TARGET_API_MAC_OSX
|
#if TARGET_API_MAC_OSX
|
||||||
|
::DeactivateControl( inControl ) ;
|
||||||
|
|
||||||
|
#else
|
||||||
// we have to add the control after again to the update rgn
|
// we have to add the control after again to the update rgn
|
||||||
// otherwise updates get lost
|
// otherwise updates get lost
|
||||||
bool visible = IsControlVisible( inControl ) ;
|
bool visible = IsControlVisible( inControl ) ;
|
||||||
if ( visible )
|
if ( visible )
|
||||||
SetControlVisibility( inControl , false , false ) ;
|
SetControlVisibility( inControl , false , false ) ;
|
||||||
#endif
|
|
||||||
::DeactivateControl( inControl ) ;
|
::DeactivateControl( inControl ) ;
|
||||||
#if !TARGET_API_MAC_OSX
|
|
||||||
if ( visible ) {
|
if ( visible )
|
||||||
|
{
|
||||||
SetControlVisibility( inControl , true , false ) ;
|
SetControlVisibility( inControl , true , false ) ;
|
||||||
Rect ctrlBounds ;
|
Rect ctrlBounds ;
|
||||||
InvalWindowRect(GetControlOwner(inControl),UMAGetControlBoundsInWindowCoords(inControl,&ctrlBounds) ) ;
|
InvalWindowRect( GetControlOwner(inControl), UMAGetControlBoundsInWindowCoords(inControl, &ctrlBounds) ) ;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
// shows the control and adds the region to the update region
|
// shows the control and adds the region to the update region
|
||||||
void UMAShowControl (ControlRef inControl)
|
void UMAShowControl( ControlRef inControl )
|
||||||
{
|
{
|
||||||
SetControlVisibility( inControl , true , false ) ;
|
SetControlVisibility( inControl , true , false ) ;
|
||||||
Rect ctrlBounds ;
|
Rect ctrlBounds ;
|
||||||
InvalWindowRect(GetControlOwner(inControl),UMAGetControlBoundsInWindowCoords(inControl,&ctrlBounds) ) ;
|
InvalWindowRect( GetControlOwner(inControl), UMAGetControlBoundsInWindowCoords(inControl, &ctrlBounds) ) ;
|
||||||
}
|
}
|
||||||
|
|
||||||
// hides the control and adds the region to the update region
|
// hides the control and adds the region to the update region
|
||||||
void UMAHideControl (ControlRef inControl)
|
void UMAHideControl( ControlRef inControl )
|
||||||
{
|
{
|
||||||
SetControlVisibility( inControl , false , false ) ;
|
SetControlVisibility( inControl , false , false ) ;
|
||||||
Rect ctrlBounds ;
|
Rect ctrlBounds ;
|
||||||
InvalWindowRect(GetControlOwner(inControl),UMAGetControlBoundsInWindowCoords(inControl,&ctrlBounds) ) ;
|
InvalWindowRect( GetControlOwner(inControl), UMAGetControlBoundsInWindowCoords(inControl, &ctrlBounds) ) ;
|
||||||
}
|
}
|
||||||
|
|
||||||
// keyboard focus
|
// keyboard focus
|
||||||
OSErr UMASetKeyboardFocus (WindowPtr inWindow,
|
OSErr UMASetKeyboardFocus( WindowPtr inWindow,
|
||||||
ControlRef inControl,
|
ControlRef inControl,
|
||||||
ControlFocusPart inPart)
|
ControlFocusPart inPart )
|
||||||
{
|
{
|
||||||
OSErr err = noErr;
|
OSErr err = noErr;
|
||||||
GrafPtr port ;
|
GrafPtr port ;
|
||||||
GetPort( &port ) ;
|
|
||||||
|
|
||||||
|
GetPort( &port ) ;
|
||||||
SetPortWindowPort( inWindow ) ;
|
SetPortWindowPort( inWindow ) ;
|
||||||
|
|
||||||
err = SetKeyboardFocus( inWindow , inControl , inPart ) ;
|
err = SetKeyboardFocus( inWindow , inControl , inPart ) ;
|
||||||
SetPort( port ) ;
|
SetPort( port ) ;
|
||||||
|
|
||||||
return err ;
|
return err ;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -674,12 +716,13 @@ void UMAHighlightAndActivateWindow( WindowRef inWindowRef , bool inActivate )
|
|||||||
{
|
{
|
||||||
// bool isHighlighted = IsWindowHighlited( inWindowRef ) ;
|
// bool isHighlighted = IsWindowHighlited( inWindowRef ) ;
|
||||||
// if ( inActivate != isHighlighted )
|
// if ( inActivate != isHighlighted )
|
||||||
|
|
||||||
GrafPtr port ;
|
GrafPtr port ;
|
||||||
GetPort( &port ) ;
|
GetPort( &port ) ;
|
||||||
SetPortWindowPort( inWindowRef ) ;
|
SetPortWindowPort( inWindowRef ) ;
|
||||||
HiliteWindow( inWindowRef , inActivate ) ;
|
HiliteWindow( inWindowRef , inActivate ) ;
|
||||||
ControlRef control = NULL ;
|
ControlRef control = NULL ;
|
||||||
::GetRootControl( inWindowRef , & control ) ;
|
::GetRootControl( inWindowRef , &control ) ;
|
||||||
if ( control )
|
if ( control )
|
||||||
{
|
{
|
||||||
if ( inActivate )
|
if ( inActivate )
|
||||||
@@ -687,6 +730,7 @@ void UMAHighlightAndActivateWindow( WindowRef inWindowRef , bool inActivate )
|
|||||||
else
|
else
|
||||||
UMADeactivateControl( control ) ;
|
UMADeactivateControl( control ) ;
|
||||||
}
|
}
|
||||||
|
|
||||||
SetPort( port ) ;
|
SetPort( port ) ;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -702,28 +746,29 @@ static MenuItemIndex firstCustomItemIndex = 0 ;
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
OSStatus UMAGetHelpMenu(
|
OSStatus UMAGetHelpMenu(
|
||||||
MenuRef * outHelpMenu,
|
MenuRef * outHelpMenu,
|
||||||
MenuItemIndex * outFirstCustomItemIndex)
|
MenuItemIndex * outFirstCustomItemIndex)
|
||||||
{
|
{
|
||||||
#if TARGET_CARBON
|
#if TARGET_CARBON
|
||||||
return HMGetHelpMenu( outHelpMenu , outFirstCustomItemIndex ) ;
|
return HMGetHelpMenu( outHelpMenu , outFirstCustomItemIndex ) ;
|
||||||
|
|
||||||
#else
|
#else
|
||||||
MenuRef helpMenuHandle ;
|
MenuRef helpMenuHandle ;
|
||||||
|
|
||||||
helpMenuStatus = HMGetHelpMenuHandle( &helpMenuHandle ) ;
|
helpMenuStatus = HMGetHelpMenuHandle( &helpMenuHandle ) ;
|
||||||
if ( firstCustomItemIndex == 0 && helpMenuStatus == noErr )
|
if ( firstCustomItemIndex == 0 && helpMenuStatus == noErr )
|
||||||
{
|
|
||||||
firstCustomItemIndex = CountMenuItems( helpMenuHandle ) + 1 ;
|
firstCustomItemIndex = CountMenuItems( helpMenuHandle ) + 1 ;
|
||||||
}
|
|
||||||
if ( outFirstCustomItemIndex )
|
if ( outFirstCustomItemIndex )
|
||||||
{
|
|
||||||
*outFirstCustomItemIndex = firstCustomItemIndex ;
|
*outFirstCustomItemIndex = firstCustomItemIndex ;
|
||||||
}
|
|
||||||
*outHelpMenu = helpMenuHandle ;
|
*outHelpMenu = helpMenuHandle ;
|
||||||
|
|
||||||
return helpMenuStatus ;
|
return helpMenuStatus ;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
wxMacPortStateHelper::wxMacPortStateHelper( GrafPtr newport)
|
wxMacPortStateHelper::wxMacPortStateHelper( GrafPtr newport )
|
||||||
{
|
{
|
||||||
m_clip = NULL ;
|
m_clip = NULL ;
|
||||||
Setup( newport ) ;
|
Setup( newport ) ;
|
||||||
@@ -738,17 +783,19 @@ void wxMacPortStateHelper::Setup( GrafPtr newport )
|
|||||||
{
|
{
|
||||||
GetPort( &m_oldPort ) ;
|
GetPort( &m_oldPort ) ;
|
||||||
SetPort( newport ) ;
|
SetPort( newport ) ;
|
||||||
SetOrigin(0,0);
|
SetOrigin(0, 0);
|
||||||
|
|
||||||
wxASSERT_MSG( m_clip == NULL , wxT("Cannot call setup twice") ) ;
|
wxASSERT_MSG( m_clip == NULL , wxT("Cannot call setup twice") ) ;
|
||||||
m_clip = NewRgn() ;
|
m_clip = NewRgn() ;
|
||||||
GetClip( m_clip );
|
GetClip( m_clip );
|
||||||
m_textFont = GetPortTextFont( (CGrafPtr) newport);
|
m_textFont = GetPortTextFont( (CGrafPtr) newport );
|
||||||
m_textSize = GetPortTextSize( (CGrafPtr) newport);
|
m_textSize = GetPortTextSize( (CGrafPtr) newport );
|
||||||
m_textStyle = GetPortTextFace( (CGrafPtr) newport);
|
m_textStyle = GetPortTextFace( (CGrafPtr) newport );
|
||||||
m_textMode = GetPortTextMode( (CGrafPtr) newport);
|
m_textMode = GetPortTextMode( (CGrafPtr) newport );
|
||||||
GetThemeDrawingState( &m_drawingState ) ;
|
GetThemeDrawingState( &m_drawingState ) ;
|
||||||
m_currentPort = newport ;
|
m_currentPort = newport ;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxMacPortStateHelper::Clear()
|
void wxMacPortStateHelper::Clear()
|
||||||
{
|
{
|
||||||
if ( m_clip )
|
if ( m_clip )
|
||||||
@@ -778,22 +825,23 @@ wxMacPortStateHelper::~wxMacPortStateHelper()
|
|||||||
OSStatus UMAPutScrap( Size size , OSType type , void *data )
|
OSStatus UMAPutScrap( Size size , OSType type , void *data )
|
||||||
{
|
{
|
||||||
OSStatus err = noErr ;
|
OSStatus err = noErr ;
|
||||||
|
|
||||||
#if !TARGET_CARBON
|
#if !TARGET_CARBON
|
||||||
err = PutScrap( size , type , data ) ;
|
err = PutScrap( size , type , data ) ;
|
||||||
#else
|
#else
|
||||||
ScrapRef scrap;
|
ScrapRef scrap;
|
||||||
err = GetCurrentScrap (&scrap);
|
err = GetCurrentScrap( &scrap );
|
||||||
if ( !err )
|
if ( err == noErr )
|
||||||
{
|
err = PutScrapFlavor( scrap, type , 0, size, data );
|
||||||
err = PutScrapFlavor (scrap, type , 0, size, data);
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return err ;
|
return err ;
|
||||||
}
|
}
|
||||||
|
|
||||||
Rect* UMAGetControlBoundsInWindowCoords(ControlRef theControl, Rect *bounds)
|
Rect * UMAGetControlBoundsInWindowCoords( ControlRef theControl, Rect *bounds )
|
||||||
{
|
{
|
||||||
GetControlBounds( theControl , bounds ) ;
|
GetControlBounds( theControl , bounds ) ;
|
||||||
|
|
||||||
#if TARGET_API_MAC_OSX
|
#if TARGET_API_MAC_OSX
|
||||||
WindowRef tlwref = GetControlOwner( theControl ) ;
|
WindowRef tlwref = GetControlOwner( theControl ) ;
|
||||||
|
|
||||||
@@ -801,15 +849,15 @@ Rect* UMAGetControlBoundsInWindowCoords(ControlRef theControl, Rect *bounds)
|
|||||||
if ( tlwwx != NULL && tlwwx->MacUsesCompositing() )
|
if ( tlwwx != NULL && tlwwx->MacUsesCompositing() )
|
||||||
{
|
{
|
||||||
ControlRef rootControl = tlwwx->GetPeer()->GetControlRef() ;
|
ControlRef rootControl = tlwwx->GetPeer()->GetControlRef() ;
|
||||||
HIPoint hiPoint = CGPointMake( 0 , 0 ) ;
|
HIPoint hiPoint = CGPointMake( 0 , 0 ) ;
|
||||||
HIViewConvertPoint( &hiPoint , HIViewGetSuperview(theControl) , rootControl ) ;
|
HIViewConvertPoint( &hiPoint , HIViewGetSuperview(theControl) , rootControl ) ;
|
||||||
OffsetRect( bounds , (short) hiPoint.x , (short) hiPoint.y ) ;
|
OffsetRect( bounds , (short) hiPoint.x , (short) hiPoint.y ) ;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return bounds ;
|
return bounds ;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#endif // wxUSE_GUI
|
#endif // wxUSE_GUI
|
||||||
|
|
||||||
#if wxUSE_BASE
|
#if wxUSE_BASE
|
||||||
@@ -826,5 +874,5 @@ void UMASetSystemIsInitialized(bool val)
|
|||||||
sUMASystemInitialized = val;
|
sUMASystemInitialized = val;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#endif // wxUSE_BASE
|
#endif // wxUSE_BASE
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user