Tkinter 프레임용 수직 스크롤바
여러 레이블이 있는 프레임에 수직 스크롤바를 추가하는 접근 방식은 일반적으로 정확합니다. 그러나 고려해야 할 몇 가지 개선 사항과 대체 방법이 있습니다.
코드가 효율적인가요?
예, 코드는 목표를 달성하고 프레임에 세로 스크롤 막대를 추가합니다. . 그러나 더 효율적이고 우아한 대체 접근 방식이 있습니다.
왜 그리드 방식을 사용하나요?
장소 방식도 가능하지만 이 경우 그리드 방식이 선호됩니다. 구조화되고 예측 가능한 방식으로 위젯을 구성할 수 있기 때문입니다. 각 레이블은 특정 행과 열에 배치되어 적절한 정렬과 간격을 보장할 수 있습니다. 반면에 배치 방법은 예측할 수 없는 결과와 잠재적인 중복을 초래할 수 있습니다.
캔버스 창의 경우 Anchor='nw'
창을 만들 때 캔버스를 북서쪽(nw)에 고정하면 창은 캔버스의 왼쪽 상단 모서리에 배치됩니다. 이는 캔버스가 스크롤될 때 창 내부의 콘텐츠가 표시되도록 보장하는 기본 창 앵커입니다.
대체 솔루션
다음은 수직 앵커를 사용하는 대체 구현입니다. 스크롤 프레임:
import tkinter as tk import tkinter.ttk as ttk class VerticalScrolledFrame(ttk.Frame): def __init__(self, parent, *args, **kwargs): ttk.Frame.__init__(self, parent, *args, **kwargs) self.canvas = tk.Canvas(self, bd=0, highlightthickness=0) self.canvas.pack(side=tk.LEFT, fill='both', expand=True) self.scrollbar = ttk.Scrollbar(self, orient='vertical', command=self.canvas.yview) self.scrollbar.pack(side=tk.RIGHT, fill='y') self.canvas.config(yscrollcommand=self.scrollbar.set) self.canvas.bind('<Configure>', self._configure_canvas) self.interior = ttk.Frame(self.canvas) self.interior_id = self.canvas.create_window(0, 0, window=self.interior, anchor='nw') def _configure_canvas(self, event): size = (self.interior.winfo_reqwidth(), self.interior.winfo_reqheight()) self.canvas.config(scrollregion="0 0 %s %s" % size) self.canvas.itemconfig(self.interior_id, width=self.canvas.winfo_width()) root = tk.Tk() frame = VerticalScrolledFrame(root) frame.pack(fill='both', expand=True) for i in range(50): ttk.Label(frame.interior, text=i).pack() root.mainloop()
이 솔루션은 세로 스크롤 프레임을 생성하고 캔버스를 사용하여 스크롤을 관리합니다. 내부 프레임의 크기에 맞춰 자동으로 조정되며 스크롤된 영역 내에 위젯을 간단하게 배치할 수 있습니다.
위 내용은 기존 방법과 비교하여 Tkinter 프레임에 수직 스크롤 막대를 추가하는 더 효율적인 방법이 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!