0

0

Kivy ScrollView 子控件不显示的常见原因及解决方案

霞舞

霞舞

发布时间:2026-01-22 19:53:12

|

851人浏览过

|

来源于php中文网

原创

Kivy ScrollView 子控件不显示的常见原因及解决方案

本文详解 kivy 中 scrollview 子控件(如 label、gridlayout)无法显示的根本原因:错误地创建了新 app 实例而非调用当前运行实例的方法,导致 ui 更新失效。

在 Kivy 开发中,ScrollView 是展示长内容的常用容器,但其子控件“莫名空白”是新手高频踩坑点。你提供的代码中,右侧 ScrollView 始终为空,看似布局或尺寸问题,实则根源在于 对象作用域与实例引用错误

关键问题出在 SelectableLabel.apply_selection() 方法中这一行:

MyApp().display_info(self.data)  # ❌ 错误!每次新建一个 MyApp 实例

该语句每次都会构造一个全新的 MyApp() 对象——它独立于当前正在运行的 GUI 应用,其内部的 self.info_layout 是全新未挂载的空容器,对主窗口中的 ScrollView 完全无影响。因此,无论 print(data) 是否输出成功,display_info() 的 UI 操作都发生在“影子应用”中,真实界面自然毫无反应。

✅ 正确做法是获取当前正在运行的 App 实例,使用 Kivy 官方推荐的单例访问方式:

from kivy.app import App

# 替换原 apply_selection 中的错误调用:
def apply_selection(self, rv, index, is_selected):
    self.selected = is_selected
    if is_selected:
        App.get_running_app().display_info(self.data)  # ✅ 正确:获取真实运行实例

此外,还需确保 ScrollView 内部子控件能正确触发高度自适应。你已为 GridLayout 设置了 size_hint_y=None 和 height=500,这虽可临时生效,但更健壮的做法是绑定 minimum_height 并启用 scroll_type:

多墨智能
多墨智能

多墨智能 - AI 驱动的创意工作流写作工具

下载
# 在 build() 中优化 info_layout 初始化:
self.info_layout = GridLayout(
    cols=1,
    size_hint_y=None,
    height=0,  # 初始高度设为 0,后续由 minimum_height 驱动
)
self.info_layout.bind(minimum_height=self.info_layout.setter('height'))

同时,在 KV 字符串中为 ScrollView 显式启用滚动行为(可选但推荐):

ScrollView:
    size_hint_x: 0.65
    do_scroll_x: False
    do_scroll_y: True

⚠️ 注意事项:

  • 永远避免在回调中通过 MyApp() 构造新实例操作 UI;统一使用 App.get_running_app();
  • ScrollView 要显示内容,其直接子控件必须设置 size_hint_y=None 且明确绑定 height(通常通过 minimum_height);
  • RecycleView 的 data 更新不会自动触发外部组件刷新,需显式调用业务逻辑(如本例的 display_info)。

修正后,点击左侧单词即可实时在右侧 ScrollView 中显示对应释义,UI 响应完全正常。这是 Kivy 事件驱动与对象生命周期管理的经典实践案例。

相关专题

更多
python中print函数的用法
python中print函数的用法

python中print函数的语法是“print(value1, value2, ..., sep=' ', end=' ', file=sys.stdout, flush=False)”。本专题为大家提供print相关的文章、下载、课程内容,供大家免费下载体验。

185

2023.09.27

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

278

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1490

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

621

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

551

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

566

2024.04.29

go语言字符串相关教程
go语言字符串相关教程

本专题整合了go语言字符串相关教程,阅读专题下面的文章了解更多详细内容。

166

2025.07.29

Golang 性能分析与pprof调优实战
Golang 性能分析与pprof调优实战

本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

9

2026.01.22

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Java 教程
Java 教程

共578课时 | 49.3万人学习

国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 1.0万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号