wxPython实现带颜色的进度条


Posted in Python onNovember 19, 2019

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

【问题描述】

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

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

wxPython实现带颜色的进度条

图1-1 pygauge制作的进度条

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

wxPython实现带颜色的进度条

图1-2 期望效果图

【程序代码】

# --------------------------------------------------------------------------------- #
# GAUGE wxPython 
#
# Jin Jianchao, @ 25 Oct 2013
# Mail: jianchaojin@gmail.com
#
# 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(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 <0 or 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()

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
基于Python代码编辑器的选用(详解)
Sep 13 Python
Python判断两个对象相等的原理
Dec 12 Python
Atom的python插件和常用插件说明
Jul 08 Python
Python使用pyautogui模块实现自动化鼠标和键盘操作示例
Sep 04 Python
浅析Python函数式编程
Oct 06 Python
Python高级特性之闭包与装饰器实例详解
Nov 19 Python
python+OpenCV实现图像拼接
Mar 05 Python
Python如何将字符串转换为日期
Jul 31 Python
selenium+超级鹰实现模拟登录12306
Jan 24 Python
Python tkinter实现日期选择器
Feb 22 Python
python爬取企查查企业信息之selenium自动模拟登录企查查
Apr 08 Python
python cv2图像质量压缩的算法示例
Jun 04 Python
Python使用Pandas读写Excel实例解析
Nov 19 #Python
pycharm修改file type方式
Nov 19 #Python
wxPython实现列表增删改查功能
Nov 19 #Python
python ctypes库2_指定参数类型和返回类型详解
Nov 19 #Python
Python 使用type来定义类的实现
Nov 19 #Python
Pytorch中index_select() 函数的实现理解
Nov 19 #Python
wxPython多个窗口的基本结构
Nov 19 #Python
You might like
php仿discuz分页效果代码
2008/10/02 PHP
PHP版微信公众平台红包API
2015/04/02 PHP
分享php代码将360浏览器导出的favdb的sqlite数据库文件转换为html
2015/12/09 PHP
PHP面向对象程序设计之对象生成方法详解
2016/12/02 PHP
PHP学习记录之常用的魔术常量详解
2019/12/12 PHP
js中array的sort()方法使用介绍
2014/02/20 Javascript
JavaScript用Number方法实现string转int
2014/05/13 Javascript
jquery实现滑动特效代码
2015/08/10 Javascript
原生js页面滚动延迟加载图片
2015/12/20 Javascript
很棒的Bootstrap选项卡切换效果
2016/07/01 Javascript
JavaScript仿微博输入框效果(案例分析)
2016/12/06 Javascript
NodeJS处理Express中异步错误
2017/03/26 NodeJs
12个非常有用的JavaScript技巧
2017/05/17 Javascript
bootstrap模态框远程示例代码分享
2017/05/22 Javascript
Angular5中调用第三方js插件的方法
2018/02/26 Javascript
微信小程序onLaunch异步,首页onLoad先执行?
2018/09/20 Javascript
微信小程序扫描二维码获取信息实例详解
2019/05/07 Javascript
vue中使用mxgraph的方法实例代码详解
2019/05/17 Javascript
详解express使用vue-router的history踩坑
2019/06/05 Javascript
详解vue中多个有顺序要求的异步操作处理
2019/10/29 Javascript
Vue axios 将传递的json数据转为form data的例子
2019/10/29 Javascript
Python break语句详解
2014/03/11 Python
python实现多线程的两种方式
2016/05/22 Python
python中subprocess批量执行linux命令
2018/04/27 Python
Python实现的读写json文件功能示例
2018/06/05 Python
python 字符串只保留汉字的方法
2018/11/16 Python
Appium+Python自动化测试之运行App程序示例
2019/01/23 Python
多版本python的pip 升级后, pip2 pip3 与python版本失配解决方法
2019/09/11 Python
Python 图像对比度增强的几种方法(小结)
2019/09/25 Python
Python爬虫定时计划任务的几种常见方法(推荐)
2021/01/15 Python
文员个人求职自荐信
2013/09/21 职场文书
大一期末自我鉴定
2013/12/13 职场文书
教师个人考察材料
2014/12/16 职场文书
房地产销售主管岗位职责
2015/02/13 职场文书
领导干部学习三严三实心得体会
2016/01/05 职场文书
详解JavaScript中Arguments对象用途
2021/08/30 Javascript