elyana
elyanaMarch 16, 2020, 9:24 p.m.

Drawer QML

В документации к Drawer Qml Type указано свойство position, но я так и не поняла как его применять, может кто-нибудь показать пример?
Также, при выдвижении drawer'a остальная часть экрана затемняется, как убрать эту тень я тоже не нашла. Были какие-то примеры с Overlay.model, но это не работает, а точнее, делает прозрачным весь drawer

We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.

Do you like it? Share on social networks!

25
Evgenii Legotckoi
  • March 17, 2020, 5:47 a.m.

Добрый день

position - это свойство, которое отвечает за то, насколько Drawer выдвинут, если там 1, то он полностью открыт, если 0, то полностью скрыт.
Если хотите изменить, откуда выдвигается Drawer, то нужно менять свойство edge

    elyana
    • March 17, 2020, 7:39 a.m.

    Я понимаю, что position это положение до и после, мне нужен пример синтаксиса. Я, например, писала:
    position: 0.3
    Но это не срабатывало

      Evgenii Legotckoi
      • March 17, 2020, 7:46 a.m.

      В документации этого не написано, но полагаю, что это readonly свойство, вы ничего не сможете туда установить, только считать.
      Для открытия и закрытия есть методы open() , close()

        elyana
        • March 17, 2020, 8:14 a.m.
        • (edited)

        Да, но как тогда поместить на экран часть drawer'a так, чтобы она выходила из-за границ окна, margin и padding не работают

          Evgenii Legotckoi
          • March 17, 2020, 8:15 a.m.
          • The answer was marked as a solution.

          Никак. Или писать свой собственный кастомный Drawer с нуля или пересмотреть задачу и подумать над иным решением.

            Evgenii Legotckoi
            • March 17, 2020, 8:17 a.m.

            Свойство position отвечает за обработку пальцами на экране, то есть насколько drawer был выдвинут, но не для фиксированного кастомного положения drawer на экране.

              Evgenii Legotckoi
              • March 17, 2020, 8:18 a.m.
              • (edited)

              Впрочем у меня есть мысль, Drawer наследован от объекта Popup, а он уже имеет свойство x, попробуйте изменить его, то есть координату x

              Drawer {
                  x: 50
              }
              
                elyana
                • March 17, 2020, 8:20 a.m.

                Пыталась написать что-то своё на javascript'e, но мне почему то постоянно выдавало ошибку "mouseXY is not defined", при вызове функции через onClicked(), и не важно, что там было изменение цвета, сообщение в консоль или же изменение координат. Не знаете, почему так происходит?

                  elyana
                  • March 17, 2020, 8:27 a.m.

                  Координаты, это первое, что я меняла -- бесполезно

                    Evgenii Legotckoi
                    • March 17, 2020, 8:27 a.m.

                    если onClicked вообще вызывалось, поскольку такого обработчика у Drawer нет

                      elyana
                      • March 17, 2020, 8:30 a.m.

                      В drawer'e была Button/MouseArea, оттуда и вызывался onClicked()

                        Evgenii Legotckoi
                        • March 17, 2020, 8:34 a.m.

                        тогда, без кода трудно что-то утверждать

                          Serj Demchenko
                          • March 17, 2020, 8:45 a.m.
                          • (edited)

                          Можно использовать как обычный компонент

                          ...
                          Drawer {
                                  id: expanderMenu
                                  width: window.width/3.5
                                  height: window.height
                                  }
                          ...
                          

                          или вы хотите переопределить чтобы он допустим сверху открывался?

                            elyana
                            • March 17, 2020, 8:56 a.m.
                            • (edited)

                            С edge у меня проблем нет, мне нужно, чтобы он торчал из-за границы окна, например, на 10-ю часть своего размера
                            Примерно так:

                              Serj Demchenko
                              • March 17, 2020, 9:15 a.m.

                              Так?

                                Drawer {
                                      id: drawer
                                      width:  window.width
                                      height:0.1 * window.height
                                      edge: Qt.BottomEdge
                              
                                  }
                              
                                Evgenii Legotckoi
                                • March 17, 2020, 9:17 a.m.
                                • (edited)

                                не думаю, что это будет правильным решением, вы просто устанавливаете высоту drawer, то есть скрытой части не будет совсем, а здесь нужно, чтобы 80 процентов того Drawer была за экраном. А у вас будет 100 процентов в экране

                                  Evgenii Legotckoi
                                  • March 17, 2020, 9:19 a.m.

                                  Кстати, если у вас Drawer снизу, то не пробовали установить координаты так

                                  Window {
                                      id: window
                                  
                                      Drawer {
                                          y: window.height - 50
                                      }
                                  
                                  }
                                  
                                    Serj Demchenko
                                    • March 17, 2020, 9:23 a.m.
                                    • (edited)

                                    Не получится так, drawer вписан в окно, можно попробовать сделать custom dialog и его прибиндить к окну

                                      elyana
                                      • March 17, 2020, 9:24 a.m.

                                      Изменение размера ничего не даст. Он всё равно на начальном этапе будет x:0 y:0

                                        Evgenii Legotckoi
                                        • March 17, 2020, 9:26 a.m.

                                        Тогда можете попытаться адаптировать для себя этот пример QML - Урок 019. Navigation Drawer в Qt Qml Android

                                        Он старый и в некоторых случаях работает криво, но вполне работоспособен

                                          elyana
                                          • March 17, 2020, 9:28 a.m.

                                          Спасибо, возможно, Popup будет работать как мне нужно...

                                            Serj Demchenko
                                            • March 17, 2020, 9:42 a.m.
                                            • (edited)

                                            Попробуйте так:

                                            import QtQuick 2.7
                                            import QtQuick.Controls 2.0
                                            import QtQuick.Dialogs 1.3
                                            
                                            ApplicationWindow {
                                                id: window
                                                Drawer {
                                                    id: drawer
                                                    width:  window.width
                                                    height:0.31 * window.height
                                            
                                                    edge: Qt.BottomEdge
                                                    onOpened:{
                                                        drawer.close()
                                                        popup.open()
                                            
                                                    }
                                                }
                                                Popup {
                                                    id: popup
                                                    x: 0
                                                    y: 100
                                                    width: window.width
                                                    height: window.height / 3
                                                    modal: true
                                                    focus: true
                                                    closePolicy: Popup.CloseOnEscape | Popup.CloseOnPressOutsideParent
                                                }
                                            }
                                            

                                            с y: поиграетесь и всё

                                              Serj Demchenko
                                              • March 17, 2020, 9:46 a.m.
                                              • (edited)

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

                                                elyana
                                                • March 17, 2020, 9:53 a.m.
                                                • (edited)

                                                Скорее всего, нужно вместо Window использовать Item: привязать его к верху экрана и уменьшить размер на 10%, и туда тогда засовывать drawer, который выдвигается снизу

                                                  Serj Demchenko
                                                  • March 17, 2020, 10:17 a.m.

                                                  можно еще как костыль:

                                                  import QtQuick 2.7
                                                  import QtQuick.Controls 2.0
                                                  import QtQuick.Dialogs 1.3
                                                  
                                                  ApplicationWindow {
                                                      id: window
                                                      width: 320
                                                      height: 240
                                                      x:500
                                                      y:500
                                                      Component.onCompleted: {
                                                          popup.setX(window.x)
                                                          popup.setY(window.y+popup.height*2.3);
                                                          // + запретить перетаскивание popup
                                                      }
                                                      Drawer {
                                                          id: drawer
                                                          width:  window.width
                                                          height:0.31 * window.height
                                                          edge: Qt.BottomEdge
                                                          onOpened:{
                                                              drawer.close()
                                                              popup.open()
                                                          }
                                                      }
                                                      Dialog {
                                                          id: popup
                                                          modality:Qt.NonModal
                                                          width: window.width
                                                          height: window.height / 3
                                                      }
                                                  }
                                                  
                                                  
                                                  

                                                    Comments

                                                    Only authorized users can post comments.
                                                    Please, Log in or Sign up
                                                    l
                                                    • laei
                                                    • April 23, 2024, 9:19 p.m.

                                                    C ++ - Test 004. Pointers, Arrays and Loops

                                                    • Result:10points,
                                                    • Rating points-10
                                                    l
                                                    • laei
                                                    • April 23, 2024, 9:17 p.m.

                                                    C++ - Тест 003. Условия и циклы

                                                    • Result:50points,
                                                    • Rating points-4
                                                    e
                                                    • ehot
                                                    • April 1, 2024, 2:29 a.m.

                                                    C++ - Тест 003. Условия и циклы

                                                    • Result:78points,
                                                    • Rating points2
                                                    Last comments
                                                    k
                                                    kmssrFeb. 9, 2024, 7:43 a.m.
                                                    Qt Linux - Lesson 001. Autorun Qt application under Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
                                                    Qt WinAPI - Lesson 007. Working with ICMP Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
                                                    EVA
                                                    EVADec. 25, 2023, 11:30 p.m.
                                                    Boost - static linking in CMake project under Windows Ошибка LNK1104 часто возникает, когда компоновщик не может найти или открыть файл библиотеки. В вашем случае, это файл libboost_locale-vc142-mt-gd-x64-1_74.lib из библиотеки Boost для C+…
                                                    J
                                                    JonnyJoDec. 25, 2023, 9:38 p.m.
                                                    Boost - static linking in CMake project under Windows Сделал всё по-как у вас, но выдаёт ошибку [build] LINK : fatal error LNK1104: не удается открыть файл "libboost_locale-vc142-mt-gd-x64-1_74.lib" Хоть убей, не могу понять в чём дел…
                                                    G
                                                    GvozdikDec. 19, 2023, 10:01 a.m.
                                                    Qt/C++ - Lesson 056. Connecting the Boost library in Qt for MinGW and MSVC compilers Для решения твой проблемы добавь в файл .pro строчку "LIBS += -lws2_32" она решит проблему , лично мне помогло.
                                                    Now discuss on the forum
                                                    G
                                                    GarApril 22, 2024, 5:46 p.m.
                                                    Clipboard Как скопировать окно целиком в clipb?
                                                    DA
                                                    Dr Gangil AcademicsApril 20, 2024, 7:45 p.m.
                                                    Unlock Your Aesthetic Potential: Explore MSC in Facial Aesthetics and Cosmetology in India Embark on a transformative journey with an msc in facial aesthetics and cosmetology in india . Delve into the intricate world of beauty and rejuvenation, guided by expert faculty and …
                                                    a
                                                    a_vlasovApril 14, 2024, 6:41 p.m.
                                                    Мобильное приложение на C++Qt и бэкенд к нему на Django Rest Framework Евгений, добрый день! Такой вопрос. Верно ли следующее утверждение: Любое Android-приложение, написанное на Java/Kotlin чисто теоретически (пусть и с большими трудностями) можно написать и на C+…
                                                    Павел Дорофеев
                                                    Павел ДорофеевApril 14, 2024, 2:35 p.m.
                                                    QTableWidget с 2 заголовками Вот тут есть кастомный QTableView с многорядностью проект поддерживается, обращайтесь
                                                    f
                                                    fastrexApril 4, 2024, 4:47 p.m.
                                                    Вернуть старое поведение QComboBox, не менять индекс при resetModel Добрый день! У нас много проектов в которых используется QComboBox, в версии 5.5.1, когда модель испускает сигнал resetModel, currentIndex не менялся. В версии 5.15 при resetModel происходит try…

                                                    Follow us in social networks