基维:如何在recycleview中正确地制作标签

2024-10-04 09:21:00 发布

您现在位置:Python中文网/ 问答频道 /正文

我正在尝试使用recycleview在kivy上构建一个日志查看器,因为日志可能非常大。我将为每行分配一个标签小部件,以便将来对文本有更多的控制。有些行比其他行有更多的文本,因此调整了标签小部件以根据大小调整大小,但当将其放入recycleview中时,它似乎无法再控制每行小部件的高度,它保持相同的大小。我所期望的是标签包装在文本上并调整高度,因为行间不需要额外的空间。如果只有很少的文本,则会显示大量的可用空间,如果我在标签中放入太多文本,则会溢出,标签不会增长

我用不同的代码尝试的一种解决方法是,每个标签至少分配200行,这似乎可行,但我确实需要对每行文本进行更多的控制

以下是示例代码:

from kivy.app import App
from kivy.lang import Builder
from kivy.uix.boxlayout import BoxLayout
from kivy.properties import ObjectProperty

Builder.load_string('''
<Row@BoxLayout>:
    canvas:
        Color:
            rgba: 1, 0.1, 0.1, 0.5 #Red Marker
        Rectangle:
            size: self.size
            pos: self.pos
    value: ''
    orientation: 'vertical'
    Label:
        text: root.value
        text_size: self.width, None
        size_hint_y: None
        height: self.texture_size[1]
        font_size: 20

<LogDisplayWidget>:
    rv: rv
    orientation: 'vertical'
                
    RecycleView:
        id: rv
        scroll_type: ['bars', 'content']
        scroll_wheel_distance: dp(114)
        bar_width: dp(10)
        viewclass: 'Row'
        RecycleBoxLayout:
            default_size_hint: 1, None
            size_hint_y: None
            height: self.minimum_height
            orientation: 'vertical'
            spacing: dp(2)
''')


class LogDisplayWidget(BoxLayout):
    rv = ObjectProperty()

    def __init__(self):
        super(LogDisplayWidget, self).__init__()
        self.load_text()

    def load_text(self):
        for i in range(10):
            line = str(i) + 'This is a test of a bunch of text'
            self.rv.data.append({'value': line})


class TestApp(App):
    def build(self):
        return LogDisplayWidget()


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

enter image description hereenter image description here


Tags: textfrom文本importselfnonesizevalue
1条回答
网友
1楼 · 发布于 2024-10-04 09:21:00

重新编写代码后,标签在第一页中显示为正确调整大小,但在滚动后会出现意外的结果,有时会显示正确的标签大小,然后一些标签会变大,滚动会跳过,比如尝试调整自身大小,然后再次修复大小。有没有人有更好的方法来实现这一点,或者我遗漏了什么?我怀疑这与景色更新的方式有关

这是新代码:

from kivy.app import App
from kivy.lang import Builder
from kivy.uix.recycleview import RecycleView
import random

Builder.load_string('''
<Row@Label>:
    canvas.before:
        Color:
            rgba: 0.8, 0.1, 0.1, 0.5 #Red Marker
        Rectangle:
            size: self.size
            pos: self.pos
    text_size: self.width, None
    size_hint_y: None
    height: self.texture_size[1]
    font_size: dp(20)

<RV>:
    viewclass: 'Row'
    RecycleBoxLayout:
        default_size: None, dp(20)
        default_size_hint: 1, None
        size_hint_y: None
        height: self.minimum_height
        orientation: 'vertical'
        spacing: dp(3)
        
''')


class RV(RecycleView):
    def __init__(self, **kwargs):
        super(RV, self).__init__(**kwargs)
        line = ''
        for i in range(50):
            n = random.randint(0, 1)
            if n:
                j = random.randint(5, 30)
                line = 'Line: ' + str(i+1) + ' This is a test of a bunch of text' * j
            else:
                line = 'Line: ' + str(i+1) + ' This is a test of a bunch of text'
            self.data.append({'text': line})


class TestApp(App):
    def build(self):
        return RV()


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

相关问题 更多 >