elyana
elyana16 березня 2020 р. 21:24

Drawer QML

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

Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Стабільний хостинг, на якому розміщується соціальна мережа EVILEG. Для проектів на Django радимо VDS хостинг.

Вам це подобається? Поділіться в соціальних мережах!

25
Evgenii Legotckoi
  • 17 березня 2020 р. 05:47

Добрый день

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

    elyana
    • 17 березня 2020 р. 07:39

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

      Evgenii Legotckoi
      • 17 березня 2020 р. 07:46

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

        elyana
        • 17 березня 2020 р. 08:14
        • (відредаговано)

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

          Evgenii Legotckoi
          • 17 березня 2020 р. 08:15
          • Відповідь була позначена як рішення.

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

            Evgenii Legotckoi
            • 17 березня 2020 р. 08:17

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

              Evgenii Legotckoi
              • 17 березня 2020 р. 08:18
              • (відредаговано)

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

              Drawer {
                  x: 50
              }
              
                elyana
                • 17 березня 2020 р. 08:20

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

                  elyana
                  • 17 березня 2020 р. 08:27

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

                    Evgenii Legotckoi
                    • 17 березня 2020 р. 08:27

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

                      elyana
                      • 17 березня 2020 р. 08:30

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

                        Evgenii Legotckoi
                        • 17 березня 2020 р. 08:34

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

                          Serj Demchenko
                          • 17 березня 2020 р. 08:45
                          • (відредаговано)

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

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

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

                            elyana
                            • 17 березня 2020 р. 08:56
                            • (відредаговано)

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

                              Serj Demchenko
                              • 17 березня 2020 р. 09:15

                              Так?

                                Drawer {
                                      id: drawer
                                      width:  window.width
                                      height:0.1 * window.height
                                      edge: Qt.BottomEdge
                              
                                  }
                              
                                Evgenii Legotckoi
                                • 17 березня 2020 р. 09:17
                                • (відредаговано)

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

                                  Evgenii Legotckoi
                                  • 17 березня 2020 р. 09:19

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

                                  Window {
                                      id: window
                                  
                                      Drawer {
                                          y: window.height - 50
                                      }
                                  
                                  }
                                  
                                    Serj Demchenko
                                    • 17 березня 2020 р. 09:23
                                    • (відредаговано)

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

                                      elyana
                                      • 17 березня 2020 р. 09:24

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

                                        Evgenii Legotckoi
                                        • 17 березня 2020 р. 09:26

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

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

                                          elyana
                                          • 17 березня 2020 р. 09:28

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

                                            Serj Demchenko
                                            • 17 березня 2020 р. 09:42
                                            • (відредаговано)

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

                                            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
                                              • 17 березня 2020 р. 09:46
                                              • (відредаговано)

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

                                                elyana
                                                • 17 березня 2020 р. 09:53
                                                • (відредаговано)

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

                                                  Serj Demchenko
                                                  • 17 березня 2020 р. 10:17

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

                                                  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
                                                      }
                                                  }
                                                  
                                                  
                                                  

                                                    Коментарі

                                                    Only authorized users can post comments.
                                                    Please, Log in or Sign up
                                                    sf

                                                    C++ - Тест 004. Указатели, Массивы и Циклы

                                                    • Результат:90бали,
                                                    • Рейтинг балів8
                                                    МВ

                                                    Qt - Тест 001. Сигналы и слоты

                                                    • Результат:68бали,
                                                    • Рейтинг балів-1
                                                    ЛС

                                                    C++ - Тест 001. Первая программа и типы данных

                                                    • Результат:53бали,
                                                    • Рейтинг балів-4
                                                    Останні коментарі
                                                    A
                                                    ALO1ZE19 жовтня 2024 р. 08:19
                                                    Читалка файлів fb3 на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
                                                    ИМ
                                                    Игорь Максимов05 жовтня 2024 р. 07:51
                                                    Django - Урок 064. Як написати розширення для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
                                                    d
                                                    dblas505 липня 2024 р. 11:02
                                                    QML - Урок 016. База даних SQLite та робота з нею в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                                                    k
                                                    kmssr08 лютого 2024 р. 18:43
                                                    Qt Linux - Урок 001. Автозапуск програми Qt під Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
                                                    АК
                                                    Анатолий Кононенко05 лютого 2024 р. 01:50
                                                    Qt WinAPI - Урок 007. Робота з ICMP Ping в Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
                                                    Тепер обговоріть на форумі
                                                    J
                                                    JacobFib17 жовтня 2024 р. 03:27
                                                    добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
                                                    ИМ
                                                    Игорь Максимов03 жовтня 2024 р. 04:05
                                                    Реализация навигации по разделам Спасибо Евгений!
                                                    JW
                                                    Jhon Wick01 жовтня 2024 р. 15:52
                                                    Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…
                                                    КГ
                                                    Кирилл Гусарев27 вересня 2024 р. 09:09
                                                    Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
                                                    F
                                                    Fynjy22 липня 2024 р. 04:15
                                                    при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …

                                                    Слідкуйте за нами в соціальних мережах