簡體   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