繁体   English   中英

制作按钮列表视图,这些按钮可切换到kivy中的不同屏幕

[英]Make a listview of buttons that switch to different screens in kivy

在我的项目中,我遇到了另一个问题。 我有50个屏幕,我想先显示一个引用这些屏幕的按钮列表。按下按钮时,屏幕管理器应切换到相关屏幕。 这是我的代码,但我不知道该怎么办!

来源: https : //gist.github.com/daryasary/3a2be816c1f35b748866

from kivy.uix.screenmanager import ScreenManager, Screen
from kivy.lang import Builder
from kivy.app import App
#from kivy.uix.popup import Popup
#from kivy.uix.label import Label
from kivy.core.audio import SoundLoader

Builder.load_string('''
<MenuPage>:
    BoxLayout:
        BoxLayout:
            size_hint:(.1, None)
            Button:
            text: 'Credit'
            #on_press:root.show_popup()
        #ListView:
            #size_hint: .8,.9
            #adapter:
                #sla.SimpleListAdapter(
                #data=["Item #{0}".format(i) for i in range(100)],
                #cls=button.Button
                #selection_mode='single',
                #allow_empty_selection=False)
        ListView:
            size_hint: .8, .97
            item_strings: [str(index) for index in range(50)]

        BoxLayout:
            size_hint:(.1, None)
            Button:
            text: 'atlas'


<Page>:
BoxLayout:
    BoxLayout:
        size_hint:(.1, None)
        Button:
        text: 'MENU'
        on_press: root.manager.current = 'menu'
    BoxLayout:
        orientation:'vertical'
        Button:
        text:'Title'
        size_hint:(1, .2)
    Image:
        source: '/home/hosein/Pictures/1.png'
        size_hint:(1, .8)
    BoxLayout:
        size_hint:(.1, None)
        Button:
        text: 'atlas'
''')



class MenuPage(Screen):
    M = SoundLoader.load('/home/hosein/Music/Man.mp3')

    def plays(self):
        if MenuPage.M.state == 'stop':
        MenuPage.M.play()
    else:
        MenuPage.M.stop()



class Page(Screen):
    pass



sm = ScreenManager()
menu = MenuPage(name='menu')
sm.add_widget(menu)
for i in range(50):
    name = Page(name=str(i))
    sm.add_widget(name)


class TestApp(App):

    def build(self):
    return sm

if __name__ == '__main__':
    TestApp().run()

50个“页面”都是相同的,因此将它们全部替换为一个页面会更有意义,该页面会根据所选菜单按钮更改图片/声音内容。 它使用更少的资源,并且更易于调试和维护。

您的资源文件(例如1.png)也可以通过将它们分组在一个固定的子目录中,或者使用库提供的间接机制在代码中引用它们来更好地进行组织( link

关于你的问题; listview机制允许使用多种不同的方法,但是简单的适配器就不够用。 ListView文档中提供了很多有关列表的良好示例( 链接

至少,您需要一个listadapter,一个响应按钮按下的函数以及将该函数绑定到按钮对象。 您可以通过绑定listadapter.on_selection_change事件处理程序来做到这一点,但是我发现创建带有特定处理程序的按钮项类listadapter.on_selection_change ,这就是我在下面提供的内容。

from kivy.uix.screenmanager import ScreenManager, Screen
from kivy.lang import Builder
from kivy.app import App
from kivy.core.audio import SoundLoader
from kivy.uix.listview import ListItemButton
from kivy.properties import ListProperty, NumericProperty

Builder.load_string('''
#:import la kivy.adapters.listadapter
#:import factory kivy.factory

<MenuButton>:
    size_hint_y: None
    height: dp(24)
    on_release: app.on_menu_selection(self.index)

<MenuPage>:
    BoxLayout:
        BoxLayout:
            size_hint:(.1, None)
            Button:
                text: 'Credit'
                #on_press:root.show_popup()
        ListView:
            size_hint: .8,.9
            adapter:
                la.ListAdapter(
                data=app.data,
                cls=factory.Factory.MenuButton,
                selection_mode='single',
                allow_empty_selection=True,
                args_converter=root.args_converter)

        BoxLayout:
            size_hint:(.1, None)
            Button:
                text: 'atlas'


<Page>:
    BoxLayout:
        BoxLayout:
            size_hint:(.1, None)
            Button:
                text: 'MENU'
                on_press: root.manager.current = 'menu'
        BoxLayout:
            orientation:'vertical'
            Button:
                text:'Title'
                size_hint:(1, .2)
            Image:
                source: '/home/hosein/Pictures/1.png'
                size_hint:(1, .8)
        BoxLayout:
            size_hint:(.1, None)

            Button:
                text: 'atlas'
''')

class MenuButton(ListItemButton):
    index = NumericProperty(0)

class MenuPage(Screen):
    M = SoundLoader.load('/home/hosein/Music/Man.mp3')

    def plays(self):
        if MenuPage.M.state == 'stop':
            MenuPage.M.play()
        else:
            MenuPage.M.stop()

    def args_converter(self, row_index, title):
        print ("{0}={1}".format(row_index, title))

        return {
            'index': row_index,
            'text': title
        }

class Page(Screen):
    pass

class TestApp(App):
    data = ListProperty(["Item #{0}".format(i) for i in range(50)])

    def build(self):
        sm = ScreenManager()
        menu = MenuPage(name='menu')
        sm.add_widget(menu)
        for i in range(50):
            name = Page(name=str(i))
            sm.add_widget(name)
        return sm

    def on_menu_selection(self, index):
        self.root.current = str(index)

if __name__ == '__main__':
    TestApp().run()

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM