Scrollbar与ScrolledText
1、Scrollbar
Scrollbar(滚动条)允许查看另一个小部件的所有部分,其内容通常大于可用空间。
Tkinter Scrollbar小部件不属于任何其他小部件,例如 Text 和 Listbox。 相反,Scrollbar是一个独立的小部件。
Tkinter Scrollbar 小部件基本上提供了滑动控制器,用于实现垂直滚动小部件,如 Listbox、Canvas 和 Text。 使用 Scrollbar小部件,还可以尝试在条目小部件上创建水平滚动条。 当滚动条设置为垂直时,Scrollbar用于滚动内容以垂直查看整个内容。 水平滚动条用于水平滚动内容。 Scrollbar() 语法将用于获取具有以下属性的滚动条:master 和 option/options。
创建Scrollbar的语法如下:
w=scrollbar( master, option/options, … )
参数说明如下:
- Master:Tkinter滚动条的这个master属性只代表父窗口
- option/options:Scrollbar的选项/选项属性将具有滚动条小部件常用的选项列表。 这些选项/选项主要用作键值对,以逗号分隔。
Scrollbar小部件最常用的选项列表:
- activebackground:当鼠标/光标点在滚动条/滑块上时,Scrollbar的“activebackground”选项用于为滑块/滚动条/箭头/箭头/光标符号着色。
- Bg:当鼠标/光标点实际上不在滚动条/滑块上时,Scrollbar的“bg”选项对于更改滚动条/箭头/光标点的背景非常有帮助。
- bd:用于设置围绕整个槽的周边的 3d 边框的宽度,以及滑块和鼠标点/箭头/光标点上的 3d 效果的宽度。默认情况下,槽的每个角落周围/旁边都没有边框。连同在滑块和箭头/光标点周围有 2 个像素的边框一起。
- command:每次滚动条/滑块移动时根据需要调用的过程。
- cursor:使光标在滚动条位于鼠标/光标点下方时出现。
- elementborderwidth:用于调整滑块和箭头/光标周围的边框宽度。默认情况下,elementborderwidth 的值为“1”。可以根据需要/需要使用 elementborderwidth 选项添加任何边框宽度。
- highlightbackground:用于在滚动条/滑块没有任何焦点时突出显示颜色。
- highlightcolor:用于当鼠标点/滚动条/滑块有焦点时高亮的焦点颜色。
- highlightthickness:用于设置高亮的粗细,但默认情况下,高亮粗细值设置为 1。您可以将值设置为 0 以抑制焦点高亮的显示。
- jump:控制用户拖动/拖动滑块时发生的情况。默认情况下,跳转选项的 0 值会导致每个小滑块拖动的回调命令。如果跳转选项值设置为值 1,则如果用户没有释放鼠标/光标按钮,则不会调用回调。
- orient:用于将方向设置为水平/垂直。就像 orient=HORIZONTAL 或 orient =VERTICAL 。
- repeatDelay:控制在滑块重复向特定方向移动之前,按钮 1 在槽中按下的时间。默认情况下,重复延迟(repeatdelay=300)为300,单位为毫秒。
- repeatInterval:用于重复滑块的间隔。
- takefocus:用于通过滚动条小部件切换焦点,但如果您不想要此功能/行为,可以将其设置为值 0。
- troughcolor:用于更改槽的颜色。
- width:用于设置滚动条/滑块的宽度(x 尺寸用于垂直,y 尺寸用于水平)。默认情况下,宽度值为 16 (width=16)。
Scrollbar使用的步骤如下:
- 首先,创建一个Scrollbar小部件。
- 其次,将Scrollbar与可滚动的小部件链接起来。
下面展示了如何使用 ttk.Scrollbar 构造函数创建Scrollbar小部件:
scrollbar = ttk.Scrollbar(
container,
orient='vertical',
command=widget.yview
)
上面代码通过三个参数创建Scrollbar对象:
- container是滚动条所在的窗口或Frame。
- orient 参数指定滚动条是需要水平滚动还是垂直滚动。
- command参数允许滚动条小部件与可滚动小部件进行通信。
Scrollbar小部件还需要向Scrollbar反馈当前可见的整个内容区域的百分比。
每个Scrollbar小部件都有一个 yscrollcommand 和/或 xscrollcommand 选项。 可以将 scrollbar.set 方法分配给它:
widget['yscrollcommand'] = scrollbar.set
Text小部件是几种可滚动小部件之一。 下面的程序演示了一个简单的用户界面,它由 Text 和 Scrollbar 小部件组成:
import tkinter as tk
from tkinter import ttk
root = tk.Tk()
root.resizable(False, False)
root.title("Scrollbar Widget Example")
root.grid_columnconfigure(0, weight=1)
root.grid_rowconfigure(0, weight=1)
text = tk.Text(root, height=10)
text.grid(row=0, column=0, sticky='ew')
scrollbar = ttk.Scrollbar(root, orient='vertical', command=text.yview)
scrollbar.grid(row=0, column=1, sticky='ns')
text['yscrollcommand'] = scrollbar.set
root.mainloop()
运行结果如下:
2、ScrolledText
为了更方便,Tkinter 提供了 ScrolledText 小部件,它与链接到垂直滚动条的文本小部件执行相同的操作。
要使用 ScrolledText 小部件,需要从 tkinter.scrolledtext 模块导入 ScrolledText 类。从技术上讲,ScrolledText 类继承自 Text 类。ScrolledText 小部件使用插入在容器和 Text 小部件之间的 Frame 小部件来保存 Scrollbar 小部件。因此,ScrolledText 具有与 Text 小部件相同的属性和方法。 此外,包括 pack、grid 和 place 在内的几何管理器方法仅限于 Frame。
演示代码如下:
import tkinter as tk
from tkinter.scrolledtext import ScrolledText
root = tk.Tk()
root.title("ScrolledText Widget")
st = ScrolledText(root, width=50, height=10)
st.pack(fill=tk.BOTH, side=tk.LEFT, expand=True)
root.mainloop()
用面向对象的编程方法编写代码如下:
import tkinter as tk
from tkinter.scrolledtext import ScrolledText
class App(tk.Tk):
def __init__(self):
super().__init__()
self.title("ScrolledText Widget")
st = ScrolledText(self, width=50, height=10)
st.pack(fill=tk.BOTH, side=tk.LEFT, expand=True)
if __name__ == "__main__":
app = App()
app.mainloop()
|