Михаил Сермяжко
Sept. 21, 2019, 9:43 p.m.

Как в QML прокручивать ListView из кода

Добрый день.
Как в QML прокручивать ListView из кода?

2

Do you like it? Share on social networks!

1
Михаил Сермяжко
  • Sept. 21, 2019, 10:51 p.m.
  • The answer was marked as a solution.

Так работает

  1. import QtQuick 2.7
  2. import QtQuick.Window 2.2
  3. import QtQuick.Controls 2.0
  4.  
  5. Window {
  6. id: demo
  7. width: 800
  8. height: 600
  9. visible: true
  10. color: "#ff303030"
  11.  
  12. property color accentColor: "#ff00b374"
  13.  
  14. Rectangle {
  15. width: parent.width/2-32
  16. height: parent.height-32
  17. x: 16
  18. y: 16
  19.  
  20. color: accentColor
  21. clip: true
  22. ListView {
  23. id: listView
  24. width: parent.width
  25. height: parent.height
  26.  
  27. // When scroll end align to the nearest item
  28. snapMode: ListView.SnapToItem
  29. // Clip painting to his own bounding rectangle to avoid display
  30. // data outside specified size during flick
  31. clip: true
  32. model: 100
  33.  
  34. // Increase Flick speed
  35. maximumFlickVelocity: 10000
  36. cacheBuffer:1000
  37.  
  38. ScrollBar.vertical: ScrollBar {
  39. id: verticalScrollBar
  40. active: pressed || listView.moving || listUp.pressed || listDown.pressed
  41. orientation: Qt.Vertical
  42. opacity: active ? 1:0
  43. Behavior on opacity {NumberAnimation {duration: 500}}
  44.  
  45. contentItem: Rectangle {
  46. implicitWidth: 4
  47. radius:2
  48. implicitHeight: parent.height
  49. color: accentColor
  50. }
  51. }
  52.  
  53. delegate: Rectangle {
  54. id: lineRectangle
  55. height: 32
  56. width: listView.width
  57.  
  58. // Change color based on index number for better readability
  59. color: (index & 1)? "#ffefefef" : "#ffffffff"
  60.  
  61. Text {
  62. id: textField
  63. height: parent.height
  64. width: parent.width
  65. color: listView.currentIndex === index? accentColor:"#ff000000"
  66. font.pixelSize: 16
  67. horizontalAlignment : Text.AlignHCenter
  68. text: "Element " + (index+1)
  69. }
  70. }
  71. }
  72. }
  73.  
  74. // Up Button to move list up
  75. Rectangle {
  76. id: upButton
  77.  
  78. height: 256
  79. width: height//parent.width
  80. radius: height/2
  81.  
  82. x: parent.width*3/4-width/2
  83. y: parent.height*1/4-height/2
  84.  
  85. color: "#ffffffff"
  86.  
  87. Text {
  88. text: "Up"
  89. anchors.centerIn: parent
  90. color: listUp.pressed? demo.accentColor: "#ff000000"
  91. font.pixelSize: 64
  92. }
  93.  
  94. MouseArea {
  95. anchors.fill: parent
  96. id: listUp
  97.  
  98. SmoothedAnimation {
  99. target: listView
  100. property: "contentY"
  101. running: listUp.pressed
  102. velocity: 1000
  103. to: 0
  104. }
  105. onReleased: {
  106. if (!listView.atYBeginning)
  107. listView.flick(0, 1000)
  108. }
  109. }
  110. }
  111.  
  112. // Down Button to move list down
  113. Rectangle {
  114. id: downButton
  115. height: upButton.height
  116. width: upButton.width
  117. radius: upButton.radius
  118. color: upButton.color
  119.  
  120. x: parent.width*3/4-width/2
  121. y: parent.height*3/4-height/2
  122.  
  123. Text {
  124. text: "Down"
  125. anchors.centerIn: parent
  126. color: listDown.pressed? demo.accentColor: "#ff000000"
  127. font.pixelSize: 64
  128. }
  129.  
  130. MouseArea {
  131. anchors.fill: parent
  132. id: listDown
  133.  
  134. SmoothedAnimation {
  135. target: listView
  136. property: "contentY"
  137. running: listDown.pressed
  138. to: listView.contentHeight - listView.height
  139. velocity: 1000
  140. }
  141. onReleased: {
  142. if (!listView.atYEnd)
  143. listView.flick(0, -1000)
  144. }
  145. }
  146. }
  147. }
  148.  

    Comments

    Only authorized users can post comments.
    Please, Log in or Sign up
    • Last comments
    • AK
      April 1, 2025, 11:41 a.m.
      Добрый день. В данный момент работаю над проектом, где необходимо выводить звук из программы в определенное аудиоустройство (колонки, наушники, виртуальный кабель и т.д). Пишу на Qt5.12.12 поско…
    • Evgenii Legotckoi
      March 9, 2025, 9:02 p.m.
      К сожалению, я этого подсказать не могу, поскольку у меня нет необходимости в обходе блокировок и т.д. Поэтому я и не задавался решением этой проблемы. Ну выглядит так, что вам действитель…
    • VP
      March 9, 2025, 4:14 p.m.
      Здравствуйте! Я устанавливал Qt6 из исходников а также Qt Creator по отдельности. Все компоненты, связанные с разработкой для Android, установлены. Кроме одного... Когда пытаюсь скомпилиров…
    • ИМ
      Nov. 22, 2024, 9:51 p.m.
      Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
    • Evgenii Legotckoi
      Oct. 31, 2024, 11:37 p.m.
      Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup