如何用kv语言动态制作很多按钮?

时间:2016-03-08 00:40:58

标签: python loops dynamic kivy kivy-language

我想用kv语言制作很多动态按钮。 但现在我不能...... 我将在此下显示源代码。

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)

我想在代码

下制作
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)

我该怎么办?

3 个答案:

答案 0 :(得分:1)

这种循环在kv语言中是不可能的,除了做一些肮脏的黑客攻击。

要动态创建一组按钮,请使用ListView或将它们添加到py文件中的循环中。

示例:

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

答案 1 :(得分:0)

这是错误的,您可以像这样轻松地将循环集成到您的KV文件中:

    GridLayout:
    pos: root.pos
    size: root.size
    cols:30
    rows:3
    on_parent:
        for i in range(10): strId = "B{0}".format(i+1); i=Button(text=strId, id=strId, on_press=lambda BingoMain:root.my_Function(strId)); self.add_widget(i);

答案 2 :(得分:-1)

我不认为这可以在kv文件中完成。但是,如果您可以在python文件中编写kv字符串,则可以执行以下操作:

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()