wxSize wxStaticBox::DoGetBestSize() const
{
+ wxSize best;
+
+ // Calculate the size needed by the label
int cx, cy;
wxGetCharSize(GetHWND(), &cx, &cy, GetFont());
wBox += 3*cx;
int hBox = EDIT_HEIGHT_FROM_CHAR_HEIGHT(cy);
- wxSize best(wBox, hBox);
- CacheBestSize(best);
+ // If there is a sizer then the base best size is the sizer's minimum
+ if (GetSizer() != NULL)
+ {
+ wxSize cm(GetSizer()->CalcMin());
+ best = ClientToWindowSize(cm);
+ // adjust for a long label if needed
+ best.x = wxMax(best.x, wBox);
+ }
+ // otherwise the best size falls back to the label size
+ else
+ {
+ best = wxSize(wBox, hBox);
+ }
return best;
}
if ( !rtl )
{
RECT rc2 = { x, 0, x + width, y };
- ::DrawText(hdc, label.wx_str(), label.length(), &rc2,
+ ::DrawText(hdc, label.t_str(), label.length(), &rc2,
drawTextFlags);
}
else // RTL
{
RECT rc2 = { x, 0, x - width, y };
- ::DrawText(hdc, label.wx_str(), label.length(), &rc2,
+ ::DrawText(hdc, label.t_str(), label.length(), &rc2,
drawTextFlags | DT_RTLREADING);
}
}
#endif // !__WXWINCE__
+
+wxPoint wxStaticBox::GetClientAreaOrigin() const
+{
+ // See: http://msdn.microsoft.com/en-us/library/aa511279.aspx
+ wxPoint pt = ConvertDialogToPixels(wxPoint(6,11));
+ return pt;
+}
+
+
+void wxStaticBox::DoGetClientSize(int *width, int *height) const
+{
+ // See: http://msdn.microsoft.com/en-us/library/aa511279.aspx
+ wxPoint lr = ConvertDialogToPixels(wxPoint(6,7));
+ wxPoint ul = GetClientAreaOrigin();
+ wxSize sz = GetSize();
+
+ if (width)
+ *width = sz.x - ul.x - lr.x;
+ if (height)
+ *height = sz.y - ul.y - lr.x;
+}
+
#endif // wxUSE_STATBOX