The Tkinter Scale Widget
Scale(刻度)组件看起来像是一个带数据的 Scrollbar(滚动条)组件,但事实上它们是不同的两个东东。Scale 组件允许用于通过滑动滑块来选择一个范围内的数字。你可以控制该组件的最大值、最小值,以及分辨率。
何时使用 Scale 组件?
当你希望用户输入某个范围内的一个数值,使用 Scale 组件可以很好的代替 Entry 组件。
用法
创建一个指定范围的 Scale 组件其实非常容易,你只需要指定它的 from 和 to 两个选项即可。但由于 from 本身是 Python 的关键字,所以为了区分需要在后边紧跟一个下划线:from_
1. from tkinter import *
2.
3. root = Tk()
4.
5. Scale(root, from_=0, to=42).pack()
6. Scale(root, from_=0, to=200,orient=HORIZONTAL).pack()
7.
8. mainloop()
使用 get() 方法可以获取当前滑块的位置:
1. from tkinter import *
2.
3. root = Tk()
4.
5. s1 = Scale(root, from_=0, to=42)
6. s1.pack()
7.
8. s2 = Scale(root, from_=0, to=200,orient=HORIZONTAL)
9. s2.pack()
10.
11. def show():
12. print(s1.get(), s2.get())
13.
14. Button(root, text="获得位置",command=show).pack()
15.
16. mainloop()
然后,你可以通过 resolution 选项控制分辨率(步长),通过 tickinterval 选项设置刻度:
1. from tkinter import *
2.
3. root = Tk()
4.
5. Scale(root, from_=0, to=42,tickinterval=5, length=200, \
6. resolution=5,orient=VERTICAL).pack()
7. Scale(root, from_=0, to=200,tickinterval=10, length=600, \
8. orient=HORIZONTAL).pack()
9.
10. mainloop()
参数
Scale(master=None, **options) (class)
master -- 父组件
**options -- 组件选项,下方表格详细列举了各个选项的具体含义和用法:
选项 | 含义 |
activebackground | 1. 指定当鼠标在上方飘过的时候滑块的背景颜色 |
background | 1. 滚动槽外部的背景颜色 |
bg | 跟 background 一样 |
bigincrement | 1. 设置“大”增长量 |
borderwidth | 1. 指定边框宽度 |
bd | 跟 borderwidth 一样 |
command | 1. 指定一个函数,每当滑块发生改变的时候都会自动调用该函数 |
cursor | 1. 指定当鼠标在上方飘过的时候的鼠标样式 |
digits | 1. 设置最多显示多少位数字 |
foreground | 1. 指定滑块左侧的 Label 和刻度的文字颜色 |
fg | 跟 foreground 一样 |
font | 1. 指定滑块左侧的 Label 和刻度的文字字体 |
from | 1. 设置滑块最顶(左)端的位置 |
highlightbackground | 1. 指定当 Scale 没有获得焦点的时候高亮边框的颜色 |
highlightcolor | 1. 指定当 Scale 获得焦点的时候高亮边框的颜色 |
highlightthickness | 1. 指定高亮边框的宽度 |
label | 1. 你可以在垂直的 Scale 组件的顶端右侧(水平的话是左端上方)显示一个文本标签 |
length | 1. Scale 组件的长度 |
orient | 1. 设置该 Scale 组件是水平放置(HORIZONTAL)还是垂直放置(VERTICAL) |
relief | 1. 指定边框样式 |
repeatdelay | 1. 该选项指定鼠标左键点击滚动条凹槽的响应时间 |
repeatinterval | 1. 该选项指定鼠标左键紧按滚动条凹槽时的响应间隔 |
resolution | 1. 指定 Scale 组件的分辨率(步长,即在凹槽点击一下鼠标左键它移动的数量) |
showvalue | 1. 设置是否显示滑块旁边的数字 |
sliderlength | 1. 设置滑块的长度 |
sliderrelief | 1. 设置滑块的样式 |
state | 1. 默认情况下 Scale 组件支持鼠标事件和键盘事件,可以通过设置该选项为 DISABLED 来禁用此功能 |
takefocus | 1. 指定使用 Tab 键是否可以将焦点移动到该 Scale 组件上 |
tickinterval | 1. 设置显示的刻度,如果设置一个值,那么就会按照该值的倍数显示刻度 |
to | 1. 设置滑块最底(右)端的位置 |
troughcolor | 1. 设置凹槽的颜色 |
variable | 1. 指定一个与 Scale 组件相关联的 Tkinter 变量,该变量存放滑块最新的位置 |
width | 1. 指定 Scale 组件的宽度 |
方法
coords(value=None)
-- 获得当前滑块的位置对应 Scale 组件左上角的相对坐标
-- 如果设置 value 参数,则返回当滑块所在该位置时的相对坐标
get()
-- 获得当前滑块的位置
-- Tkinter 会尽可能地返回一个整型值,否则返回一个浮点型值
identify(x, y)
-- 返回一个字符串表示指定位置下(如果有的话)的 Scale 部件
-- 返回值可以是:"slider"(滑块),"trough1"(左侧或上侧的凹槽),"trough2"(右侧或下侧的凹槽)或 ""(啥都没有)
set(value)
-- 设置 Scale 组件的值(滑块的位置)