Михаил Сермяжко
Oct. 9, 2019, 2:39 p.m.

Как в QML в ComboBox сделать выпадающий список по ширине текста

ComboBox

Добрый день.
Как в QML в ComboBox сделать выпадающий список по ширине самого длинного текста?

3

Do you like it? Share on social networks!

6
Evgenii Legotckoi
  • Oct. 9, 2019, 3:13 p.m.

Добрый день!

У ComboBox в Quick Controls 2 есть свойство delegate для выпадающенго меню. Нужно в нём настраивать ширину. Я думаю, что можно пройтись по всей модели, найти наиболее длинный текст, подсчитать необходимую ширину и задать эту ширину для делегата.

    t
    • Oct. 9, 2019, 3:22 p.m.

    Как пройтись по модели? Я не нашёл как это сделать? Получается нужно скрипт писать? В Qt Widgets есть свойств несколько для выравнивания ширины по макс значению, здесь ничего такого нет? Тем более, что делегат кроме текста может быть чем угодно. Нужно его видимо ещё правильно написать, чтобы выпадающий список автоматом расширился?

      Михаил Сермяжко
      • Oct. 9, 2019, 3:27 p.m.

      Нашел такого делегата, но у него почему текст не виден, и не могу понять как задать цвет текста.
      Помогите пожалуйста настроить этот делегат

      1. delegate: ItemDelegate {
      2. //width: comboBoxProfilOptions.width
      3. text: text
      4. //text: control.textRole ? (Array.isArray(comboBoxProfilOptions.model) ? modelData[comboBoxProfilOptions.textRole] : model[comboBoxProfilOptions.textRole]) : modelData
      5. font.weight: comboBoxProfilOptions.currentIndex === index ? Font.DemiBold : Font.Normal
      6. font.family: comboBoxProfilOptions.font.family
      7. font.pointSize: comboBoxProfilOptions.font.pointSize
      8. highlighted: comboBoxProfilOptions.highlightedIndex === index
      9. hoverEnabled: comboBoxProfilOptions.hoverEnabled
      10. }
        Evgenii Legotckoi
        • Oct. 9, 2019, 3:28 p.m.

        Да. Делегат можно написать как угодно, там и изображения могут быть и чёрт знает что.

        У ComboBox есть свойство model. Нужно обратиться к нему и через индекс пройтись по всем элементам, выбирая текст, или что-то там ещё у вас может быть, подсчитать предполагаемую максимальную длину, а потом задать ширину в делегате.
        Это как я себе это представляю.

          Evgenii Legotckoi
          • Oct. 9, 2019, 3:29 p.m.
          • (edited)

          Прямо сейчас не могу это проверить или накидать пример, на данный момент на работе занят своими задачами.

            Михаил Сермяжко
            • Oct. 9, 2019, 4:04 p.m.
            • (edited)

            Сделал так, но теперь не меняется CurrentIndex

            1. delegate: ItemDelegate {
            2. width: comboBoxProfilOptions.width
            3. height: 25
            4. highlighted: comboBoxProfilOptions.highlightedIndex === index
            5. hoverEnabled: comboBoxProfilOptions.hoverEnabled
            6. onClicked: {
            7. comboBoxProfilOptions.currentIndex = index
            8. comboBoxProfilOptions.t = text1
            9. console.log("index:" + index)
            10. console.log("text:" + text)
            11. }
            12. Rectangle{
            13. anchors.fill: parent
            14. border.width: 1
            15. border.color: "black"
            16. color: "#00000000"
            17. }
            18.  
            19. Label{
            20. x: 3
            21. anchors.verticalCenter: parent.verticalCenter
            22. width: parent.width
            23. text: text1
            24. font.pixelSize: comboBoxProfilOptions.font.pixelSize
            25. //color: "red"
            26. }
            27. }

              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