X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/7eb67c0012ec1ce0d6faafac1b2bc0eb37c0e891..d76240bfe106c10ca9a775448f712311fc5e1443:/src/mac/carbon/tooltip.cpp diff --git a/src/mac/carbon/tooltip.cpp b/src/mac/carbon/tooltip.cpp index 64ea19f58c..2fbce9c667 100644 --- a/src/mac/carbon/tooltip.cpp +++ b/src/mac/carbon/tooltip.cpp @@ -190,7 +190,10 @@ void wxMacToolTip::Setup( WindowRef win , wxString text , wxPoint localPosition m_mark++ ; Clear() ; m_position = localPosition ; - m_label = wxMacMakeMacStringFromPC( text ) ; + if( wxApp::s_macDefaultEncodingIsPC ) + m_label = wxMacMakeMacStringFromPC( text ) ; + else + m_label = text ; m_window =win; s_ToolTipWindowRef = m_window ; m_backpict = NULL ; @@ -201,10 +204,12 @@ void wxMacToolTip::Setup( WindowRef win , wxString text , wxPoint localPosition 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 ; @@ -228,9 +233,9 @@ void wxMacToolTip::Draw() #endif { wxMacPortStateHelper help( (GrafPtr) GetWindowPort( m_window ) ); - +#if TARGET_CARBON bool useDrawThemeText = ( DrawThemeTextBox != (void*) kUnresolvedCFragSymbolAddress ) ; - +#endif m_shown = true ; FontFamilyID fontId ; @@ -280,27 +285,60 @@ void wxMacToolTip::Draw() 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(); - PenNormal() ; + ClosePicture(); + SetGWorld( origPort , origDevice ) ; + DisposeGWorld( port ) ; + PenNormal() ; RGBColor tooltipbackground = { 0xFFFF , 0xFFFF , 0xC000 } ; BackColor( whiteColor ) ; - RGBForeColor( &tooltipbackground ) ; + RGBForeColor( &tooltipbackground ) ; PaintRect( &m_rect ) ; ForeColor(blackColor ) ; @@ -316,6 +354,7 @@ void wxMacToolTip::Draw() { if( text[i] == 13 || text[i] == 10) { +#if TARGET_CARBON if ( useDrawThemeText ) { Rect frame ; @@ -335,6 +374,7 @@ void wxMacToolTip::Draw() height += lineh ; } else +#endif { ::DrawText( text , laststop , i - laststop ) ; height += lineh ; @@ -344,6 +384,7 @@ void wxMacToolTip::Draw() } i++ ; } +#if TARGET_CARBON if ( useDrawThemeText ) { Rect frame ; @@ -362,6 +403,7 @@ void wxMacToolTip::Draw() CFRelease( mString ) ; } else +#endif { ::DrawText( text , laststop , i - laststop ) ; }