python - PyGObject 页面切换按钮
问题描述
我想借助 Gtk.Stack 中的按钮切换页面。共有3个页面,应用程序的标题栏有一个前进和一个后退按钮。我希望它在按下前进按钮时转到下一页,并在按下后退按钮时转到上一页。它的当前状态只能在第 1 页和第 2 页之间切换。
import gi, os
gi.require_version("Gtk", "3.0")
gi.require_version("Handy", "1")
from gi.repository import Gtk, Handy
Handy.init()
class MyWindow(Handy.Window):
def __init__(self):
super().__init__(title="Hello World")
self.set_default_size(500, 300)
# WindowHandle
self.handle = Handy.WindowHandle()
self.add(self.handle)
# Box
self.winbox = Gtk.Box(spacing=6, orientation=Gtk.Orientation.VERTICAL)
self.handle.add(self.winbox)
# Headerbar
self.hb = Handy.HeaderBar()
self.hb.set_show_close_button(True)
self.hb.props.title = "Stack Example"
self.winbox.pack_start(self.hb, False, True, 0)
# Stack
self.stack = Gtk.Stack()
self.stack.set_transition_type(Gtk.StackTransitionType.SLIDE_LEFT_RIGHT)
self.winbox.pack_start(self.stack, True, True, 0)
# Labels
self.label = Gtk.Label(label="Page 1")
self.stack.add_titled(self.label, "page0", "Label")
self.label = Gtk.Label(label="Page 2")
self.stack.add_titled(self.label, "page1", "Label")
self.label = Gtk.Label(label="Page 3")
self.stack.add_titled(self.label, "page2", "Label")
# Headerbar button 1
self.button = Gtk.Button()
self.button = Gtk.Button.new_from_icon_name("pan-start-symbolic", Gtk.IconSize.MENU)
self.hb.pack_start(self.button)
self.button.connect('clicked', self.on_button1_clicked)
# Headerbar button 2
self.button2 = Gtk.Button()
self.button2 = Gtk.Button.new_from_icon_name("pan-end-symbolic", Gtk.IconSize.MENU)
self.hb.pack_start(self.button2)
self.button2.connect("clicked", self.on_button2_clicked)
def on_button1_clicked(self, widget):
self.stack.set_visible_child_name("page1")
def on_button2_clicked(self, widget):
self.stack.set_visible_child_name("page2")
win = MyWindow()
win.connect("destroy", Gtk.main_quit)
win.show_all()
Gtk.main()
解决方案
我不知道是否有一种简单的方法可以使 a 中的下一个孩子可见,GtkStack
或者另一个容器是否具有此功能GtkAssistant
。
不过,您可以通过多种方式自己实现这一点。要么像这样:
def on_button1_clicked(self, widget):
pages = self.stack.get_children()
cur_page = self.stack.get_visible_child()
i = pages.index(cur_page)
if i == 0: return
self.stack.set_visible_child(pages[i-1])
def on_button2_clicked(self, widget):
pages = self.stack.get_children()
cur_page = self.stack.get_visible_child()
i = pages.index(cur_page)
if i == len(pages) - 1: return
self.stack.set_visible_child(pages[i+1])
在哪里获得堆栈的孩子GtkContainer.get_children()
,找到当前可见孩子的索引,然后加/减一个以获得下一页/上一页。警告:我不确定是否get_children()
总是按照添加的顺序返回子小部件。
或者,在您的__init__()
函数中,您可以创建一个列表来存储您的页面名称/小部件,例如self.page_names = ['page0', 'page1', 'page2']
. 然后你可以这样做:
def on_button1_clicked(self, widget):
cur_page_name = self.stack.get_visible_child_name()
i = self.page_names.index(cur_page_name)
if i == 0: return
self.stack.set_visible_child_name(self.page_names[i-1])
或者,也许您使用 RegEx 从子名称(例如0
from page0
)中提取页码并生成下一页的名称。有很多方法可以做到这一点,我个人会保留所有页面的变量并使用它来确定哪个页面是下一页/上一页。
推荐阅读
- html - 如何将表格中的表格居中
- c# - 带有字典的 asp.net 核心 ioptions
- spring - Spring HTTP 基本身份验证会话身份验证
- python - 如何使函数在 fastAPI 中异步运行得更快?
- oracle - ORA-00900: 无效的 SQL 语句 - 当使用 node-oracledb 运行查询时
- c# - C#读取数据多个COM端口
- http - 谷歌搜索控制台 http https 索引
- javascript - 通过原始 DOM 引用元素查找克隆元素
- python - Pytorch Transformer 的维度问题
- python - Jupyter 拒绝在 VS Code 交互模式下加载虚拟环境