探索flutter框架开发的app在移动应用市场的潜力与挑战
736
2022-10-12
Tkinter编程应知应会(26)-通过OptionDB控制控件属性
到前一篇文章为止,我们基本上对Tkinter中的每一种基本控件都进行了简单的说明。在这些的示例代码中,用户可以通过属性控制每个控件的前景色,背景色,字体等各种属性。这种方式的直观易懂,但是存在几个缺点:
1.即使希望同样的设定,也需要每个控件单独制定。
2.设定信息淹没在代码中,无论是增减还是调整属性都需要修改代码。麻烦不说还有可能破坏代码的完整性。
第一个问题,Tkinter提供了option_add方法用户根据分类分类制定控件属性的方式,例如对于表示计算结果和表达式的两个标签控件来讲,可以使用下面的代码指定它们的背景色:
root.option_add('*Label.background', "#a0ffa0")
代码中‘*Label.background’的含义就是所有Label控件的背景色。
如果需要对每个控件进行单独控制,首先要为控件指定名称。下面的代码通过name属性分别为两个标签控件指定了各自的名称。
# create a label to change state.upper_display = Label(root, name='upperDisplay', foreground="#000000", width=24, anchor=E)upper_display.grid(row=1, column=0, columnspan=4, sticky=E + W)# create a label to change state.lower_display = Label(root, name='lowerDisplay', foreground="#000000", width=12, anchor=E)lower_display.grid(row=2, column=0, columnspan=4, sticky=E + W)
名称指定完成之后就可以使用名称为特定的控件指定属性了。为了和分类指定想区别,控件的名称必须小写。
ftTimes1 = Font(family='Times', size=12, weight=BOLD)ftTimes2 = Font(family='Times', size=24, weight=BOLD)root.option_add('*upperDisplay.font', ftTimes1)root.option_add('*lowerDisplay.font', ftTimes2)root.option_add('*Button*font', ftTimes1)
除了两个标签之外,代码还顺便为所有的按钮指定了字体,其结果如下:
通过上面的例子可以看到,通过使用OptionDB,只要使用很少的代码,就可以实现同时为多个控件指定属性的功能。除此之外,Tkinter还提供了通过配置文件修改控件属性的功能。下面的代码就是指定计算器中每个控件的字体和颜色的实例。
*Label.background:#a0ffa0*upperDisplay.font:times 12 bold*lowerDisplay.font:times 24 bold*Button*font: Meiryo 12 bold*Button*foreground:#007700*ckey*foreground:#ff0000*cekey*foreground:#ff0000*back*foreground:#ff0000*devkey*foreground:#0000ff*mulkey*foreground:#0000ff*minukey*foreground:#0000ff*pluskey*foreground:#0000ff*equalkey*foreground:#000000
配置文件完成之后,取一个适当的名字保存即可。本例中使用26 OpDb.txt。
最后一步就是在代码中增加下面一行以读入配置文件:
root.option_readfile('26 OpDb.txt')
程序执行结果如下:
总结如下:
1.为各个控件指定name属性
2.代码中忽略可能变化的属性
3.通过OptionDB为控件类或单个控件指定属性
完整代码可以从以下地址-:
https://github.com/xueweiguo/TkinterPrimer/blob/master/Sample/26%20OptionDatabase.py
https://github.com/xueweiguo/TkinterPrimer/blob/master/Sample/26%20OpDb.txt
觉得本文有帮助?请分享给更多人。
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~