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

                                                    Комментарии

                                                    Только авторизованные пользователи могут публиковать комментарии.
                                                    Пожалуйста, авторизуйтесь или зарегистрируйтесь
                                                    AD

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

                                                    • Результат:50баллов,
                                                    • Очки рейтинга-4
                                                    m
                                                    • molni99
                                                    • 26 октября 2024 г. 8:37

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

                                                    • Результат:80баллов,
                                                    • Очки рейтинга4
                                                    m
                                                    • molni99
                                                    • 26 октября 2024 г. 8:29

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

                                                    • Результат:20баллов,
                                                    • Очки рейтинга-10
                                                    Последние комментарии
                                                    i
                                                    innorwall15 ноября 2024 г. 5:26
                                                    Qt/C++ - Урок 031. QCustomPlot - строим график по времени buy generic priligy We can just chat, and we will not lose too much time anyway
                                                    i
                                                    innorwall15 ноября 2024 г. 3:03
                                                    Qt/C++ - Урок 060. Настройка внешнего вида приложения в рантайме I didnt have an issue work colors priligy dapoxetine 60mg revia cost uk August 3, 2022 Reply
                                                    i
                                                    innorwall14 ноября 2024 г. 19:42
                                                    Как Копировать Файлы в Linux If only females relatives with DZ offspring were considered these percentages were 23 order priligy online uk
                                                    i
                                                    innorwall14 ноября 2024 г. 17:09
                                                    Qt/C++ - Урок 068. Hello World с использованием системы сборки CMAKE в CLion ditropan pristiq dosing With the Yankees leading, 4 3, Rivera jogged in from the bullpen to a standing ovation as he prepared for his final appearance in Chicago buy priligy pakistan
                                                    Сейчас обсуждают на форуме
                                                    i
                                                    innorwall14 ноября 2024 г. 11:39
                                                    добавить qlineseries в функции priligy amazon canada 93 GREB1 protein GREB1 AB011147 6
                                                    i
                                                    innorwall11 ноября 2024 г. 18:55
                                                    Всё ещё разбираюсь с кешем. priligy walgreens levitra dulcolax carbs The third ring was found to be made up of ultra relativistic electrons, which are also present in both the outer and inner rings
                                                    9
                                                    9Anonim25 октября 2024 г. 16:10
                                                    Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
                                                    ИМ
                                                    Игорь Максимов3 октября 2024 г. 11:05
                                                    Реализация навигации по разделам Спасибо Евгений!

                                                    Следите за нами в социальных сетях