簡體   English   中英

調整復選框滾動大小 tkinter

[英]Resize scroll for checkbox tkinter

經過幾次測試和收到的幫助,我設法獲得了一個帶有多個復選框的滾動條的代碼。 我目前的問題是卷軸比它需要的空間大得多,一般來說我不能根據自己的喜好改變它的大小。 這是我的代碼:

import tkinter as tk
class CheckboxList(tk.Frame):
    def __init__(self, master=None, **kw):
        super().__init__(master, **kw)
        self.checkbuttons = []
        self.vars = []
        self.canvas = tk.Canvas(self, bg='white', bd=0, highlightthickness=0)
        self.yscroll = tk.Scrollbar(self, orient="vertical", command=self.canvas.yview)
        self.frame = tk.Frame(self.canvas)
        self.canvas.create_window((0, 0), window=self.frame, anchor='nw')
        self.canvas.configure(yscrollcommand=self.yscroll.set)
        self.canvas.grid(row=0,column=0, sticky='nsew')
        self.yscroll.grid(row=0, column=1, sticky='nse')
        for i in range(20):
            var = tk.IntVar(value=0)
            cb = tk.Checkbutton(self.frame, text=f"checkbutton #{i}", variable=var, onvalue=1, offvalue=0)
            cb.grid(row=i, column=0, sticky='w')
            self.checkbuttons.append(cb)
            self.vars.append(var)
        self.frame.update_idletasks()
        self.canvas.config(scrollregion=self.canvas.bbox("all"))
        
        self.canvas.bind_all("<MouseWheel>", self._on_mousewheel)
        
    def _on_mousewheel(self, event):
        self.canvas.yview_scroll(int(-1*(event.delta/120)), "units")

root = tk.Tk()
cl = CheckboxList(root, width=20, height=10)
cl.grid(row=0,column=0,sticky='nsew')
root.mainloop()

我通過更改“網格”的值進行了幾次測試,但我不能。 我希望我能更好地控制尺寸。 從圖中可以看出,還有很多空白區域,我也希望能夠改變整體高度在此處輸入圖像描述

編輯:工作代碼:

class CheckboxList(tk.Frame):
def __init__(self, master=None, **kw):
    super().__init__(master, **kw)
    self.checkbuttons = []
    self.vars = []
    self.canvas = tk.Canvas(self, bg='white', bd=0, highlightthickness=0)
    #self.canvas = tk.Canvas(self, bg='white', bd=0,width=115, highlightthickness=0)
    self.yscroll = tk.Scrollbar(self, orient="vertical", command=self.canvas.yview)
    self.frame = tk.Frame(self.canvas)
    self.canvas.create_window((0, 0), window=self.frame, anchor='nw')
    self.canvas.configure(yscrollcommand=self.yscroll.set)
    self.canvas.grid(row=0,column=0, sticky='nsew')
    self.yscroll.grid(row=0, column=1, sticky='nse')
    self.frame.bind("<Configure>", lambda e: self.canvas.config(width=e.width, scrollregion=self.canvas.bbox("all")))

    for i in range(20):
        var = tk.IntVar(value=0)
        cb = tk.Checkbutton(self.frame, text=f"checkbutton #{i}", variable=var, onvalue=1, offvalue=0)
        cb.grid(row=i, column=0, sticky='w')
        self.checkbuttons.append(cb)
        self.vars.append(var)
    self.frame.update_idletasks()
   
    self.canvas.bind_all("<MouseWheel>", self._on_mousewheel)
    
def _on_mousewheel(self, event):
    self.canvas.yview_scroll(int(-1*(event.delta/120)), "units")

在第 8 行添加width

改變這個:

self.canvas = tk.Canvas(self, bg='white', bd=0, highlightthickness=0)

到:

self.canvas = tk.Canvas(self, bg='white', bd=0,width=115, highlightthickness=0)

截屏:

在此處輸入圖像描述

每當通過self.frame上的事件<Configure>回調調整self.frame的大小時,您可以將self.frame的寬度設置為與self.canvas相同。 另請注意,當self.frame的大小更改時,您需要更新scrollregion的滾動區域。

        ...
        self.frame = tk.Frame(self.canvas)
        self.frame.bind("<Configure>", lambda e: self.canvas.config(width=e.width, scrollregion=self.canvas.bbox("all")))
        ...
        # scrollregion will be updated via the above event binding on self.frame, so below line is not necessary
        #self.canvas.config(scrollregion=self.canvas.bbox("all"))
        ...

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM