X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/b881fc787d2823bdd8a415080b82feee90804a17..41d1d7e34bfa5ebd0bfcdb7fb6df0243663a85a4:/wxPython/wx/lib/stattext.py?ds=sidebyside diff --git a/wxPython/wx/lib/stattext.py b/wxPython/wx/lib/stattext.py index 5a87aa9e03..ac50f76e73 100644 --- a/wxPython/wx/lib/stattext.py +++ b/wxPython/wx/lib/stattext.py @@ -32,27 +32,9 @@ class GenStaticText(wx.PyControl): wx.DefaultValidator, name) wx.PyControl.SetLabel(self, label) # don't check wx.ST_NO_AUTORESIZE yet - self.SetPosition(pos) - font = parent.GetFont() - if not font.Ok(): - font = wx.SystemSettings.GetSystemFont(wx.SYS_DEFAULT_GUI_FONT) - wx.PyControl.SetFont(self, font) # same here - - self.defBackClr = parent.GetBackgroundColour() - if not self.defBackClr.Ok(): - self.defBackClr = wx.SystemSettings.GetSystemColour(wx.SYS_COLOUR_3DFACE) - self.SetBackgroundColour(self.defBackClr) - - clr = parent.GetForegroundColour() - if not clr.Ok(): - clr = wx.SystemSettings_GetSystemColour(wx.SYS_COLOUR_BTNTEXT) - self.SetForegroundColour(clr) - - rw, rh = size - bw, bh = self.GetBestSize() - if rw == -1: rw = bw - if rh == -1: rh = bh - self.SetSize(wx.Size(rw, rh)) + self.defBackClr = self.GetBackgroundColour() + self.InheritAttributes() + self.SetBestFittingSize(size) self.Bind(wx.EVT_ERASE_BACKGROUND, self.OnEraseBackground) self.Bind(wx.EVT_PAINT, self.OnPaint) @@ -66,7 +48,9 @@ class GenStaticText(wx.PyControl): wx.PyControl.SetLabel(self, label) style = self.GetWindowStyleFlag() if not style & wx.ST_NO_AUTORESIZE: - self.SetSize(self.GetBestSize()) + best = self.GetBestSize() + self.SetSize(best) + self.SetMinSize(best) self.Refresh() @@ -78,13 +62,17 @@ class GenStaticText(wx.PyControl): wx.PyControl.SetFont(self, font) style = self.GetWindowStyleFlag() if not style & wx.ST_NO_AUTORESIZE: - self.SetSize(self.GetBestSize()) + best = self.GetBestSize() + self.SetSize(best) + self.SetMinSize(best) self.Refresh() def DoGetBestSize(self): - """Overridden base class virtual. Determines the best size of the - button based on the label size.""" + """ + Overridden base class virtual. Determines the best size of + the button based on the label size. + """ label = self.GetLabel() maxWidth = totalHeight = 0 for line in label.split('\n'): @@ -102,6 +90,22 @@ class GenStaticText(wx.PyControl): return False + def GetDefaultAttributes(self): + """ + Overridden base class virtual. By default we should use + the same font/colour attributes as the native StaticText. + """ + return wx.StaticText.GetClassDefaultAttributes() + + + def ShouldInheritColours(self): + """ + Overridden base class virtual. If the parent has non-default + colours then we want this control to inherit them. + """ + return True + + def OnPaint(self, event): dc = wx.BufferedPaintDC(self) #dc = wx.PaintDC(self) @@ -113,7 +117,7 @@ class GenStaticText(wx.PyControl): backBrush = wx.Brush(clr, wx.SOLID) if wx.Platform == "__WXMAC__" and clr == self.defBackClr: # if colour is still the default then use the striped background on Mac - backBrush.SetMacTheme(1) # 1 == kThemeBrushDialogBackgroundActive + backBrush.MacSetTheme(1) # 1 == kThemeBrushDialogBackgroundActive dc.SetBackground(backBrush) dc.SetTextForeground(self.GetForegroundColour()) @@ -131,7 +135,7 @@ class GenStaticText(wx.PyControl): x = width - w if style & wx.ALIGN_CENTER: x = (width - w)/2 - dc.DrawText(line, (x, y)) + dc.DrawText(line, x, y) y += h