<bdo id='vflS4'></bdo><ul id='vflS4'></ul>

  • <i id='vflS4'><tr id='vflS4'><dt id='vflS4'><q id='vflS4'><span id='vflS4'><b id='vflS4'><form id='vflS4'><ins id='vflS4'></ins><ul id='vflS4'></ul><sub id='vflS4'></sub></form><legend id='vflS4'></legend><bdo id='vflS4'><pre id='vflS4'><center id='vflS4'></center></pre></bdo></b><th id='vflS4'></th></span></q></dt></tr></i><div id='vflS4'><tfoot id='vflS4'></tfoot><dl id='vflS4'><fieldset id='vflS4'></fieldset></dl></div>

    <small id='vflS4'></small><noframes id='vflS4'>

      1. <legend id='vflS4'><style id='vflS4'><dir id='vflS4'><q id='vflS4'></q></dir></style></legend><tfoot id='vflS4'></tfoot>

        Kivy - python - recycleview 行中的多个小部件

        时间:2023-10-09

        • <legend id='LHdXi'><style id='LHdXi'><dir id='LHdXi'><q id='LHdXi'></q></dir></style></legend>
                <tbody id='LHdXi'></tbody>

              <tfoot id='LHdXi'></tfoot>

                  <bdo id='LHdXi'></bdo><ul id='LHdXi'></ul>

                  <i id='LHdXi'><tr id='LHdXi'><dt id='LHdXi'><q id='LHdXi'><span id='LHdXi'><b id='LHdXi'><form id='LHdXi'><ins id='LHdXi'></ins><ul id='LHdXi'></ul><sub id='LHdXi'></sub></form><legend id='LHdXi'></legend><bdo id='LHdXi'><pre id='LHdXi'><center id='LHdXi'></center></pre></bdo></b><th id='LHdXi'></th></span></q></dt></tr></i><div id='LHdXi'><tfoot id='LHdXi'></tfoot><dl id='LHdXi'><fieldset id='LHdXi'></fieldset></dl></div>

                  <small id='LHdXi'></small><noframes id='LHdXi'>

                • 本文介绍了Kivy - python - recycleview 行中的多个小部件的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

                  问题描述

                  I would like to make a recycleview that has multiple labels in each recycleview row. In my specfic example I would like to have 3 labels in each row: 1 label containing the item index, one label containing an item from one dataset, and another label from another dataset

                  In this example (taken from the kivy examples) we have a recycleview where each row in the recycleview contains a single label:

                  from kivy.app import App
                  from kivy.lang import Builder
                  from kivy.uix.recycleview import RecycleView
                  from kivy.uix.recycleview.views import RecycleDataViewBehavior
                  from kivy.uix.label import Label
                  from kivy.properties import BooleanProperty
                  from kivy.uix.recycleboxlayout import RecycleBoxLayout
                  from kivy.uix.behaviors import FocusBehavior
                  from kivy.uix.recycleview.layout import LayoutSelectionBehavior
                  
                  Builder.load_string('''
                  <SelectableLabel>:
                      # Draw a background to indicate selection
                      canvas.before:
                          Color:
                              rgba: (.0, 0.9, .1, .3) if self.selected else (0, 0, 0, 1)
                          Rectangle:
                              pos: self.pos
                              size: self.size
                  <RV>:
                      viewclass: 'SelectableLabel'
                      SelectableRecycleBoxLayout:
                          default_size: None, dp(56)
                          default_size_hint: 1, None
                          size_hint_y: None
                          height: self.minimum_height
                          orientation: 'vertical'
                          multiselect: True
                          touch_multiselect: True
                  ''')
                  
                  
                  items_1= {'apple', 'banana', 'pear', 'pineapple'}
                  items_2= {'dog', 'cat', 'rat', 'bat'}
                  
                  class SelectableRecycleBoxLayout(FocusBehavior, LayoutSelectionBehavior,
                                                   RecycleBoxLayout):
                      ''' Adds selection and focus behaviour to the view. '''
                  
                  
                  class SelectableLabel(RecycleDataViewBehavior, Label):
                      ''' Add selection support to the Label '''
                      index = None
                      selected = BooleanProperty(False)
                      selectable = BooleanProperty(True)
                  
                      def refresh_view_attrs(self, rv, index, data):
                          ''' Catch and handle the view changes '''
                          self.index = index
                          return super(SelectableLabel, self).refresh_view_attrs(
                              rv, index, data)
                  
                      def on_touch_down(self, touch):
                          ''' Add selection on touch down '''
                          if super(SelectableLabel, self).on_touch_down(touch):
                              return True
                          if self.collide_point(*touch.pos) and self.selectable:
                              return self.parent.select_with_touch(self.index, touch)
                  
                      def apply_selection(self, rv, index, is_selected):
                          ''' Respond to the selection of items in the view. '''
                          self.selected = is_selected
                          if is_selected:
                              print("selection changed to {0}".format(rv.data[index]))
                          else:
                              print("selection removed for {0}".format(rv.data[index]))
                  
                  
                  class RV(RecycleView):
                      def __init__(self, **kwargs):
                          super(RV, self).__init__(**kwargs)
                          self.data = [{'text': str(x)} for x in items_1]
                  
                  
                  class TestApp(App):
                      def build(self):
                          return RV()
                  
                  if __name__ == '__main__':
                      TestApp().run()
                  

                  I would like each recycleview row to have 3 labels: first label is the index, second label is items_1 and third label is items_2. Like this:

                  0 apple dog

                  1 banana cat

                  2 pear rat

                  3 pineapple bat

                  Thank you!

                  解决方案

                  I was looking for a similar solution and could not find it. I do not think PalimPalim has really answered the question since I think the Ben t was looking for multiple label widgets treated as a single line.

                  In this case you use a custom widget for GridLayout and specify it's structure.

                  <SelectableLabel>:
                  # Draw a background to indicate selection
                  canvas.before:
                      Color:
                          rgba: (.0, 0.9, .1, .3) if self.selected else (0, 0, 0, 1)
                      Rectangle:
                          pos: self.pos
                          size: self.size
                  label1_text: 'label 1 text'
                  label2_text: 'label 2 text'
                  label3_text: 'label 3 text'
                  pos: self.pos
                  size: self.size
                  Label:
                      id: id_label1
                      text: root.label1_text
                  Label:
                      id: id_label2
                      text: root.label2_text
                  Label:
                      id: id_label3
                      text: root.label3_text
                  

                  In applying your data into the RV, you will need to restructure the dictionary to reflect the label layout

                  class RV(RecycleView):
                  def __init__(self, **kwargs):
                      super(RV, self).__init__(**kwargs)
                      paired_iter = zip(items_1, items_2)
                      self.data = []
                      for i1, i2 in paired_iter:
                          d = {'label2': {'text': i1}, 'label3': {'text': i2}}
                          self.data.append(d)
                  

                  Finally in the refresh_view_attrs, you will specify .label_text which is bound to each label, or you can use label id's.

                  def refresh_view_attrs(self, rv, index, data):
                      ''' Catch and handle the view changes '''
                      self.index = index
                      self.label1_text = str(index)
                      self.label2_text = data['label2']['text']
                      self.ids['id_label3'].text = data['label3']['text']  # As an alternate method of assignment
                      return super(SelectableLabel, self).refresh_view_attrs(
                          rv, index, data)
                  

                  The entire code is below:

                  from kivy.app import App
                  from kivy.lang import Builder
                  from kivy.uix.recycleview import RecycleView
                  from kivy.uix.recycleview.views import RecycleDataViewBehavior
                  from kivy.uix.label import Label
                  from kivy.uix.gridlayout import GridLayout
                  from kivy.properties import BooleanProperty
                  from kivy.uix.recycleboxlayout import RecycleBoxLayout
                  from kivy.uix.behaviors import FocusBehavior
                  from kivy.uix.recycleview.layout import LayoutSelectionBehavior
                  
                  Builder.load_string('''
                  <SelectableLabel>:
                      # Draw a background to indicate selection
                      canvas.before:
                          Color:
                              rgba: (.0, 0.9, .1, .3) if self.selected else (0, 0, 0, 1)
                          Rectangle:
                              pos: self.pos
                              size: self.size
                      label1_text: 'label 1 text'
                      label2_text: 'label 2 text'
                      label3_text: 'label 3 text'
                      pos: self.pos
                      size: self.size
                      Label:
                          id: id_label1
                          text: root.label1_text
                      Label:
                          id: id_label2
                          text: root.label2_text
                      Label:
                          id: id_label3
                          text: root.label3_text
                  
                  <RV>:
                      viewclass: 'SelectableLabel'
                      SelectableRecycleBoxLayout:
                          default_size: None, dp(56)
                          default_size_hint: 1, None
                          size_hint_y: None
                          height: self.minimum_height
                          orientation: 'vertical'
                          multiselect: True
                          touch_multiselect: True
                  ''')
                  
                  
                  items_1 = {'apple', 'banana', 'pear', 'pineapple'}
                  items_2 = {'dog', 'cat', 'rat', 'bat'}
                  
                  
                  class SelectableRecycleBoxLayout(FocusBehavior, LayoutSelectionBehavior,
                                                   RecycleBoxLayout):
                      ''' Adds selection and focus behaviour to the view. '''
                  
                  
                  class SelectableLabel(RecycleDataViewBehavior, GridLayout):
                      ''' Add selection support to the Label '''
                      index = None
                      selected = BooleanProperty(False)
                      selectable = BooleanProperty(True)
                      cols = 3
                  
                      def refresh_view_attrs(self, rv, index, data):
                          ''' Catch and handle the view changes '''
                          self.index = index
                          self.label1_text = str(index)
                          self.label2_text = data['label2']['text']
                          self.ids['id_label3'].text = data['label3']['text']  # As an alternate method of assignment
                          return super(SelectableLabel, self).refresh_view_attrs(
                              rv, index, data)
                  
                      def on_touch_down(self, touch):
                          ''' Add selection on touch down '''
                          if super(SelectableLabel, self).on_touch_down(touch):
                              return True
                          if self.collide_point(*touch.pos) and self.selectable:
                              return self.parent.select_with_touch(self.index, touch)
                  
                      def apply_selection(self, rv, index, is_selected):
                          ''' Respond to the selection of items in the view. '''
                          self.selected = is_selected
                          if is_selected:
                              print("selection changed to {0}".format(rv.data[index]))
                          else:
                              print("selection removed for {0}".format(rv.data[index]))
                  
                  
                  class RV(RecycleView):
                      def __init__(self, **kwargs):
                          super(RV, self).__init__(**kwargs)
                          paired_iter = zip(items_1, items_2)
                          self.data = []
                          for i1, i2 in paired_iter:
                              d = {'label2': {'text': i1}, 'label3': {'text': i2}}
                              self.data.append(d)
                          # can also be performed in a complicated one liner for those who like it tricky
                          # self.data = [{'label2': {'text': i1}, 'label3': {'text': i2}} for i1, i2 in zip(items_1, items_2)]
                  
                  
                  class TestApp(App):
                      def build(self):
                          return RV()
                  
                  if __name__ == '__main__':
                      TestApp().run()
                  

                  这篇关于Kivy - python - recycleview 行中的多个小部件的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持html5模板网!

                  上一篇:buildozer android NDK没有下载Ubuntu 下一篇:如何使用 Pyinstaller 打包的 Kivy Python 应用程序在

                  相关文章

                  最新文章

                  1. <legend id='ocDGi'><style id='ocDGi'><dir id='ocDGi'><q id='ocDGi'></q></dir></style></legend>
                    1. <small id='ocDGi'></small><noframes id='ocDGi'>

                        <bdo id='ocDGi'></bdo><ul id='ocDGi'></ul>

                      <i id='ocDGi'><tr id='ocDGi'><dt id='ocDGi'><q id='ocDGi'><span id='ocDGi'><b id='ocDGi'><form id='ocDGi'><ins id='ocDGi'></ins><ul id='ocDGi'></ul><sub id='ocDGi'></sub></form><legend id='ocDGi'></legend><bdo id='ocDGi'><pre id='ocDGi'><center id='ocDGi'></center></pre></bdo></b><th id='ocDGi'></th></span></q></dt></tr></i><div id='ocDGi'><tfoot id='ocDGi'></tfoot><dl id='ocDGi'><fieldset id='ocDGi'></fieldset></dl></div>

                      <tfoot id='ocDGi'></tfoot>