- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我需要有关在不需要时自动隐藏 tkinter 滚动条的帮助。我从 effbot.org 找到了自动隐藏滚动条的代码,但仅限于网格几何。在我的案例中,我没有使用网格几何。这是我的代码。
import Tkinter as tk
from Tkinter import *
import tkFont
class AutoScrollbar(Scrollbar):
# a scrollbar that hides itself if it's not needed. only
# works if you use the grid geometry manager.
def set(self, lo, hi):
if float(lo) <= 0.0 and float(hi) >= 1.0:
# grid_remove is currently missing from Tkinter!
self.tk.call("grid", "remove", self)
else:
self.grid()
Scrollbar.set(self, lo, hi)
def pack(self, **kw):
raise TclError, "cannot use pack with this widget"
def place(self, **kw):
raise TclError, "cannot use place with this widget"
class MainWindow(tk.Tk):
def __init__(self, *args, **kwargs):
tk.Tk.__init__(self, *args, **kwargs)
w = 1200
h = 650
x = self.winfo_screenwidth()/2 - w/2
y = self.winfo_screenheight()/2 - h/2
self.geometry("%ix%i+%i+%i" % (w, h, x, y))
self.mainTopFrame = Frame(self, height=75)
self.mainTopFrame.pack(side=TOP, fill=X)
self.canvas = Canvas(self, borderwidth=0, bg='#ffffff')
self.mainBottomFrame = Frame(self.canvas, bg='#000000')
self.yscroll = Scrollbar(self.canvas, orient=VERTICAL, command=self.canvas.yview)
self.canvas.configure(yscrollcommand=self.yscroll.set)
self.canvas.pack(side=TOP, fill=BOTH, expand=1)
self.yscroll.pack(side=RIGHT, fill=Y)
self.canvas.create_window((4,4), window=self.mainBottomFrame, anchor=NW)
self.mainBottomFrame.bind("<Configure>", self.onFrameConfigure)
self.menuFrame = Frame(self.mainTopFrame, bg='#545454')
self.menuFrame.pack(side=TOP, fill=BOTH, expand=True)
self.container = Frame(self.mainBottomFrame)
self.container.pack(side=TOP, fill=BOTH, expand=True)
self.frames = {}
for F in (MonitorPage, PlanPage, DataLogPage, HelpPage):
self.frame = F(self.container, self)
self.frames[F] = self.frame
self.frame.grid(row=0, column=0, sticky="nsew")
self.show_frame(MonitorPage)
def show_frame(self, cont):
self.frame = self.frames[cont]
self.frame.tkraise()
def onFrameConfigure(self, event):
'''Reset the scroll region to encompass the inner frame'''
self.canvas.configure(scrollregion=self.canvas.bbox("all"))
class AutoScrollbar(Scrollbar):
# a scrollbar that hides itself if it's not needed. only
# works if you use the grid geometry manager.
def set(self, lo, hi):
if float(lo) <= 0.0 and float(hi) >= 1.0:
# grid_remove is currently missing from Tkinter!
self.tk.call("grid", "remove", self)
else:
self.grid()
Scrollbar.set(self, lo, hi)
def pack(self, **kw):
raise TclError, "cannot use pack with this widget"
def place(self, **kw):
raise TclError, "cannot use place with this widget"
class MonitorPage(tk.Frame):
def __init__(self, parent, controller):
tk.Frame.__init__(self, parent)
self.labelFont = tkFont.Font(family="Fixedsys", size=15, weight=tkFont.BOLD)
self.leftFrame0 = Frame(self, bg='#888888')
self.leftFrame0.pack(side=LEFT, fill=BOTH)
self.rightFrame0 = Frame(self, bg='#888888')
self.rightFrame0.pack(side=RIGHT, fill=BOTH)
self.upLftFrame0 = Frame(self.leftFrame0)
self.upLftFrame0.pack(side=TOP, fill=BOTH, padx=10, pady=10)
self.dnLftFrame0 = Frame(self.leftFrame0)
self.dnLftFrame0.pack(side=BOTTOM, fill=BOTH, padx=10, pady=10)
self.upLftLblFrame0 = tk.LabelFrame(self.upLftFrame0)
self.upLftLblFrame0.pack(side=TOP, fill=BOTH, padx=5, pady=5)
self.dnLftLblFrame0 = tk.LabelFrame(self.dnLftFrame0)
self.dnLftLblFrame0.pack(side=BOTTOM, fill=BOTH, padx=5, pady=5)
self.rtLblFrame0 = tk.LabelFrame(self.rightFrame0)
self.rtLblFrame0.pack(side=TOP, fill=BOTH, padx=10, pady=10)
self.label0 = Label(self.rtLblFrame0, height=40, width=70)
self.label0.pack()
self.label1 = Label(self.upLftLblFrame0, height=25, width=115)
self.label1.pack()
self.label2 = Label(self.dnLftLblFrame0, height=10, width=115)
self.label2.pack()
class PlanPage(tk.Frame, MainWindow):
def __init__(self, parent, controller):
tk.Frame.__init__(self, parent)
class DataLogPage(tk.Frame):
def __init__(self, parent, controller):
tk.Frame.__init__(self, parent)
class HelpPage(tk.Frame):
def __init__(self, parent, controller):
tk.Frame.__init__(self, parent)
if __name__ == '__main__':
rungui = MainWindow()
rungui.mainloop()
因此,即使我正在使用包几何体,我也想自动隐藏滚动条。我希望我把我的问题说清楚了。我对 python 和 tkinter 很陌生。
最佳答案
我将 effbot.org 中的示例改编为 pack 方法:
from Tkinter import *
class AutoScrollbar(Scrollbar):
# a scrollbar that hides itself if it's not needed. only
# works if you use the grid geometry manager.
def set(self, lo, hi):
if float(lo) <= 0.0 and float(hi) >= 1.0:
# grid_remove is currently missing from Tkinter!
self.pack_forget()
else:
if self.cget("orient") == HORIZONTAL:
self.pack(fill=X)
else:
self.pack(fill=Y)
Scrollbar.set(self, lo, hi)
def grid(self, **kw):
raise TclError, "cannot use grid with this widget"
def place(self, **kw):
raise TclError, "cannot use place with this widget"
# create scrolled canvas
root = Tk()
hscrollbar = AutoScrollbar(root, orient=HORIZONTAL)
canvas = Canvas(root,
xscrollcommand=hscrollbar.set)
canvas.pack(side=TOP, fill=BOTH, expand=True)
hscrollbar.pack()
hscrollbar.config(command=canvas.xview)
# make the canvas expandable
root.grid_rowconfigure(0, weight=1)
root.grid_columnconfigure(0, weight=1)
# create canvas contents
frame = Frame(canvas)
frame.rowconfigure(1, weight=1)
frame.columnconfigure(1, weight=1)
rows = 5
for i in range(1,rows):
for j in range(1,10):
button = Button(frame, padx=7, pady=7, text="[%d,%d]" % (i,j))
button.grid(row=i, column=j, sticky='news')
canvas.create_window(0, 0, anchor=NW, window=frame)
frame.update_idletasks()
canvas.config(scrollregion=canvas.bbox("all"))
root.mainloop()
关于python - 使用包几何自动隐藏 Tkinter Canvas 滚动条,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41095385/
在 How to make a Tkinter window jump to the front? 中提出的问题之后的一个问题 我希望有一个顶层窗口(我用它来导航我的其他主窗口)总是在前面。但我希望它
有没有办法在 Tkinter 中保持小部件(特别是图像)的堆叠顺序一致?例如,我可能在 Canvas 上的同一位置有两个矩形、两个三角形和一个圆。圆圈移动到最后一次点击鼠标的地方,但我总是希望它被绘制
这是一个简单的 GUI 程序,用于创建 5x16 按钮矩阵。 from tkinter import * root = Tk() button = [[0 for x in range(16)] fo
有一个错误:“AttributeError: module 'tkinter' has no attribute 'messagebox'” 即使 import tkinter 一开始就已经给出了,为
我知道 menu.tk_popup() 可用于在特定坐标处打开上下文菜单,但也不知道如何从中打开子菜单,如果这有意义的话。这是我编写的代码: import tkinter as tk root = t
我正在尝试在禁用自动换行和水平滚动条的文本窗口中书写,如下所示: root = Toplevel() root.geometry("%dx%d+0+0" % (350,400)) af=Frame(r
已经将文本变量分配给小部件后,如何将其删除? widget.config(textvariable=None)只是不工作。在谷歌或这里找不到任何东西。 最佳答案 将您的变量分配给一个空字符串以实现此目
Jython 支持 Tkinter 吗?如果我用 Python 编写一个程序并放一个 使用 Tkinter 的 GUI 前端,做同样的事情有多难 Jython 中的程序?或者对于 Jython GUI
因此,我尝试创建一个 tkinter 窗口,显示当前时间和日期以及自定义短语。不过,我遇到的问题是,我似乎无法在第二天刷新日期。 我可以传递截至运行代码时的当前日期,但之后它变为静态。 这是我目前的程
我的理解是在初始化 __init__ 中的所有框架和小部件之后方法,tkinter 窗口会调整大小以适合所有这些组件。 我想将窗口的初始化大小设置为其最小大小。我希望能够最大化并放大窗口,但我从不希望
此代码仅水平居中,如何使进度条也垂直居中? import Tkinter import ttk root = Tkinter.Tk() root.geometry("=500x500") root.p
使用 Python 2.7 和 Tkinter 模块,我创建了一个菜单按钮并为其分配了一个菜单。现在每次我在特定位置发布菜单时,菜单的宽度都会根据字符数自动设置。有没有办法在菜单小部件中设置静态宽度?
我想将我的 tkinter 应用程序的主题更改为 clam。 代码是什么,我把它放在哪里?我试过了: from tkinter import * from tkinter.ttk import * s
我有以下代码: from Tkinter import * from urllib import urlretrieve import webbrowser import ttk def get_la
我知道,如果我将滚动条控制的框架绑定(bind)到函数 ( onFrameConfigure ),您可以获得滚动条位置,如下所示:self.calendar_frame.bind("", self.o
许多网站都说菜单小部件有一个选项“字体”,但我一直无法设置它。系统是在 Windows 8.1 中运行的 Python 3.5。脚本开始: 从 tkinter 导入 * 根 = Tk() root.g
我正在阅读本教程,它帮助我同时学习 tkinter 和 wxWidgets,但我想深入挖掘,所以想知道哪个 GUI 工具更适合深入学习,为什么? 最佳答案 不可能说哪个“更好”。两者均可用于最常见的用
看书学python,tkinter.END用在一段代码里不用解释 import tkinter def count(text, out_data): """ Update out_data w
我正在尝试使用 Python 2.7 将 Tkinter 导入到我的项目中,但我收到了错误: ImportError: No module named tkinter 在有人说之前,我已经尝试了“Tk
当我回答 Tkinter 问题时,我通常会尝试自己运行代码,但有时我会收到此错误: Traceback (most recent call last): File "C:\Python27\pyg
我是一名优秀的程序员,十分优秀!