bool m_shown ;
long m_mark ;
wxMacToolTipTimer* m_timer ;
+#ifdef TARGET_CARBON
+ CFStringRef m_helpTextRef ;
+#endif
} ;
class wxMacToolTipTimer : public wxTimer
void wxToolTip::SetWindow( wxWindow *win )
{
- m_window = win;
+ m_window = win ;
}
void wxToolTip::Enable( bool flag )
m_mark = 0 ;
m_shown = false ;
m_timer = NULL ;
+ m_helpTextRef = NULL ;
}
-void wxMacToolTip::Setup( WindowRef window , wxString text , wxPoint localPosition )
+void wxMacToolTip::Setup( WindowRef win , wxString text , wxPoint localPosition )
{
m_mark++ ;
Clear() ;
m_position = localPosition ;
- m_label = wxMacMakeMacStringFromPC( text ) ;
- m_window = window ;
- s_ToolTipWindowRef = window ;
+ if( wxApp::s_macDefaultEncodingIsPC )
+ m_label = wxMacMakeMacStringFromPC( text ) ;
+ else
+ m_label = text ;
+ m_window =win;
+ s_ToolTipWindowRef = m_window ;
m_backpict = NULL ;
if ( m_timer )
delete m_timer ;
wxMacToolTip::~wxMacToolTip()
{
- if ( m_timer )
+ if ( m_timer ) {
delete m_timer ;
- if ( m_backpict )
- Clear() ;
+ m_timer = NULL;
+ }
+ if ( m_backpict )
+ Clear() ;
}
const short kTipBorder = 2 ;
if ( m_window == s_ToolTipWindowRef )
{
+ m_shown = true ;
#if TARGET_CARBON
-/*
if ( HMDisplayTag != (void*) kUnresolvedCFragSymbolAddress )
{
- HMDisplayTag(
+ HMHelpContentRec tag ;
+ tag.version = kMacHelpVersion;
+ SetRect( &tag.absHotRect , m_position.x - 2 , m_position.y - 2 , m_position.x + 2 , m_position.y + 2 ) ;
+ GrafPtr port ;
+ GetPort( &port ) ;
+ SetPortWindowPort(m_window) ;
+ LocalToGlobal( (Point *) &tag.absHotRect.top );
+ LocalToGlobal( (Point *) &tag.absHotRect.bottom );
+ SetPort( port );
+ if( m_helpTextRef )
+ CFRelease( m_helpTextRef )
+ m_helpTextRef = wxMacCreateCFString(m_label) ;
+ tag.content[kHMMinimumContentIndex].contentType = kHMCFStringContent ;
+ tag.content[kHMMinimumContentIndex].u.tagCFString = text ;
+ tag.content[kHMMaximumContentIndex].contentType = kHMCFStringContent ;
+ tag.content[kHMMaximumContentIndex].u.tagCFString = text ;
+ tag.tagSide = kHMDefaultSide;
+ HMDisplayTag( &tag );
}
else
-*/
#endif
{
wxMacPortStateHelper help( (GrafPtr) GetWindowPort( m_window ) );
-
- m_shown = true ;
-
- TextFont( kFontIDGeneva ) ;
- TextSize( 10 ) ;
- TextFace( 0 ) ;
+#if TARGET_CARBON
+ bool useDrawThemeText = ( DrawThemeTextBox != (void*) kUnresolvedCFragSymbolAddress ) ;
+#endif
+
+ FontFamilyID fontId ;
+ Str255 fontName ;
+ SInt16 fontSize ;
+ Style fontStyle ;
+ GetThemeFont(kThemeSmallSystemFont , GetApplicationScript() , fontName , &fontSize , &fontStyle ) ;
+ GetFNum( fontName, &fontId );
+
+ TextFont( fontId ) ;
+ TextSize( fontSize ) ;
+ TextFace( fontStyle ) ;
FontInfo fontInfo;
::GetFontInfo(&fontInfo);
short lineh = fontInfo.ascent + fontInfo.descent + fontInfo.leading;
m_rect.left = m_position.x + kTipOffset;
m_rect.top = m_position.y + kTipOffset;
m_rect.right = m_rect.left + width + 2 * kTipBorder;
+#if TARGET_CARBON
+ if ( useDrawThemeText )
+ m_rect.right += kTipBorder ;
+#endif
m_rect.bottom = m_rect.top + height + 2 * kTipBorder;
+ Rect r ;
+ GetPortBounds( GetWindowPort( m_window ) , &r ) ;
+ if ( m_rect.top < 0 )
+ {
+ m_rect.bottom += -m_rect.top ;
+ m_rect.top = 0 ;
+ }
+ if ( m_rect.left < 0 )
+ {
+ m_rect.right += -m_rect.left ;
+ m_rect.left = 0 ;
+ }
+ if ( m_rect.right > r.right )
+ {
+ m_rect.left -= (m_rect.right - r.right ) ;
+ m_rect.right = r.right ;
+ }
+ if ( m_rect.bottom > r.bottom )
+ {
+ m_rect.top -= (m_rect.bottom - r.bottom) ;
+ m_rect.bottom = r.bottom ;
+ }
ClipRect( &m_rect ) ;
BackColor( whiteColor ) ;
ForeColor(blackColor ) ;
+ GWorldPtr port ;
+ NewGWorld( &port , wxDisplayDepth() , &m_rect , NULL , NULL , 0 ) ;
+ CGrafPtr origPort ;
+ GDHandle origDevice ;
+
+ GetGWorld( &origPort , &origDevice ) ;
+ SetGWorld( port , NULL ) ;
+
m_backpict = OpenPicture(&m_rect);
CopyBits(GetPortBitMapForCopyBits(GetWindowPort(m_window)),
- GetPortBitMapForCopyBits(GetWindowPort(m_window)),
+ GetPortBitMapForCopyBits(port),
&m_rect,
&m_rect,
srcCopy,
NULL);
+ ClosePicture();
+ SetGWorld( origPort , origDevice ) ;
+ DisposeGWorld( port ) ;
+ PenNormal() ;
- ClosePicture();
- PenNormal() ;
- SetThemeBackground(kThemeBrushNotificationWindowBackground,32,true) ;
- SetThemeTextColor(kThemeTextColorNotification,32,true) ;
- EraseRect( &m_rect ) ;
+ RGBColor tooltipbackground = { 0xFFFF , 0xFFFF , 0xC000 } ;
+ BackColor( whiteColor ) ;
+ RGBForeColor( &tooltipbackground ) ;
+
+ PaintRect( &m_rect ) ;
+ ForeColor(blackColor ) ;
FrameRect( &m_rect ) ;
+ SetThemeTextColor(kThemeTextColorNotification,wxDisplayDepth(),true) ;
::MoveTo( m_rect.left + kTipBorder , m_rect.top + fontInfo.ascent + kTipBorder);
i = 0 ;
laststop = 0 ;
height = 0 ;
+
while( i < length )
{
if( text[i] == 13 || text[i] == 10)
{
- ::DrawText( text , laststop , i - laststop ) ;
- height += lineh ;
- ::MoveTo( m_rect.left + kTipBorder , m_rect.top + fontInfo.ascent + kTipBorder + height );
+#if TARGET_CARBON
+ if ( useDrawThemeText )
+ {
+ Rect frame ;
+ frame.top = m_rect.top + kTipBorder + height ;
+ frame.left = m_rect.left + kTipBorder ;
+ frame.bottom = frame.top + 1000 ;
+ frame.right = frame.left + 1000 ;
+ CFStringRef mString = CFStringCreateWithBytes( NULL , (UInt8*) text + laststop , i - laststop , CFStringGetSystemEncoding(), false ) ;
+ ::DrawThemeTextBox( mString,
+ kThemeCurrentPortFont,
+ kThemeStateActive,
+ true,
+ &frame,
+ teJustLeft,
+ nil );
+ CFRelease( mString ) ;
+ height += lineh ;
+ }
+ else
+#endif
+ {
+ ::DrawText( text , laststop , i - laststop ) ;
+ height += lineh ;
+ ::MoveTo( m_rect.left + kTipBorder , m_rect.top + fontInfo.ascent + kTipBorder + height );
+ }
laststop = i+1 ;
}
i++ ;
}
-
- ::DrawText( text , laststop , i - laststop ) ;
+#if TARGET_CARBON
+ if ( useDrawThemeText )
+ {
+ Rect frame ;
+ frame.top = m_rect.top + kTipBorder + height ;
+ frame.left = m_rect.left + kTipBorder ;
+ frame.bottom = frame.top + 1000 ;
+ frame.right = frame.left + 1000 ;
+ CFStringRef mString = CFStringCreateWithCString( NULL , text + laststop , kCFStringEncodingMacRoman ) ;
+ ::DrawThemeTextBox( mString,
+ kThemeCurrentPortFont,
+ kThemeStateActive,
+ true,
+ &frame,
+ teJustLeft,
+ nil );
+ CFRelease( mString ) ;
+ }
+ else
+#endif
+ {
+ ::DrawText( text , laststop , i - laststop ) ;
+ }
::TextMode( srcOr ) ;
- // DrawText( m_label , 0 , m_label.Length() ) ;
- }
+ }
}
}
}
if ( !m_shown )
return ;
-
+#if TARGET_CARBON
+ HMHideTag() ;
+ if( m_helpTextRef )
+ CFRelease( m_helpTextRef )
+#else
if ( m_window == s_ToolTipWindowRef && m_backpict )
{
wxMacPortStateHelper help( (GrafPtr) GetWindowPort(m_window) ) ;
KillPicture(m_backpict);
m_backpict = NULL ;
}
+#endif
}
#endif