Михаил Сермяжко
Михаил Сермяжко30 октября 2019 г. 13:22

Как в QML сочетать Map и MouseArea

Map

Добрый день.
Использую этот код
Если использовать MouseArea, то не получается передвгать карту. Скажите пожалуйста, как получать сигнал от MouseArea при нажатии и иметь возможность передвигать карту мышкой?

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

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

3
zloi
  • 30 октября 2019 г. 13:45

Возможно вам поможет свойство propagateComposedEvents, оно позволяет передавать события мыши ниже по уровню.

    Михаил Сермяжко
    • 30 октября 2019 г. 15:35
    • (ред.)

    Сделал так, не момогло. В документации говорится, что это работает только для MouseArea.

            Map {
                    id: mapview
                    anchors.fill: parent
                    plugin: plugin
                    center: QtPositioning.coordinate(59.91, 10.75)
                    zoomLevel: 14
    
                    MapItemView{
                        model: markerModel
                        delegate: mapcomponent
                    }
                }
    
            Component {
                    id: mapcomponent
                    MapQuickItem {
                        id: marker
                        anchorPoint.x: image.width/4
                        anchorPoint.y: image.height
                        coordinate: position
    
                        sourceItem: Image {
                            id: image
                            source: "qrc:/Images/Images/markerRed.png"
                        }
                    }
                }
    
                MouseArea {
                    anchors.fill: parent
                    propagateComposedEvents: true
                    onPressAndHold:  {
                        var coordinate = mapview.toCoordinate(Qt.point(mouse.x,mouse.y))
                        markerModel.addMarker(coordinate)
                    }
                }
    
      Михаил Сермяжко
      • 30 октября 2019 г. 15:52
      • Ответ был помечен как решение.

      Вот так работает

              Map {
                      id: mapview
                      anchors.fill: parent
                      plugin: plugin
                      center: QtPositioning.coordinate(59.91, 10.75)
                      zoomLevel: 14
      
                      MapItemView{
                          model: markerModel
                          delegate: mapcomponent
                      }
      
                      MouseArea {
                          anchors.fill: parent
                          onPressAndHold:  {
                              var coordinate = mapview.toCoordinate(Qt.point(mouse.x,mouse.y))
                              markerModel.addMarker(coordinate)
                          }
                      }
                  }
      
              Component {
                      id: mapcomponent
                      MapQuickItem {
                          id: marker
                          anchorPoint.x: image.width/4
                          anchorPoint.y: image.height
                          coordinate: position
      
                          sourceItem: Image {
                              id: image
                              source: "qrc:/Images/Images/markerRed.png"
                          }
                      }
                  }
      

        Комментарии

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

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

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

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

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

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

        • Результат:20баллов,
        • Очки рейтинга-10
        Последние комментарии
        i
        innorwall14 ноября 2024 г. 21:26
        Qt/C++ - Урок 031. QCustomPlot - строим график по времени buy generic priligy We can just chat, and we will not lose too much time anyway
        i
        innorwall14 ноября 2024 г. 19:03
        Qt/C++ - Урок 060. Настройка внешнего вида приложения в рантайме I didnt have an issue work colors priligy dapoxetine 60mg revia cost uk August 3, 2022 Reply
        i
        innorwall14 ноября 2024 г. 11:42
        Как Копировать Файлы в Linux If only females relatives with DZ offspring were considered these percentages were 23 order priligy online uk
        i
        innorwall14 ноября 2024 г. 9: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 г. 3:39
        добавить qlineseries в функции priligy amazon canada 93 GREB1 protein GREB1 AB011147 6
        i
        innorwall11 ноября 2024 г. 10: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 г. 9:10
        Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
        ИМ
        Игорь Максимов3 октября 2024 г. 4:05
        Реализация навигации по разделам Спасибо Евгений!

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