Pmw大控件英文名Pmw Python megawidgets

官方参考文档:Pmw 1.3 Python megawidgets

一,如何使用Pmw大控件

下面以创建一个计数器(Counter)为例说明如何使用Pmw大控件

1.初始化

from tkinter import *
import Pmw root=Tk()
Pmw.initialise(root)

2.创建counter控件,并显示

counter1=Pmw.Counter()
counter1.pack(padx=10,pady=10)

3.使用方法

创建了大控件之后,就可以调用它的方法了。下面设置counter里的值,并使之增加

counter1.setentry(41)
counter1.increment()

4.选项

像tkinter控件一样,大控件也允许用户配置选项。选项配置允许大控件使用者指定大控件的外观和行为。counter大控件有一些可配置的选项,如,datetype,用于指定counter如何递增和递减,如按照integers,reals,times 或dates计数。默认为"numeric",表示要求输入整数并按整数递增或递减。

另一个选项是increment,指定递增或递减时一次递增或递减的单位。使用这些选项,你可以创建一个时间计数器,用HH:MM:SS的格式,以分钟minutes为计数单位,如:

counter2=Pmw.Counter(datatype="time",
increment=60) counter2.setentry("00:00:00")
counter2.pack(padx=10,pady=10)

很多大控件选项也可以使用configure()指定,如:

counter2.configure(increment = 60 * 10)

将每次递增设置为10分钟

5.初始化选项
某些选项只能在创建大控件的时候设置,而不能通过调用configure()方法,但是它们仍然可以使用通常的方法查询。如,counter控件包含一个orient的初始化选项,用于指定,箭头的方向是左右方向(horizontal),还是上下方向(vertical)

counter3=Pmw.Counter(orient="vertical")
counter3.pack()

6.查询方法

print(counter2.cget("increment"))
print(counter3.configure("orient"))

7.部件(components)

大控件由其他的部件组成,部件都有一个逻辑名,可以是一个tkinter控件,或本身也是一个大控件。Pmw提供用户直接访问部件的方法,使用component()方法

mega.component('comp').doit()(备注,作用不明)

~部件选项

有一种快速访问部件的方法,使用component_option,如下面的例子改变counter控件箭头的背景颜色,箭头部件的名字为向下箭头downarrow和向下箭头uparrow

counter3.configure(downarrow_background="green",
uparrow_background="red")

~hull

所有大控件都基于由Pmw基类直接创建的控件。一般的大控件是基于Tkinter Frame控件,而顶层窗口大控件,则基于Tkinter Toplevel控件。基控件可以通过hull部件访问。访问基控件可以使用hull_option,例如设置counter大控件的relief和边框宽度:

counter4=Pmw.Counter(hull_relief="sunken",
hull_borderwidth=5).pack()

~The interior

(略)

~子组件和别名,

组成大控件的组件自身也可能是一个大控件,那么访问组件的组件,可以使用component_sub-component方法,如counter大控件的里的entryfield本身是一个大控件,它基于名为entry的tkinter.Entry组件,所以你可以这样它的背景色

counter2.configure(entryfield_entry_background = 'yellow')

大部分组件路径名都有一个更短的别名,如entryfield_entry的是entry,所以这样做也是等效的:

counter2.configure(entry_background = 'yellow')

~改变组件的python类

每个大控件都是一些python类的实例,每个组件的默认类可以参考手册。在创建组件的时候,你可以使用pyclass选项指定它们继承的类,如:

counter5 = Pmw.Counter(
labelpos = 'w',
label_text = 'Hello',
label_pyclass =Button
).pack(padx=10,pady=10)

babel默认继承自Label,这里把它改成继承Button

二,如何创建Pmw大控件

介绍如果通过继承Pmw基类的方法创建Pmw大控件

1.选项组件

我们使用Tkinter.Scale(用于允许用户在一个范围内选择一个值)和Tkinter.Frame(用户,当用户选择的值超过范围的时候,显示一个指示)创建一个大控件,它的效果看上去是这样的:

使用这个控件的程序员,在改变scale的范围的时候,需要访问scale控件。因此,scale将是大控件的一个组件。程序员可能不需要访问指示灯的Frame,但是以防万一,需要修改指示灯的边框宽度和relief,我们也把它做成一个组件。这是关于组件的一个约定:为了最大的可配置性,把所有子控件当成组件(for maximum configurability, make all sub-widgets components.)

2.选项配置

除了组件本身具有的配置选项之外,大控件也需要一些属于自己的配置选项。在这里实例中,它要一个tkreshold选项设置阈值(tkreshold),它可能也需要一个选项去设置指示灯的颜色,在选择是数字高于或低于阈值的时候。其他的,如orient或者indicatorpos用来指定组件的相对位置,margin,padx或pady去指定部件的间隔。在这个例子里,我们定义了三个选项——threshold,colors和value。其中colors选项是2个元素的序列,用来指定两种颜色(低于阈值,超过阈值),value是scale初始化的值。

3.编写大控件

首先为新的大控件取个名字,决定它继承自那个基类,以及着手写它的构造函数。大部分Pmw大控件来源于Pmw.MegaWidget,Pmw.MegaToplevel或者Pmw.Dialog,在这里我们继承Pmw.MegaWidget。大控件的构造函数有一个参数(大控件的hull的父控件,默认为root窗口),和任意数量的关键词参数。

from tkinter import *

class ThresholdScale(Pmw.MegaWidget):
"""Megawidget containing a scale and a indicator.
"""
def __init__(self,parent=None,**kw):

接下来,我们需要定义大控件支持的选项,每个选项由一个3元素的序列指定。第一个元素是选项的名字,第二个元素是默认的值,第三个元素是一个回调函数,Pmw.INITOPT,或None。首先,函数在构造函数的结束时(在调用self.inialiseoptions期间),或调用configure设置选项时被调用。其次,Pmw.INITOPT表示该选项是一个初始化选项——它可以通过调用configure来设置。None表示选项能被configure设置,但是没有回调函数。

self.defineoptions也包含传递给构造函数的参数。当指定选项的值时,会覆盖默认的值。

        #Define the megawidget options.
optiondefs=(
("color",("green","red"),None),
("threshold",50,None),
("value",None,Pmw.INITOPT))
self.defineoptions(kw,optiondefs)

下一步,调用基类构造函数

    Pmw.MegaWiget.__init__(self,parent)

接下来创建组件,子控件被创建为大控件内部的子元素或子元素下的子元素。

    #Create the indicator component.
interior=self.interior()

第一个创建的组件是指示灯,用createcomponent方法创建子控件并且将控件注册为大控件的组件。它带五个参数加上任意数量的关键词参数。这些参数是名字(name),别名(aliases),组(group),类(class)和构造函数参数。查看Pmw.MegaArchetype reference manual获得所有细节。

    self.indicator=self.createcomponent("indicator",
(),None,
Frame,(interior,),
width=16,
height=16,
borderwidth=2,
relief="raised")
self.indicator.grid()

创建scale的方法也类似,在这里,scale的value设置为选项初始化value一样的值

    self.scale=self.createcomponent("scale",
(),None,
Scale,(interior,),
command=self.doCommand,
tickinterval=20,
length=200,
from_=100,
to=0,
showvalue=0)
self.scale.grid()

构造函数最后,调用initialiseoptions方法检查所有关键词参数被使用,并调用选项里的回调函数

    #Check keywords and initialise options.
self.initialiseoptions()

所有其他的方法必须现在定义,在本例中,只需要一个方法

    def _doCommand(self, valueStr):
if self.scale.get() > self['threshold']:
color = self['colors'][1]
else:
color = self['colors'][0]
self.indicator.configure(background = color)

完成大控件,来自其他类的方法可以被复制进该类

    Pmw.forwardmethods(ThresholdScale, Tkinter.Scale, 'scale')

例子完成代码

import tkinter
import Pmw class ThresholdScale(Pmw.MegaWidget):
""" Megawidget containing a scale and an indicator.
""" def __init__(self, parent=None, **kw): # Define the megawidget options.
optiondefs = (
('colors', ('green', 'red'), None),
('threshold', 50, None),
('value', None, Pmw.INITOPT),
)
self.defineoptions(kw, optiondefs) # Initialise base class (after defining options).
Pmw.MegaWidget.__init__(self, parent) # Create the components.
interior = self.interior() # Create the indicator component.
self.indicator = self.createcomponent('indicator',
(), None,
tkinter.Frame, interior,
width=16,
height=16,
borderwidth=2,
relief='raised')
self.indicator.grid() # Create the scale component.
self.scale = self.createcomponent('scale',
(), None,
tkinter.Scale, interior,
command=self._doCommand,
tickinterval=20,
length=200,
from_=100,
to=0,
showvalue=0)
self.scale.grid() value = self['value']
if value is not None:
self.scale.set(value) # Check keywords and initialise options.
self.initialiseoptions() def _doCommand(self, valueStr):
if self.scale.get() > self['threshold']:
color = self['colors'][1]
else:
color = self['colors'][0]
self.indicator.configure(background=color) Pmw.forwardmethods(ThresholdScale, tkinter.Scale, 'scale') # Initialise Tkinter and Pmw.
root = Pmw.initialise()
root.title('Pmw ThresholdScale demonstration') # Create and pack two ThresholdScale megawidgets.
mega1 = ThresholdScale()
mega1.pack(side='left', padx=10, pady=10) mega2 = ThresholdScale(
colors=('green', 'yellow'),
threshold=75,
value=80,
indicator_width=32,
scale_width=25)
mega2.pack(side='left', padx=10, pady=10) # Let's go.
root.mainloop()

>>

Pmw大控件(二)的更多相关文章

  1. Pmw大控件

    Python大控件——Pmw——是合成的控件,以Tkinter控件为基类,是完全在Python内写的.它们可以很方便地增加功能性的应用,而不必写一堆代码.特别是,组合框和内部确认计划的输入字段放在一起 ...

  2. Windows高DPI系列控件(二) - 柱状图

    目录 一.QCP 二.效果展示 三.高DPI适配 1.自定义柱状图 2.新的柱状图 3.测试代码 四.相关文章 原文链接:Windows高DPI系列控件(二) - 柱状图 一.QCP QCP全称QCu ...

  3. QRowTable表格控件(二)-红涨绿跌

    目录 一.开心一刻 二.概述 三.效果展示 四.任务需求 五.指定列排序 六.排序 七.列对其方式 八.相关文章 原文链接:QRowTable表格控件(二)-红涨绿跌 一.开心一刻 一天,五娃和六娃去 ...

  4. QT 常用控件二

    QT提供QHBoxLayout类.QVBoxlayout类及QGridLayout类等的基本布局管理,分别是水平排列布局,垂直排列布局和网格排列布局 addWidget()方法用于向布局中加入需要布局 ...

  5. Rich控件二

    Calendar控件  使用案例: 在Default.aspx中: <div> <h1>Calendar控件</h1> <asp:Calendar ID=&q ...

  6. jquery 分页控件(二)

    上一章主要是关于分页控件的原理,代码也没有重构.在这一章会附上小插件的下载链接,插件主要就是重构逻辑部分,具体可以下载源文件看下,源代码也有注释.为了测试这个插件是能用的,我弄了个简单的asp.net ...

  7. WPF 自定义分页控件二

    一:添加自定义分页控件,命名为KDataPagerTwo: public class KDataPagerTwo : Control, INotifyPropertyChanged { static ...

  8. android菜鸟学习笔记13----Android控件(二) 自定义控件简单示例

    有时候,可能觉得系统提供的控件太丑,就会需要自定义控件来实现自己想要的效果. 以下主要参考<第一行代码> 1.自定义一个标题栏: 系统自带的标题栏很丑,且没什么大的作用,所以我们之前会在o ...

  9. ExtJS基础知识总结:自定义日历和ComboBox控件(二)

    概述 1.ExtJS 5不支持日期选择框中只选择年月,为了满足ExtJs5可以实现选择年月的功能,查询网上资料,整理出来了相应的处理方式,最终实现的效果如下图: 2.ExtJS 控件丰富,如果需要实现 ...

随机推荐

  1. 吴裕雄--天生自然java开发常用类库学习笔记:多线程基础编程

    class MyThread implements Runnable{ // 实现Runnable接口,作为线程的实现类 private String name ; // 表示线程的名称 public ...

  2. LeetCode实战练习题目 - Array

    实战练习题目 - Array 盛最多水的容器 class Solution { public: int maxArea(vector<int>& height) { int res ...

  3. msf自动连接postgresql配置

    今天做了一下msf连接数据库的配置,中间碰到了一些坑点这里就不详细叙述了,开始正确的操作方式. 首先对postgresql进行配置以方便连接. root@kali:~# service postgre ...

  4. --转载 详细介绍java中的数据结构

    http://developer.51cto.com/art/201107/273003.htm 也许你已经熟练使用了java.util包里面的各种数据结构,但是我还是要说一说java版数据结构与算法 ...

  5. WTL之手动编写框架窗口

    新版博客已经搭建好了,有问题请访问 htt://www.crazydebug.com 本人是一个实践主义者,不罗嗦上一篇工程搭建好以后,这一篇就开始写代码,写之前再说几句,如果你熟悉MFC分析过MFC ...

  6. mongodb单机版的安装和配置

    首先根据操作系统下载MongoDB的相关安装文件 下载后上传到linux上,解压 将解压后的文件夹重新命名为monggodb4.0.1 命令mv 配置必要的文件夹mgdata存放运行数据,mglog存 ...

  7. 官网英文版学习——RabbitMQ学习笔记(十)RabbitMQ集群

    在第二节我们进行了RabbitMQ的安装,现在我们就RabbitMQ进行集群的搭建进行学习,参考官网地址是:http://www.rabbitmq.com/clustering.html 首先我们来看 ...

  8. 利用vim查看日志,快速定位问题《转载》

    利用vim查看日志,快速定位问题 链接:https://www.cnblogs.com/abcwt112/p/5192944.html

  9. mitmproxy(TLS错误)

    一.原来的基础上添加代码 """ This inline script allows conditional TLS Interception based on a us ...

  10. vue-cli 官方脚手架 eslink配置 恢复serve状态下的打印

    使用官方脚手架 打印会提示保存,主要是eslink的配置(在package.json文件夹里面修改) 配置说明 下面是抄的 "eslintConfig": { "root ...