如何在Kivy ScrollView中滚动GridLayout?

10

目前这是我不可滚动的kv代码:

BoxLayout:
    id: bl
    orientation: 'vertical'
    padding: 10, 10
    row_default_height: '48dp'
    row_force_default: True
    spacing: 10, 10

    GridLayout:
        id: layout_content
        cols: 1
        row_default_height: '20dp'
        row_force_default: True
        spacing: 0, 0
        padding: 0, 0

        Label:
            text: 'You don''t have any downloads. Please add new download from Home screen'

你如何使上面的kv代码可滚动?我知道Kivy ScrollView只接受一个子项,我已经将GridLayout作为新ScrollView的子项,但不起作用。有什么建议吗?
2个回答

22
根据ScrollView的文档,您必须禁用至少一个ScrollView子项的size_hint属性: (参见此处)
<Controller>:
    layout_content: layout_content
    BoxLayout:
        id: bl
        orientation: 'vertical'
        padding: 10, 10
        row_default_height: '48dp'
        row_force_default: True
        spacing: 10, 10
        ScrollView:
            size: self.size
            GridLayout:
                id: layout_content
                size_hint_y: None
                cols: 1
                row_default_height: '20dp'
                row_force_default: True
                spacing: 0, 0
                padding: 0, 0

                Label:
                    text: "Lorem ipsum dolor sit amet"

并将布局大小绑定以适应自身:

# main.py

class Controller(FloatLayout):
    layout_content=ObjectProperty(None)

    def __init__(self, **kwargs):
        super(Controller, self).__init__(**kwargs)
        self.layout_content.bind(minimum_height=self.layout_content.setter('height'))

3
几乎就是了:细节中隐藏着魔鬼,特别是在 kv 方面 :) - synw
4
你确定这是正确的吗?我收到了一个错误消息:Traceback (most recent call last): File "main.py", line 24, in <module> edlApp().run() File "/usr/lib/python2.7/dist-packages/kivy/app.py", line 766, in run root = self.build() File "main.py", line 20, in build return Controller() File "main.py", line 16, in __init__ self.layout_content.bind(minimum_height=self.layout_content.setter('height')) AttributeError: 'NoneType' object has no attribute 'bind' - amd
应该是 ScrollView: <- 冒号要加 - Rockbot
一种更简单的方法是在kv文件中将高度绑定到最小高度:height: self.minimum_height。(参见https://stackoverflow.com/a/47600781/6362595) - fgoudra
对于任何想要水平滚动而不是垂直滚动的ScrollView,使用 width: self.minimum_width - Drake P
显示剩余3条评论

0

修复了滚动视图在最大化窗口时无法调整长度的问题。对于那些不需要kv的人来说,这是有效的解决方案。

kivy.require('1.11.1')
      
class ScrollTest(ScrollView):
    def __init__(self,**kwargs):
        super().__init__(**kwargs)
    
        Window.bind(on_maximize=self.testing)
        
        self.size_hint = (1,None)
        self.pos_hint = {'center_x':0.5,'top': 1}
        self.size = (Window.width,Window.height)

        self.inside = GridLayout()
        self.inside.cols = 1
        self.inside.size_hint_y= None
        self.inside.spacing = 10
        
        self.inside.bind(minimum_height=self.inside.setter('height'))#checks when window maximized
        
        for i in range(1,5):
            self.submit = Button(text='something',size_hint_y=None, height=40)
            self.submit.bind(on_press=self.wPressed)
            self.inside.add_widget(self.submit)
        
        self.add_widget(self.inside)
        
    def wPressed(self,instance):
        self.submit = Button(text='something',size_hint_y=None, height=40)
        self.submit.bind(on_press=self.wPressed)
        self.inside.add_widget(self.submit)
            
    def testing(self,instance):
        self.size= (Window.width,Window.height)

        
class MyApp(App):
    def build(self):
        self.screen_manager = ScreenManager()
        
        '''Creation of login screen'''
        self.login_page = ScrollTest()
        screen = Screen(name= 'Login')
        screen.add_widget(self.login_page)
        self.screen_manager.add_widget(screen)
        
        return self.screen_manager


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

从kivy.uix.scrollview导入ScrollView 从kivy.core.window导入Window 从kivy.uix.gridlayout导入GridLayout 从kivy.uix.button导入Button - BananaMaster

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接