• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

wxPython实现带颜色的进度条

python 搞代码 4年前 (2022-01-07) 25次浏览 已收录 0个评论

这篇文章主要介绍了wxPython实现带颜色的进度条,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了wxPython实现带颜色进度条的具体代码,供大家参考,具体内容如下

【问题描述】

1、在使用wxpython创建进度条时遇到如下问题,使用SetForegroundColour和SetBackgrounColour指令在Win7下不生效,即无法改变进度条的颜色及其背景颜色。

2、查阅资料发现wx.lib.agw.pygauge可以实现进度条颜色的修改(具体指令请参考pygauge说明文档),但其显示效果为平面较差(如下图):

图1-1 pygauge制作的进度条

期望实现的进度条效果如下:

图1-2 期望效果图

【程序代码】

 # --------------------------------------------------------------------------------- # # GAUGE wxPython # # Jin Jianchao, @ 25 Oct 2013 # Mail: [email protected] # # End Of Comments # --------------------------------------------------------------------------------- # """ Description =========== Draw color gauge with wxpython Usage ===== Usage example:: import wx import Gauge class MyFrame(wx.Frame): def __init__(self, parent): wx.Frame.__init__(self, parent, -1, "ColourGauge Demo") panel = wx.Panel(self) gauge1 = Gauge.ColourGauge(panel, -1, size=(100, 25)) gauge1.setPercent(0.8) gauge1.setBarColour(wx.RED) gauge1.setBackgroundColour(wx.WHITE) gauge2 = Gauge.ColourGauge(panel, -1, size=(200, 50)) gauge2.setPercent(0.9) gauge2.setBarColour(wx.RED) gauge2.setBackgroundColour(wx.BLUE) sizer = wx.BoxSizer(<strong style="color:transparent">来源gaodai#ma#com搞@@代~&码网</strong>wx.VERTICAL) sizer.Add(gauge1, 0, wx.ALIGN_CENTER_VERTICAL|wx.ALL, 20) sizer.Add(gauge2, 0, wx.ALIGN_CENTER_VERTICAL|wx.ALL, 20) panel.SetSizer(sizer) sizer.Layout() # our normal wxApp-derived class, as usual app = wx.App(0) frame = MyFrame(None) app.SetTopWindow(frame) frame.Show() app.MainLoop() """ import wx import wx.lib.fancytext as fancytext class ColourGauge(wx.Panel): def __init__(self, parent,id, pos=wx.DefaultPosition, size=wx.DefaultSize): wx.Panel.__init__(self, id=id, parent=parent, pos=pos, size=size, style=wx.TAB_TRAVERSAL) # creat Gauge self.gauge = Gauge(self, id=-1, size=size) self.SetAutoLayout(True) lc = wx.LayoutConstraints() lc.top.SameAs(self, wx.Top, 0) #AsIs() lc.left.AsIs() lc.height.AsIs() lc.right.SameAs(self, wx.Right, 0) self.gauge.SetConstraints(lc) def setPercent(self, percent): self.gauge.setPercent(percent) def setBackgroundColour(self, colour): self.gauge.SetBackgroundColour(colour) def setBarColour(self, colour): self.gauge.color = colour def getBarColour(self): return self.gauge.color def setStep(self,step): self.gauge.step=step def makeStep(self): if self.gauge.percent>=1.: return self.gauge.percent+=self.gauge.step if self.gauge.percent>1.: self.gauge.percent=1. self.Refresh() self.Update() class Gauge(wx.Control): default_color = "GREEN" # "MAGENTA","BLUE" # "GREEN" "RED" "YELLOW" def __init__(self, parent,id,pos=wx.DefaultPosition,size=wx.DefaultSize): wx.Control.__init__(self, parent, id, pos, size) self.SetBackgroundColour(wx.WHITE) self.color= Gauge.default_color self.percent = 0.0 self.step = 0.0 wx.EVT_PAINT(self, self.OnPaint) def OnPaint(self, evt): dc = wx.PaintDC(self) dc.Clear() dc.BeginDrawing() dc.SetPen( wx.Pen(self.color,0) ) dc.SetBrush( wx.Brush(self.color) ) w,h = self.GetSizeTuple() dc.DrawRectangleRect((0,0,w*self.percent,h)) percentStr= "%d%%"% int(self.percent*100) tx, ty = fancytext.getExtent(percentStr, dc) dc.DrawText(percentStr, w/2-tx/2, h/2-ty/2) dc.EndDrawing() def setPercent(self,percent): if percent 1.: return self.percent = percent def setColor(self,color): self.color = color def getColor(self): return self.color def setStep(self,step): self.step=step def makeStep(self): if self.percent>=1.: return self.percent+=self.step if self.percent>1.: self.percent=1. self.gauge.Refresh() self.gauge.Update()

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持gaodaima搞代码网

以上就是wxPython实现带颜色的进度条的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:wxPython实现带颜色的进度条

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址