alex_lip
alex_lipMarch 20, 2018, 3:21 a.m.

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

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

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!

17
Evgenii Legotckoi
  • March 20, 2018, 3:47 a.m.
  • The answer was marked as a solution.

Добрый день!

Якоря в 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
    • March 20, 2018, 4 a.m.

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

      Evgenii Legotckoi
      • March 20, 2018, 4:08 a.m.

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

        alex_lip
        • March 20, 2018, 4:21 a.m.

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

          Evgenii Legotckoi
          • March 20, 2018, 4:31 a.m.

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

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

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

            Спасибо!

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

              Evgenii Legotckoi
              • March 20, 2018, 6:05 a.m.

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

                alex_lip
                • March 20, 2018, 8:39 a.m.

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

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


                  Evgenii Legotckoi
                  • March 20, 2018, 9:15 a.m.

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

                  Item {
                          anchors.fill: parent
                  
                          TapHandler {
                              longPressThreshold: 10.0
                              onTapped: console.log("standard press")
                              onLongPressed: console.log("long press")
                          }
                      }
                    alex_lip
                    • March 20, 2018, 9:33 a.m.

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

                      Evgenii Legotckoi
                      • March 20, 2018, 9:36 a.m.

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

                        alex_lip
                        • March 22, 2018, 2:46 a.m.

                        Не получилось два 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
                          • March 22, 2018, 4:20 a.m.

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

                            alex_lip
                            • March 22, 2018, 4:26 a.m.

                            Сделал через 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
                              • March 22, 2018, 4:29 a.m.

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

                                alex_lip
                                • March 22, 2018, 4:31 a.m.
                                • (edited)

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

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

                                  Evgenii Legotckoi
                                  • March 22, 2018, 4:33 a.m.

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

                                    Comments

                                    Only authorized users can post comments.
                                    Please, Log in or Sign up
                                    d
                                    • dsfs
                                    • April 26, 2024, 1:56 a.m.

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

                                    • Result:80points,
                                    • Rating points4
                                    d
                                    • dsfs
                                    • April 26, 2024, 1:45 a.m.

                                    C++ - Test 002. Constants

                                    • Result:50points,
                                    • Rating points-4
                                    d
                                    • dsfs
                                    • April 26, 2024, 1:35 a.m.

                                    C++ - Test 001. The first program and data types

                                    • Result:73points,
                                    • Rating points1
                                    Last comments
                                    k
                                    kmssrFeb. 8, 2024, 3:43 p.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, 7:30 a.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, 5:38 a.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. 18, 2023, 6:01 p.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, 2:46 a.m.
                                    Clipboard Как скопировать окно целиком в clipb?
                                    DA
                                    Dr Gangil AcademicsApril 20, 2024, 4:45 a.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, 3:41 a.m.
                                    Мобильное приложение на C++Qt и бэкенд к нему на Django Rest Framework Евгений, добрый день! Такой вопрос. Верно ли следующее утверждение: Любое Android-приложение, написанное на Java/Kotlin чисто теоретически (пусть и с большими трудностями) можно написать и на C+…
                                    Павел Дорофеев
                                    Павел ДорофеевApril 13, 2024, 11:35 p.m.
                                    QTableWidget с 2 заголовками Вот тут есть кастомный QTableView с многорядностью проект поддерживается, обращайтесь
                                    f
                                    fastrexApril 4, 2024, 1:47 a.m.
                                    Вернуть старое поведение QComboBox, не менять индекс при resetModel Добрый день! У нас много проектов в которых используется QComboBox, в версии 5.5.1, когда модель испускает сигнал resetModel, currentIndex не менялся. В версии 5.15 при resetModel происходит try…

                                    Follow us in social networks