<small id='UZWSq'></small><noframes id='UZWSq'>

<legend id='UZWSq'><style id='UZWSq'><dir id='UZWSq'><q id='UZWSq'></q></dir></style></legend>
  • <tfoot id='UZWSq'></tfoot>
      <bdo id='UZWSq'></bdo><ul id='UZWSq'></ul>

    1. <i id='UZWSq'><tr id='UZWSq'><dt id='UZWSq'><q id='UZWSq'><span id='UZWSq'><b id='UZWSq'><form id='UZWSq'><ins id='UZWSq'></ins><ul id='UZWSq'></ul><sub id='UZWSq'></sub></form><legend id='UZWSq'></legend><bdo id='UZWSq'><pre id='UZWSq'><center id='UZWSq'></center></pre></bdo></b><th id='UZWSq'></th></span></q></dt></tr></i><div id='UZWSq'><tfoot id='UZWSq'></tfoot><dl id='UZWSq'><fieldset id='UZWSq'></fieldset></dl></div>

        切换 kivy 小部件

        时间:2023-06-07
        <i id='bPffS'><tr id='bPffS'><dt id='bPffS'><q id='bPffS'><span id='bPffS'><b id='bPffS'><form id='bPffS'><ins id='bPffS'></ins><ul id='bPffS'></ul><sub id='bPffS'></sub></form><legend id='bPffS'></legend><bdo id='bPffS'><pre id='bPffS'><center id='bPffS'></center></pre></bdo></b><th id='bPffS'></th></span></q></dt></tr></i><div id='bPffS'><tfoot id='bPffS'></tfoot><dl id='bPffS'><fieldset id='bPffS'></fieldset></dl></div>
      1. <legend id='bPffS'><style id='bPffS'><dir id='bPffS'><q id='bPffS'></q></dir></style></legend>

        <small id='bPffS'></small><noframes id='bPffS'>

          <tbody id='bPffS'></tbody>
        • <bdo id='bPffS'></bdo><ul id='bPffS'></ul>

                • <tfoot id='bPffS'></tfoot>
                  本文介绍了切换 kivy 小部件的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

                  问题描述

                  我正在使用 Kivy python 库.

                  I am using the Kivy python library.

                  我定义了两个小部件.

                  程序运行时,我运行第一个小部件.

                  When the program runs, I run the first widget.

                  当那个小部件按钮被按下时,我希望它消失并被第二个小部件替换.

                  When that widgets button is pressed, I want it to dissapear and be replaced with the second widget.

                  这是两个小部件的 .kv

                  Here is the .kv for the two widgets

                  #uitest.kv
                  <TestForm>:
                      canvas:
                          Rectangle:
                              pos: self.center_x, 0
                              size: 10, self.height
                  
                      BoxLayout:
                          size: root.size
                          padding: 40
                          Button:
                              text: 'Hello'
                              on_release: root.testCallback()
                  
                  <TestForm2>:
                      canvas:
                          Rectangle:
                              pos: self.center_x, 0
                              size: self.height, 10
                  

                  我的主要 python 文件运行应用程序,并返回第一个小部件

                  My main python file runs the app, and returns the first widget

                  #main.py
                  from testform import TestForm
                  from kivy.app import App
                  
                  class UITestApp(App):
                      def build(self):
                          return TestForm()
                  
                  # Main launching point
                  if __name__ in ('__main__', '__android__'):
                      UITestApp().run()
                  

                  我的第一个小部件有一个回调.这是有问题的代码所属的地方

                  My first widget has a callback. This is where the code-in-question belongs

                  from testform2 import TestForm2
                  from kivy.uix.widget import Widget
                  
                  class TestForm(Widget):
                      def testCallback(self):
                          TestForm2() # Code in question goes here. @TODO replace this widget with TestForm2 widget.
                  

                  这里的想法是拥有一个用户界面管理器.该管理器不像树那样运行 UI,而是像列表和堆栈一样运行.该列表包含我所有的 UI 表单的实例.堆栈保存所述表单的遍历,每当我们跳转到一个表单时,我们将其推送到堆栈并渲染"或其他任何一个.

                  The idea here is to have a user interface manager. This manager doesn't run the UI like a tree, but like a list and stack. The list holds instances of all my UI Forms. The stack holds the traversal of said forms, whenever we jump to a form we push it to the stack and "render" or whatever that one.

                  我选择了我的答案,但在搜索中我还找到了 Screen 对象:http://kivy.org/docs/api-kivy.uix.screenmanager.html就个人而言,clear() 和 add() 命令更强大,但如果您有兴趣,屏幕会从您手中夺走很多东西.过渡效果也是如此.

                  I chose my answer, but in my searches I also found the Screen object: http://kivy.org/docs/api-kivy.uix.screenmanager.html Personally, the clear() and add() commands are more powerful, but the screen takes a lot of that out of your hands if you're interested. Transition effects too.

                  推荐答案

                  我的建议是有一个界面管理器小部件,然后您可以为您的 UI 表单提供各种小部件.

                  My suggestion is to have an interface manager widget, then you can have various widgets for your UI forms.

                  import kivy
                  from kivy.uix.label import Label
                  from kivy.uix.button import Button
                  from kivy.uix.boxlayout import BoxLayout
                  from kivy.app import App
                  
                  class InterfaceManager(BoxLayout):
                  
                      def __init__(self, **kwargs):
                          super(InterfaceManager, self).__init__(**kwargs)
                  
                          self.first = Button(text="First")
                          self.first.bind(on_press=self.show_second)
                  
                          self.second = Button(text="Second")
                          self.second.bind(on_press=self.show_final)
                  
                          self.final = Label(text="Hello World")
                          self.add_widget(self.first)
                  
                      def show_second(self, button):
                          self.clear_widgets()
                          self.add_widget(self.second)
                  
                      def show_final(self, button):
                          self.clear_widgets()
                          self.add_widget(self.final)
                  
                  
                  class MyApp(App):
                      def build(self):
                          return InterfaceManager(orientation='vertical')
                  
                  if __name__ == '__main__':
                      MyApp().run()
                  

                  当然,你不会那样组织它.您可以将所有表单保存在 Container 对象的字典中,并有一个通用回调,通过键提供另一种表单.

                  You wouldn't structure it like that of course. You could hold all your forms in a dictionary on the Container object and have a universal callback which provides another form by key.

                  class InterfaceManager(BoxLayout):
                  
                      def __init__(self, **kwargs):
                          super(InterfaceManager, self).__init__(**kwargs)
                          self.forms = {}
                  
                      def add_form(self, key, form):
                          self.forms[key] = form
                  
                      def uniCallback(self, button):
                          self.clear_widgets()
                          # You could introduce a more elegant key
                          # handling system here.
                          self.add_widget(self.forms[button.text])
                  

                  这篇关于切换 kivy 小部件的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

                  上一篇:在 Kivy 中将图像对象作为按钮背景传递 下一篇:Kivy 日期选择器小部件

                  相关文章

                  <i id='9uFid'><tr id='9uFid'><dt id='9uFid'><q id='9uFid'><span id='9uFid'><b id='9uFid'><form id='9uFid'><ins id='9uFid'></ins><ul id='9uFid'></ul><sub id='9uFid'></sub></form><legend id='9uFid'></legend><bdo id='9uFid'><pre id='9uFid'><center id='9uFid'></center></pre></bdo></b><th id='9uFid'></th></span></q></dt></tr></i><div id='9uFid'><tfoot id='9uFid'></tfoot><dl id='9uFid'><fieldset id='9uFid'></fieldset></dl></div>

                      <bdo id='9uFid'></bdo><ul id='9uFid'></ul>

                    <small id='9uFid'></small><noframes id='9uFid'>

                    <legend id='9uFid'><style id='9uFid'><dir id='9uFid'><q id='9uFid'></q></dir></style></legend>

                    <tfoot id='9uFid'></tfoot>