实战wxPython系列-045
本文介绍几个扩展按钮,它们不数属于wxPython核心库中的控件,但是它们可以提供一些特殊的效果。
一、PlateButton
PlateButton是一个通用按钮控件,它是一个自定义的平面按钮。它在许多方面模拟Safari浏览器书签栏中的按钮。可以使用它来替换wx.Button或者wx.BitmapButton。它还提供了一些选项来定义其外观。
PlateButton支持的窗口样式:
下面的例子展示了如何创建一个PlateButton。例子显示了几种不同样式的PlateButton按钮。并演示了如何给PlateButton添加一个菜单。
#wx.lib.platebutton PlateButton
import wx
import wx.lib.platebtn as platebtn
class SamplePlateButton(wx.Frame):
def __init__(self, *args, **kw):
super(SamplePlateButton, self).__init__(*args, **kw)
self.InitUi()
def InitUi(self):
self.SetTitle("实战wxPython: PlateButton演示")
self.SetSize(400, 240)
panel = wx.Panel(self)
girdSizer = wx.GridBagSizer(2, 3)
#按钮三种不同背景
btnDefault = platebtn.PlateButton(panel, label="Default", style = platebtn.PB_STYLE_DEFAULT)
btnGradient = platebtn.PlateButton(panel, label="Graddient", style = platebtn.PB_STYLE_GRADIENT)
btnSquare = platebtn.PlateButton(panel, label="Square", style = platebtn.PB_STYLE_SQUARE)
#菜单支持
menu = wx.Menu()
for url in ["https://www.baidu.com", "https://cn.bing.com/", "https://sogou.com/"]:
menu.Append(wx.NewId(), url, "在浏览器里打开 %s" % url)
btnMenu = platebtn.PlateButton(panel, label="Menu", style = platebtn.PB_STYLE_DEFAULT)
btnMenu.SetMenu(menu)
girdSizer.Add(btnDefault, flag = wx.EXPAND, pos = (0, 0))
girdSizer.Add(btnGradient, flag = wx.EXPAND, pos = (0, 1))
girdSizer.Add(btnSquare, flag = wx.EXPAND, pos = (0, 2))
girdSizer.Add(btnMenu, flag = wx.EXPAND, pos = (1, 0))
panel.SetSizer(girdSizer);
self.Centre()
def main():
app = wx.App()
sample = SamplePlateButton(None)
sample.Show()
app.MainLoop()
if __name__ == "__main__":
main()
二、AquaButton
AquaButton及之后介绍的两个按钮都来自wxPython的高级通用控件(Advanced Generic Widgets, AGW)库。
AquaButton是一个自定义绘制的按钮控件,它近似地模仿了Mac上Aqua按钮的行为。它支持以下效果:
下面的代码演示如何使用AquaButton。
#wx.lib.agw.aquabutton.AquaButton
import wx
import wx.lib.agw.aquabutton as ab
class SampleAquaButton(wx.Frame):
def __init__(self, *args, **kw):
super(SampleAquaButton, self).__init__(*args, **kw)
self.InitUi()
def InitUi(self):
self.SetTitle("实战wxPython: AquaButton演示")
self.SetSize(400, 240)
panel = wx.Panel(self)
bmp = wx.Bitmap("agt_mp3.png", wx.BITMAP_TYPE_ANY)
btn1 = ab.AquaButton(panel, bitmap=bmp, label="Click me")
btn1.SetForegroundColour("black")
btn1.Bind(wx.EVT_BUTTON, self.OnButtonClickMe)
btn2 = ab.AquaButton(panel, label="PulseOnFocus")
btn2.SetForegroundColour("black")
btn2.SetPulseOnFocus(True)
vbox = wx.BoxSizer(wx.VERTICAL)
vbox.Add(btn1, 0, wx.CENTER|wx.ALL, 5)
vbox.Add(btn2, 0, wx.CENTER|wx.ALL, 5)
panel.SetSizer(vbox)
self.Centre()
def OnButtonClickMe(self, e):
msg = "点击了按钮"
dlg = wx.MessageDialog(None, msg, "消息", wx.OK|wx.ICON_EXCLAMATION)
dlg.ShowModal()
dlg.Destroy()
def main():
app = wx.App()
sample = SampleAquaButton(None)
sample.Show()
app.MainLoop()
if __name__ == "__main__":
main()
AquaButton支持位图,因此在上面的例子中我们展示了两个按钮,其中一个带有位图,另一个没有。AquaButton另一个功能是当它具有焦点时,它具有脉冲效果,第二个按钮打开了这个效果。
三、GradientButton
GradientButton是另一个自定义绘制的按钮类。类似于AquaButton,它们都有圆角,可以有一个可选的位图。GradientButton允许设置从上到下的渐变,以及按下时的顶部/底部颜色。GradientButton支持:
下面的代码演示如何使用GradientButton。
#wx.lib.agw.gradientbutton.GradientButton
import wx
import wx.lib.agw.gradientbutton as gb
class SampleGradientButton(wx.Frame):
def __init__(self, *args, **kw):
super(SampleGradientButton, self).__init__(*args, **kw)
self.InitUi()
def InitUi(self):
self.SetTitle("实战wxPython: GradientButton演示")
self.SetSize(400, 240)
panel = wx.Panel(self)
bmp = wx.Bitmap("agt_mp3.png", wx.BITMAP_TYPE_ANY)
gbBtn1 = gb.GradientButton(panel, bitmap=bmp, label="Gradient with bitmap")
gbBtn2 = gb.GradientButton(panel, label="Press Me")
gbBtn2.Bind(wx.EVT_BUTTON, self.OnPressMe)
vbox = wx.BoxSizer(wx.VERTICAL)
vbox.Add(gbBtn1, 0, wx.CENTER|wx.ALL, 5)
vbox.Add(gbBtn2, 0, wx.CENTER|wx.ALL, 5)
panel.SetSizer(vbox)
self.Centre()
def OnPressMe(self, e):
msg = "OK!"
dlg = wx.MessageDialog(None, msg, "消息", wx.OK|wx.ICON_EXCLAMATION)
dlg.ShowModal()
dlg.Destroy()
def main():
app = wx.App()
sample = SampleGradientButton(None)
sample.Show()
app.MainLoop()
if __name__ == "__main__":
main()
类似AquaButton, 我们展示了两个按钮,其中一个带有位图,另一个没有。
四、ShapedButton
ShapedButton试图填补wxPython中“自定义形状”控件的不足(这取决于wxWidgets中同样的不足)。可用于制作圆形按钮或椭圆按钮。
ShapedButton可能是功能最齐全的按钮。你可以创建一个普通按钮,一个位图按钮,一个奇怪的偏移位图+文本按钮,切换按钮,也可以旋转文本到任何角度显示。
尽管ShapedButton是构建在矩形窗口上,但是只有当鼠标事件发生在圆圈/椭圆内时,ShapedButton才会对鼠标事件做出反应。
使用ShapedButton我们可以:
下面的代码演示了如何使用ShapedButton。
#wx.lib.agw.shapedbutton.ShapedButton
import wx
import wx.lib.agw.shapedbutton as sb
class SampleShapedButton(wx.Frame):
def __init__(self, *args, **kw):
super(SampleShapedButton, self).__init__(*args, **kw)
self.InitUi()
def InitUi(self):
self.SetTitle("实战wxPython: ShapedButton演示")
self.SetSize(400, 240)
panel = wx.Panel(self)
bmp = wx.Bitmap("agt_mp3.png", wx.BITMAP_TYPE_ANY)
sBtn = sb.SButton(panel, label="Press Me", size = (75, 75))
sBtn.Bind(wx.EVT_BUTTON, self.OnShapedButton)
bmpBtn = sb.SBitmapButton(panel, wx.ID_ANY, bitmap=bmp)
bmpBtn.Bind(wx.EVT_BUTTON, self.OnBmpShapedButton)
bmpToggleBtn = sb.SBitmapToggleButton(panel, wx.ID_ANY, bitmap=bmp)
bmpToggleBtn.Bind(wx.EVT_BUTTON, self.OnToggle)
bmpToggleTxtBtn = sb.SBitmapTextToggleButton(panel, wx.ID_ANY, bitmap=bmp, label="Toggle", size=(100, 100))
rotatedTxtBtn = sb.SButton(panel, label="Rotated!", size = (75, 75))
rotatedTxtBtn.SetAngleOfRotation(90)
hbox = wx.BoxSizer(wx.HORIZONTAL)
hbox.Add(sBtn, 0, wx.ALL, wx.CENTER, 5)
hbox.Add(bmpBtn, 0, wx.ALL, wx.CENTER, 5)
hbox.Add(bmpToggleBtn, 0, wx.ALL, wx.CENTER, 5)
hbox.Add(bmpToggleTxtBtn, 0, wx.ALL, wx.CENTER, 5)
hbox.Add(rotatedTxtBtn, 0, wx.ALL, wx.CENTER, 5)
panel.SetSizer(hbox)
self.Centre()
def OnShapedButton(self, e):
self.ShowDialog("你点击了常规的ShapedButton")
def OnBmpShapedButton(self, e):
dlg = wx.ColourDialog(self)
data = dlg.GetColourData()
data.SetChooseFull(True)
if dlg.ShowModal() == wx.ID_OK:
print(" '你选择了:%s
" % str(data.GetColour().Get()))
dlg.Destroy()
def OnToggle(self, e):
if e.GetIsDown():
wx.CallAfter(self.ShowDialog, "You Toggled Me!")
else:
wx.CallAfter(self.ShowDialog, "You untoggled me!")
e.Skip()
def ShowDialog(self, msg):
""" 显示一个自定义消息 """
dlg = wx.MessageDialog(None, msg, "消息", wx.OK|wx.ICON_EXCLAMATION)
dlg.ShowModal()
dlg.Destroy()
def main():
app = wx.App()
sample = SampleShapedButton(None)
sample.Show()
app.MainLoop()
if __name__ == "__main__":
main()
在上面的代码中,演示了如何创建一个普通的ShapedButton,一对切换按钮和一个带有一些旋转90度的文本的按钮。
五、本文知识点
前一篇:wxPython - 高级控件之HtmlWindow
欢迎关注,评论,收藏,点赞,和转发。
页面更新:2024-05-13
本站资料均由网友自行发布提供,仅用于学习交流。如有版权问题,请与我联系,QQ:4156828
© CopyRight 2020-2024 All Rights Reserved. Powered By 71396.com 闽ICP备11008920号-4
闽公网安备35020302034903号