elyana
elyanaНаурыз 16, 2020, 9:24 Т.Қ.

Drawer QML

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

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

Ол саған ұнайды ма? Әлеуметтік желілерде бөлісіңіз!

25
Evgenii Legotckoi
  • Наурыз 17, 2020, 5:47 Т.Ж.

Добрый день

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

    elyana
    • Наурыз 17, 2020, 7:39 Т.Ж.

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

      Evgenii Legotckoi
      • Наурыз 17, 2020, 7:46 Т.Ж.

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

        elyana
        • Наурыз 17, 2020, 8:14 Т.Ж.
        • (өңделген)

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

          Evgenii Legotckoi
          • Наурыз 17, 2020, 8:15 Т.Ж.
          • Жауап шешім ретінде белгіленді.

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

            Evgenii Legotckoi
            • Наурыз 17, 2020, 8:17 Т.Ж.

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

              Evgenii Legotckoi
              • Наурыз 17, 2020, 8:18 Т.Ж.
              • (өңделген)

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

              Drawer {
                  x: 50
              }
              
                elyana
                • Наурыз 17, 2020, 8:20 Т.Ж.

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

                  elyana
                  • Наурыз 17, 2020, 8:27 Т.Ж.

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

                    Evgenii Legotckoi
                    • Наурыз 17, 2020, 8:27 Т.Ж.

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

                      elyana
                      • Наурыз 17, 2020, 8:30 Т.Ж.

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

                        Evgenii Legotckoi
                        • Наурыз 17, 2020, 8:34 Т.Ж.

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

                          Serj Demchenko
                          • Наурыз 17, 2020, 8:45 Т.Ж.
                          • (өңделген)

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

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

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

                            elyana
                            • Наурыз 17, 2020, 8:56 Т.Ж.
                            • (өңделген)

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

                              Serj Demchenko
                              • Наурыз 17, 2020, 9:15 Т.Ж.

                              Так?

                                Drawer {
                                      id: drawer
                                      width:  window.width
                                      height:0.1 * window.height
                                      edge: Qt.BottomEdge
                              
                                  }
                              
                                Evgenii Legotckoi
                                • Наурыз 17, 2020, 9:17 Т.Ж.
                                • (өңделген)

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

                                  Evgenii Legotckoi
                                  • Наурыз 17, 2020, 9:19 Т.Ж.

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

                                  Window {
                                      id: window
                                  
                                      Drawer {
                                          y: window.height - 50
                                      }
                                  
                                  }
                                  
                                    Serj Demchenko
                                    • Наурыз 17, 2020, 9:23 Т.Ж.
                                    • (өңделген)

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

                                      elyana
                                      • Наурыз 17, 2020, 9:24 Т.Ж.

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

                                        Evgenii Legotckoi
                                        • Наурыз 17, 2020, 9:26 Т.Ж.

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

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

                                          elyana
                                          • Наурыз 17, 2020, 9:28 Т.Ж.

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

                                            Serj Demchenko
                                            • Наурыз 17, 2020, 9: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, 9:46 Т.Ж.
                                              • (өңделген)

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

                                                elyana
                                                • Наурыз 17, 2020, 9: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
                                                      }
                                                  }
                                                  
                                                  
                                                  

                                                    Пікірлер

                                                    Тек рұқсаты бар пайдаланушылар ғана пікір қалдыра алады.
                                                    Кіріңіз немесе Тіркеліңіз
                                                    Г

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

                                                    • Нәтиже:66ұпай,
                                                    • Бағалау ұпайлары-1
                                                    t

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

                                                    • Нәтиже:33ұпай,
                                                    • Бағалау ұпайлары-10
                                                    t

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

                                                    • Нәтиже:52ұпай,
                                                    • Бағалау ұпайлары-4
                                                    Соңғы пікірлер
                                                    G
                                                    GoattRockҚыр. 3, 2024, 1:50 Т.Қ.
                                                    Linux жүйесінде файлдарды қалай көшіруге болады Задумывались когда-нибудь о том, как мы привыкли доверять свои вещи службам грузоперевозок? Сейчас такие услуги стали неотъемлемой частью нашей жизни, особенно когда речь идет о переездах между …
                                                    d
                                                    dblas5Шілде 5, 2024, 11:02 Т.Ж.
                                                    QML - Сабақ 016. SQLite деректер қоры және онымен QML Qt-та жұмыс істеу Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                                                    k
                                                    kmssrАқп. 8, 2024, 6:43 Т.Қ.
                                                    Qt Linux - Сабақ 001. Linux астында Autorun Qt қолданбасы как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
                                                    АК
                                                    Анатолий КононенкоАқп. 5, 2024, 1:50 Т.Ж.
                                                    Qt WinAPI - Сабақ 007. Qt ішінде ICMP Ping арқылы жұмыс істеу Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
                                                    Енді форумда талқылаңыз
                                                    Evgenii Legotckoi
                                                    Evgenii LegotckoiМаусым 24, 2024, 3:11 Т.Қ.
                                                    добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
                                                    F
                                                    FynjyШілде 22, 2024, 4:15 Т.Ж.
                                                    при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …
                                                    BlinCT
                                                    BlinCTМаусым 25, 2024, 1 Т.Ж.
                                                    Нарисовать кривую в qml Всем привет. Имеется Лист листов с тосками, точки получаны интерполяцией Лагранжа. Вопрос, как этими точками нарисовать кривую? ChartView отпадает сразу, в qt6.7 появился новый элемент…
                                                    BlinCT
                                                    BlinCTМамыр 5, 2024, 5:46 Т.Ж.
                                                    Написать свой GraphsView Всем привет. В Qt есть давольно старый обьект дял работы с графиками ChartsView и есть в 6.7 новый но очень сырой и со слабым функционалом GraphsView. По этой причине я хочу написать х…
                                                    Evgenii Legotckoi
                                                    Evgenii LegotckoiМамыр 2, 2024, 2:07 Т.Қ.
                                                    Мобильное приложение на C++Qt и бэкенд к нему на Django Rest Framework Добрый день. По моему мнению - да, но то, что будет касаться вызовов к функционалу Андроида, может создать огромные трудности.

                                                    Бізді әлеуметтік желілерде бақылаңыз