alex_lip
alex_lip20 марта 2018 г. 3:21

Картинка на картинке внутри column

Добрый день.
Есть row - внутри нее column - внутри column - две картинки - одна под другой - как бы сделать так, чтобы нижняя картинка немного наезжала на верхнюю(то есть поднять ее на 2- пикселов, чтобы она перекрыла низ верхней картинки). Anchors.topMargin: -20; - не работает.

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

Вам это нравится? Поделитесь в социальных сетях!

17
Evgenii Legotckoi
  • 20 марта 2018 г. 3:47
  • Ответ был помечен как решение.

Добрый день!

Якоря в row и column как правило либо не работают вовсе, зависит от версий библиотек, либо работают только в одно направлении, Для row это только ось y, для column это ось x.

В рамках вашей задачи вам придётся отказаться от row и column вовсе. Не получится реализовать такое с их помощью.
Поместите оба изображения в Item, а в нём уже позиционируйте с помощь якорей изображения так, как Вам нужно.

Item {
    id: root

    Item {
        id: first
        anchors {
            top: parent.top
            left: parent.left
            right: parent.right
        }
    }
    Item {
        id: second
        anchors {
            top: first.bottom
            topMargin: -20
            left: parent.left
            right: parent.right
        }
    }
}
То есть вместо column используйте такой Item, в котором с помощью якорей будете позиционировать изображения так, как Вам необходимо.

Сам по себе объект column для такого, что вы хотите сделать, не предназначен.
    alex_lip
    • 20 марта 2018 г. 4:00

    Спасибо. Я так и думал (( Я только начал графикой в QML интересоваться. Не подскажете куда посмотреть для начала? Примеры - Ваши уроки - и т.д. Я почему спрашиваю - столкнулся с тем, что QtQuick 2 - сильно отличается от предыдущих версий и старые примеры только путают(например отстутствие Style) .

      Evgenii Legotckoi
      • 20 марта 2018 г. 4:08

      Да, QtQuick 2 сильно отличается, ничего не поделаешь, но он значительно лучше.
      Лучше скажите, что конкретно хотите делать. Проще будет подсказать. Ещё заглядывайте в раздел Android . Я понемногу сейчас пишу сравнительные статьи и там именно на новом QtQuick 2 всё сделано.

        alex_lip
        • 20 марта 2018 г. 4:21

        Хочу со спрайтами разобраться. Хочу понять для чего нужен image provider. Как показать галерею на андроиде и ios.

          Evgenii Legotckoi
          • 20 марта 2018 г. 4:31

          Про спрайты - это можете почитать вот эти статьи спокойно.

          1. https://evileg.com/post/177/
          2. https://evileg.com/post/310/
          А что касается галереи - это интересно... но такой статьи у меня нет. Надо будет подумать о её написании, со временем и самому может понадобиться галерея.

          Что касается Image Provider, то как я понял из документации, то это что-то вроде универсального провайдера изображений, с помощью которого можно предоставлять изображения в необходимом качестве в зависимости от запрошенного размера, я только сразу не нашёл ещё как его установить правильно в приложение.
            alex_lip
            • 20 марта 2018 г. 5:58

            Спасибо!

            Про image provider есть пример - но он у меня не запускается.

              Evgenii Legotckoi
              • 20 марта 2018 г. 6:05

              Хорошо, что пример есть, надо будет глянуть. На первый взгляд по документации там ничего сложного нет. Возможно, что сам по себе пример устаревший в Qt Creator

                alex_lip
                • 20 марта 2018 г. 8:39

                Прочитал статью https://evileg.com/post/310/ - пытаюсь на объекте где есть mouse click повесить

                                            TapHandler {
                                                   // gesturePolicy : TapHandler.DragThreshold
                longPressThreshold:2 onTapped: console.log("longPressThreshold") }
                Долгое нажатие не перехватывается. Вы пробовали использовать данное событие?


                  Evgenii Legotckoi
                  • 20 марта 2018 г. 9:15

                  Обработчик не тот используете, нужно использовать onLongPressed

                  Item {
                          anchors.fill: parent
                  
                          TapHandler {
                              longPressThreshold: 10.0
                              onTapped: console.log("standard press")
                              onLongPressed: console.log("long press")
                          }
                      }
                    alex_lip
                    • 20 марта 2018 г. 9:33

                    Отлично. Можно вместо  onClicked: использовать там где надо клик и долгое нажатие.

                      Evgenii Legotckoi
                      • 20 марта 2018 г. 9:36

                      Ага. При этом TapHandler Выступает в качестве присоединяемого объекта, которых, как я понял, может быть несколько. А это значит, что можно контролировать несколько степеней долгого нажатия, например. Это гораздо удобнее, чем прикручивать MouseArea. Посколько наложение нескольких MouseArea неминуемо приводило к конфликтам при передаче сигнала от выше стоящей MouseArea к ниже стоящей.

                        alex_lip
                        • 22 марта 2018 г. 2:46

                        Не получилось два TapHandler на одим Item повесить - по LongPress срабатывает только первый


                                                                        Item {
                                                                            anchors.fill: parent
                        
                                                                            TapHandler {
                                                                                longPressThreshold: 2.0
                                                                                onTapped: {
                                                                                    view_nazn_isp.currentIndex = model.index
                                                                                    console.log(text_nazn_isp.text)
                                                                                  }
                                                                                onLongPressed:
                                                                                {
                                                                                    //Qt.openUrlExternally("tel:%1".arg(phone)) ;
                                                                                    Qt.openUrlExternally("tel:89999999") ;
                                                                                    console.log("long press 2")
                                                                                }
                                                                            }
                                                                            TapHandler {
                                                                                longPressThreshold: 4.0
                                                                                onLongPressed:
                                                                                {
                                                                                    //Qt.openUrlExternally("tel:%1".arg(phone)) ;
                                                                                    Qt.openUrlExternally("tel:80000000") ;
                                                                                    console.log("long press 4")
                                                                                }
                                                                            }



                          Evgenii Legotckoi
                          • 22 марта 2018 г. 4:20

                          Значит всё-таки не взлетело... ну остаётся только пометить этот момент в памяти и придумывать иные ухищрения, если всё-таки потребуется такой функционал.

                            alex_lip
                            • 22 марта 2018 г. 4:26

                            Сделал через tapcount - тоже прикольно


                                                                                TapHandler {
                                                                                    longPressThreshold: 0.7
                                                                                    onTapped:
                                                                                      if (tapCount == 3)
                                                                                      {
                                                                                          Qt.openUrlExternally("tel:"+mobila) ;
                                                                                          console.log("tap count 3")
                                                                                      }
                                                                                    else
                                                                                    {
                                                                                        view_nazn_isp.currentIndex = model.index
                                                                                        console.log(text_nazn_isp.text)
                                                                                    }
                                                                                    onLongPressed:
                                                                                    {
                                                                               
                                                                                        Qt.openUrlExternally("tel:"+phone) ;
                                                                                        console.log("long press 2")
                                                                                    }
                                                                                }



                              Evgenii Legotckoi
                              • 22 марта 2018 г. 4:29

                              получается, что в одном случае долно держим, а в другом три раза тапнуть нужно?
                              да, пожалуй забавно будет... правда не уверен, что в плане юзабилити это будет понятно пользователю )))

                                alex_lip
                                • 22 марта 2018 г. 4:31
                                • (ред.)

                                тройной тап - это недокументированная функция для доступа к мобильному номеру))

                                Для пользователя возможно будет понятен двойной тап и долгое нажатие
                                А так - конечно контекстное меню все-таки лучше всего. Правда его я пока не пробовал.

                                  Evgenii Legotckoi
                                  • 22 марта 2018 г. 4:33

                                  ха ха.. Это как на Honor 8 нужно в настройках на идентификатор телефона нажать семь раз, чтобы получить доступ к режиму разработчика.

                                    Комментарии

                                    Только авторизованные пользователи могут публиковать комментарии.
                                    Пожалуйста, авторизуйтесь или зарегистрируйтесь
                                    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
                                    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 г. 12:05
                                    EVILEG-CORE. Использование Google reCAPTCHA 2001; 98 29 34 priligy buy
                                    i
                                    innorwall14 ноября 2024 г. 12:00
                                    PyQt5 - Урок 007. Работаем с QML QtQuick (Сигналы и слоты) priligy 30mg Am J Obstet Gynecol 171 1488 505
                                    Сейчас обсуждают на форуме
                                    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
                                    Реализация навигации по разделам Спасибо Евгений!

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