在kivy中将文本与ScrollView中的标签边缘对齐

Posted

技术标签:

【中文标题】在kivy中将文本与ScrollView中的标签边缘对齐【英文标题】:Align text to edge of Label in ScrollView in kivy 【发布时间】:2016-05-08 01:33:40 【问题描述】:

我正在尝试使标签水平滚动并希望 halign:"rightvalign:middle 按照以下代码

ScrollView:

  Label:    
    id:maindisplay
    text:"0"
    font_size:"50sp"
    text_size: None ,self.height[1] #  Set the text wrap box height
    size_hint_x:None
    width: self.texture_size[0]

#Following part is not working
    halign: 'right'
    valign: 'middle'

【问题讨论】:

怎么不工作了?预期的结果是什么? 它不是 align 和 valign ......它水平滚动......但我们希望文本在右侧,为此我们使用了 halign 和 valign ,它们没有给出输出 使用canvas.before: Color: rgba:1,0,0,1 Rectangle: pos: self.pos size: self.size 确保您的标签确实在您期望的位置,当我设置text:"1\n123" 时,它显然垂直居中且右对齐。 也许text_size: self.width, self.height size_hint_x: 1是你想要的? 只需检查已编辑的问题......你就会得到我想要的 【参考方案1】:

这里的关键点是文本的宽度。如果设置为None,则不受约束,如果文本比父级宽,则可以滚动。但是,如果文本只需要父级宽度的一小部分,则文本将在标签内居中(尽管多行仍将右对齐)。另一方面,如果text_size 静态设置为有限值,则不适合的文本将自动换行并且永远不会滚动。 hacky 的解决方案是设置 text_size: 8000, self.height (非常广泛,不太可能发生)。这允许滚动,但很丑陋(并且可能会意外滚动到没有显示任何内容的区域)。

相反,我们动态更改text_width。当text 发生变化时,我们首先移除宽度约束。然后我们让标签更新其内容,并将text_size 设置为与文本一样宽,但至少与父级一样宽。

其他设置确保标签本身至少与父标签 (width) 一样宽,并且 ScrollView 从其右边缘开始 (scroll_x:1)

这是一个完整的例子:

from kivy.app import App
from kivy.lang import Builder
from kivy.config import Config
from kivy.clock import Clock
from kivy.properties import StringProperty, NumericProperty

kv = '''ScrollView:
  scroll_x: 1
  Label:
    canvas.before:
      Color:
        rgba:1,0,0,1
      Rectangle:
        pos: self.parent.pos
        size: self.size
    id:maindisplay
    text:"2"
    font_size:"50sp"
    text_size: None, self.height
    size_hint_x: None
    width:  max(self.texture_size[0], self.parent.width)
    halign: 'right'
    valign: 'middle'
    on_text: app.txt_cb(*args)
'''

class QApp(App):
    txt = StringProperty("1")
    num = NumericProperty(0)

    def add_string(self, dt=0):
        self.num += 1
        self.txt += "%i" % self.num
        self.root.ids.maindisplay.text = self.txt

    def txt_cb(self, obj, text):
        obj.text_size = (None, obj.height)
        obj.texture_update()
        obj.text_size = (max(obj._label.content_width, obj.parent.width), obj.height)

    def build(self):
        Clock.schedule_once(lambda dt:self.txt_cb(self.root.ids.maindisplay, ""), 0)
        Clock.schedule_interval(self.add_string, .5)
        return Builder.load_string(kv)

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

【讨论】:

试试这个...等一下 它不工作......我只想要一个可滚动的标签,它的开始文本从右边......而不是从左边开始,它应该水平滚动...... 我让它从右边开始文本,但现在它不再滚动了 你有什么想法让文本在右侧并使其也滚动 不,它仍然没有滚动...我编码如下 ScrollView:scroll_x:1 标签:canvas.before:颜色:rgba:1,0,0,1 矩形:pos:self.parent .pos size: self.size id:maindisplay text:"1899897723" font_size:"50sp" text_size: max(self._label.content_width, self.parent.width), self.height size_hint_x: None width: max(self.texture_size [0], self.parent.width) halign: 'right' valign: 'middle'

以上是关于在kivy中将文本与ScrollView中的标签边缘对齐的主要内容,如果未能解决你的问题,请参考以下文章

Kivy ScrollView 用于文本段落

TextInput中的kivy ScrollView实现

Kivy Label 添加文本而不重叠

Kivy Scrollview 自动滚动到新文本和行消失

Kivy Scrollview 自动滚动到新文本。防止向上滚动

将文本从文本输入传递到 Kivy 中的标签