How can I make a lot of buttons at dynamic in kv l

2019-01-28 07:14发布

I want to make a lot of Buttons at dynamic in kv language. But now I cannot...... I will show now source under this.


BoxLayout:
    orientation: 'vertical'
    pos: root.pos
    size: root.size

    GridLayout:
        rows: 2
        spacing: 5
        padding: 5

        Button:
            text: "X0"
            on_press: root.X(0)
        Button:
            text: "X1"
            on_press: root.X(1)

I want to make like under code

BoxLayout:
    orientation: 'vertical'
    pos: root.pos
    size: root.size

    GridLayout:
        rows: 2
        spacing:5
        padding:5

        for i
            Button:
                text: "X#{i}"
                on_press: root.X(i)

How can I do?

2条回答
Root(大扎)
2楼-- · 2019-01-28 07:22

Such loops aren't possible in kv language, other than doing some dirty hacks.

To create a set of buttons dynamically, either use ListView or add them in a loop inside a py file.

Example:

from functools import partial

class MyGrid(GridLayout):
    def __init__(self, **kwargs):
        super(MyGrid, self).__init__(**kwargs)
        self.add_buttons()

    def add_buttons(self):
        for i in xrange(5):
            button = Button(
                text='X' + str(i),
                on_press=partial(self.X, number=i)
            )
            self.add_widget(button)

    def X(self, caller, number):
        print  caller, number
查看更多
Summer. ? 凉城
3楼-- · 2019-01-28 07:41

I don't think this can be done in an kv file. However, if you can write the kv string in your python file, you can do something like this:

from kivy.app import App
from kivy.lang import Builder

kv_string = """
BoxLayout:
    orientation: 'vertical'
    pos: root.pos
    size: root.size

    GridLayout:
        rows: 2
        spacing: 5
        padding: 5
""" + ''.join(["""
        Button:
            text: "X{0}"
            on_press: root.X({0})
""".format(i) for i in range(6)])

class MyApp(App):
    def build(self):
        w = Builder.load_string(kv_string)
        return w

if __name__ == '__main__':
    MyApp().run()
查看更多
登录 后发表回答