streamline best size calculation for buttons and made wxBU_EXACTFIT work as intended
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@61167 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
parent
d46a35d092
commit
1fe0e46ec4
@ -14,13 +14,8 @@
|
|||||||
#include "wx/button.h"
|
#include "wx/button.h"
|
||||||
|
|
||||||
#ifndef WX_PRECOMP
|
#ifndef WX_PRECOMP
|
||||||
#include "wx/panel.h"
|
|
||||||
#include "wx/toplevel.h"
|
|
||||||
#include "wx/dcclient.h"
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "wx/stockitem.h"
|
|
||||||
|
|
||||||
#include "wx/osx/private.h"
|
#include "wx/osx/private.h"
|
||||||
|
|
||||||
wxSize wxButton::DoGetBestSize() const
|
wxSize wxButton::DoGetBestSize() const
|
||||||
@ -28,97 +23,22 @@ wxSize wxButton::DoGetBestSize() const
|
|||||||
if ( GetId() == wxID_HELP )
|
if ( GetId() == wxID_HELP )
|
||||||
return wxSize( 23 , 23 ) ;
|
return wxSize( 23 , 23 ) ;
|
||||||
|
|
||||||
wxSize sz = GetDefaultSize() ;
|
|
||||||
|
|
||||||
switch (GetWindowVariant())
|
|
||||||
{
|
|
||||||
case wxWINDOW_VARIANT_NORMAL:
|
|
||||||
case wxWINDOW_VARIANT_LARGE:
|
|
||||||
sz.y = 23 ;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case wxWINDOW_VARIANT_SMALL:
|
|
||||||
sz.y = 17 ;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case wxWINDOW_VARIANT_MINI:
|
|
||||||
sz.y = 15 ;
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
wxRect r ;
|
wxRect r ;
|
||||||
|
|
||||||
m_peer->GetBestRect(&r);
|
m_peer->GetBestRect(&r);
|
||||||
|
|
||||||
if ( r.GetWidth() == 0 && r.GetHeight() == 0 )
|
wxSize sz = r.GetSize();
|
||||||
{
|
|
||||||
}
|
|
||||||
sz.x = r.GetWidth();
|
|
||||||
sz.y = r.GetHeight();
|
|
||||||
|
|
||||||
int wBtn = 96;
|
const int wBtnStd = GetDefaultSize().x;
|
||||||
|
|
||||||
if ((wBtn > sz.x) || ( GetWindowStyle() & wxBU_EXACTFIT))
|
if ( (sz.x < wBtnStd) && !HasFlag(wxBU_EXACTFIT) )
|
||||||
sz.x = wBtn;
|
sz.x = wBtnStd;
|
||||||
|
|
||||||
#if wxOSX_USE_CARBON
|
|
||||||
Rect bestsize = { 0 , 0 , 0 , 0 } ;
|
|
||||||
m_peer->GetBestRect( &bestsize ) ;
|
|
||||||
|
|
||||||
int wBtn;
|
|
||||||
if ( EmptyRect( &bestsize ) || ( GetWindowStyle() & wxBU_EXACTFIT) )
|
|
||||||
{
|
|
||||||
Point bounds;
|
|
||||||
|
|
||||||
ControlFontStyleRec controlFont;
|
|
||||||
OSStatus err = m_peer->GetData<ControlFontStyleRec>( kControlEntireControl, kControlFontStyleTag, &controlFont );
|
|
||||||
verify_noerr( err );
|
|
||||||
|
|
||||||
wxCFStringRef str( m_label, GetFont().GetEncoding() );
|
|
||||||
|
|
||||||
#if wxOSX_USE_ATSU_TEXT
|
|
||||||
SInt16 baseline;
|
|
||||||
if ( m_font.MacGetThemeFontID() != kThemeCurrentPortFont )
|
|
||||||
{
|
|
||||||
err = GetThemeTextDimensions(
|
|
||||||
(!m_label.empty() ? (CFStringRef)str : CFSTR(" ")),
|
|
||||||
m_font.MacGetThemeFontID(), kThemeStateActive, false, &bounds, &baseline );
|
|
||||||
verify_noerr( err );
|
|
||||||
}
|
|
||||||
else
|
|
||||||
#endif
|
|
||||||
{
|
|
||||||
wxClientDC dc(const_cast<wxButton*>(this));
|
|
||||||
wxCoord width, height ;
|
|
||||||
dc.GetTextExtent( m_label , &width, &height);
|
|
||||||
bounds.h = width;
|
|
||||||
bounds.v = height;
|
|
||||||
}
|
|
||||||
|
|
||||||
wBtn = bounds.h + sz.y;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
wBtn = bestsize.right - bestsize.left ;
|
|
||||||
// non 'normal' window variants don't return the correct height
|
|
||||||
// sz.y = bestsize.bottom - bestsize.top ;
|
|
||||||
}
|
|
||||||
if ((wBtn > sz.x) || ( GetWindowStyle() & wxBU_EXACTFIT))
|
|
||||||
sz.x = wBtn;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
return sz ;
|
return sz ;
|
||||||
}
|
}
|
||||||
|
|
||||||
wxSize wxButton::GetDefaultSize()
|
wxSize wxButton::GetDefaultSize()
|
||||||
{
|
{
|
||||||
int wBtn = 70 ;
|
return wxSize(84, 23);
|
||||||
int hBtn = 20 ;
|
|
||||||
|
|
||||||
return wxSize(wBtn, hBtn);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@implementation wxNSButton
|
@implementation wxNSButton
|
||||||
|
Loading…
Reference in New Issue
Block a user