python - Kivy Scrollview 的变色问题
问题描述
我在按钮之间创建了一些简单的线条,scrollview
但是当您在各个位置上下拖动滚动条时,线条的亮度似乎会波动。
当您将对象的高度设置在scrollview
501 到 999 像素之间时,会出现此问题。但是,当您将对象的高度更改为scrollview
500 或 1000 像素时,问题就会停止并且颜色保持一致。我需要红色线条在所有行中保持一致,无论高度是多少scrollview
。
有谁知道是什么导致了这个问题以及如何解决它?
编辑:我在 2019 年 7 月 22 日用更新的代码和描述编辑了这篇文章,更好地演示了明显的错误。请参阅下面的代码和屏幕截图。
这是线条开始变暗的图像:
这是拖动滚动条后线条变为更亮颜色的图像:
from kivy.app import App
from kivy.uix.floatlayout import FloatLayout
from kivy.lang import Builder
from kivy.uix.button import Button
from kivy.graphics import Line, InstructionGroup, Canvas, CanvasBase, Color, Rectangle
Builder.load_string("""
<ButtonsApp>:
ScrollView:
id: sv
size_hint: None, None
pos: 205, 0
size: 900, 700 #If you change the height to 700 pixels, the line colors will darken and brighten as you drag the scroll bar up and down...
#Alternatively, if you change the height to 500 pixels, the line colors stay consistent as you drag the scroll bar..
scroll_type: ['bars']
scroll_wheel_distance: 20
bar_width: 8
bar_inactive_color: .55, .55, .55, 1
bar_color: .663, .663, .663, 1
canvas.before:
Color:
rgba: 0, .5, 1, 1
group: 'b'
Rectangle:
size: 0, 0
group: 'b'
GridLayout:
id: container
cols: 6
height: self.minimum_height
size_hint: None, None
do_scroll_x: False
""")
class ButtonsApp(App, FloatLayout):
def build(self):
y = 1 #we need to use this variable for dynamic ID creation
start_pixel = 0
for i in range(0, 200):
L1 = Button(text="row = " + str(y), font_size=12, halign='left', valign='middle', size_hint_x=None, width=60, background_color=[0, 0, 0, 1],
id=str(y), color=[.92, .92, .92, 1])
L2 = Button(text="", font_size=12, halign='left', valign='middle', size_hint=[None, None], width=63, height=40, background_color=[0, 0, 0, 1],
id=str(y), color=[.92, .92, .92, 1])
L3 = Button(text="22" + str(y), font_size=12, halign='left', valign='middle', size_hint_x=None, width=330, background_color=[0, 0, 0, 1],
id=str(y), color=[.92, .92, .92, 1])
L4 = Button(text="33" + str(y), font_size=12, halign='left', valign='middle', size_hint_x=None, width=118, background_color=[0, 0, 0, 1],
id=str(y), color=[.92, .92, .92, 1])
L5 = Button(text="Test Description" + str(y), font_size=12, halign='left', valign='middle', size_hint_x=None, width=122, background_color=[0, 0, 0, 1],
id=str(y), color=[.92, .92, .92, 1])
L6 = Button(text="Test Description" + str(y), font_size=12, halign='left', valign='middle', size_hint_x=None, width=118, background_color=[0, 0, 0, 1],
id=str(y), color=[.92, .92, .92, 1])
with self.ids.container.canvas.after:
Color(1, 0, 0, 1)
Line(points=(L1.pos[0], L1.pos[1] + start_pixel, L1.pos[0] + 900, L1.pos[1] + start_pixel), width=1)
#bind text_size to size so that halign and valign work properly on button created above
L1.bind(size=L1.setter('text_size'))
L2.bind(size=L2.setter('text_size'))
L3.bind(size=L3.setter('text_size'))
L4.bind(size=L3.setter('text_size'))
L5.bind(size=L3.setter('text_size'))
L6.bind(size=L3.setter('text_size'))
#add the button to grid layout
self.ids.container.add_widget(L1)
self.ids.container.add_widget(L2)
self.ids.container.add_widget(L3)
self.ids.container.add_widget(L4)
self.ids.container.add_widget(L5)
self.ids.container.add_widget(L6)
y = y + 1
start_pixel = start_pixel + 40
return self
if __name__ == "__main__":
ButtonsApp().run()
解决方案
颜色没有改变,但是Line
您正在绘制的内容被Button
小部件覆盖。为什么它发生在列表的中途Buttons
,我不知道。但是您可以使用canvas.after
. 改变:
with self.ids.container.canvas:
到:
with self.ids.container.canvas.after:
推荐阅读
- angular - WebStorm 没有设置环境变量
- javascript - ES6 GroupBy 2 或更多
- vba - 在 Excel VBA 中运行相同的代码两次时无法获取 OLEObjects 属性错误
- mysql-workbench - 如何确定 MySQL Workbench 中的当前分隔符?
- php - Vue.js 和 Laravel - 将 vuejs 与 laravel 集成后不显示图像
- python-2.7 - Caffe2/detectron infer_simple 没有检测到任何物体
- vue.js - 如何动态更改 vuetify 菜单的方向
- websocket - 使用消息间放气更好的 websocket 压缩
- postgresql - 如何将值从表 A 复制到 B 并在 A 中插入对 B 的引用?
- angular - 无法将值分配给角度自动完成模型