如何在 Python Kivy 的每个小部件中画线

问题描述

我正在尝试在标签显示二叉树。如何在每个标签内从中心到左右边缘绘制线条?这个任务很奇怪,我明白,但你需要用最基本的 Kivy 对象显示一个自写的树。不能使用 Kivy 树。网上所有的解决方案都是针对触摸屏的。

在这个循环中,我添加带有节点值的标签,如果未找到节点,则为 0

class TreeApp(App):
    def build(self):
        bl = BoxLayout(orientation='vertical',padding=5,spacing=5)
            for i in range(maxdepth):
                inside_bl = BoxLayout(orientation='horizontal')
                for j in range(2 ** i):
                    try: inside_bl.add_widget(Label01(text=str(mx_lvl[i][j]),color=(0.5,0.5,1)))
                    except: inside_bl.add_widget(Label111(text="0",0.5)))
                bl.add_widget(inside_bl)
        return bl

在这里我尝试制​​作 class label01。我想用 self.将为每个标签创建自己的线条并相对于标签的原点或中心绘制。

class Label01(Label):
    def __init__(self,**kwargs):
        super(Label01,self).__init__(**kwargs)

        with self.canvas:
            self.pos = self.pos
            Color(0,1,1)
            self.line= Line(points=(self.x+100,self.y+100,self.x+250,self.y+250),close = True)

标签 111 也是如此。我想使用 self.将为每个标签创建自己独特的线条,并相对于标签的原点或中心绘制。

  • tree.kv
#:kivy 1.11.1
<Label111>:
    canvas.before:
        Line:
            
            width: 2
            points: (self.x,self.y+50,self.x+200,self.x+300,self.y+200)
        Color:
            rgb: (0.9,0.9,0.9)
  • main.py:
class Label111(Label):
    pass

我认为在使用 self.我将在每个标签内得到一条测试线(共 31 条),但在窗口底部只有 2 条线。问题:如何在每个标签内相对于其中心绘制两条线?

Window with only two lines

解决方法

因为您在其 Label01 方法中为 __init__() 绘制线条,所以在设置 Label01 的位置和大小之前绘制所有线条。所以所有的线都是使用 Label01 的默认位置(0,0)绘制的。由于您在 python 代码中执行此操作,因此在更改 Label01 的位置时没有绑定来调整行。

这可以通过编写您自己的绑定来进行调整来解决,或者通过定义 kv 中的行让 kv 为您完成。像这样:

<Label01>:
    canvas.before:
        Color:
            rgba: 0,1,1
        Line:
            points: self.center_x,self.center_y,self.center_x+250,self.center_y+250

这些点是相对于 Label01 的中心定义的(如您所述),然后 Label01 的定义变得简单:

class Label01(Label):
    pass