当前位置: 首页 > article >正文

QWidget中嵌入QQuickWidget,从qml端鼠标获取经纬度点(double类型),发到c++端。把c++端的对象暴露个qml端调用

qml端鼠标选取点
在这里插入图片描述
c++端接收
在这里插入图片描述

c++端
先写一个类,专门用来接收,取名MouseDrawAirspace

#ifndef MOUSEDRAWAIRSPACE_H
#define MOUSEDRAWAIRSPACE_H


#include <QVariant>
#include <QObject>
#include <QGeoCoordinate>
#include <QDebug>
#include <QList>

class MouseDrawAirspace : public QObject
{
    Q_OBJECT

public:
    explicit MouseDrawAirspace(QObject *parent=nullptr);
    ~MouseDrawAirspace();

public slots:
    // 槽函数,用于接收多边形点坐标
    void receivePoints( QVariantList points) ;

    void receiveCoordinates(QVector<QPointF> coordinates1);

 public:
    QList<QPointF>store_multiPolyon;

};

#endif // MOUSEDRAWAIRSPACE_H

cpp

#include "mousedrawairspace.h"

MouseDrawAirspace::MouseDrawAirspace(QObject *parent):QObject(parent)

{
//我要使用这种类型,作为对外通信,所以先注册吧,之后要用
    qRegisterMetaType <QList<QPointF>>(" QList<QPointF>");
}
MouseDrawAirspace::~MouseDrawAirspace()
{
}

void MouseDrawAirspace::receivePoints( QVariantList points)
{
    for (const auto& pointVariant : points) {
        // 将 QVariant 转换为 QVariantList,代表单个坐标点
        QVariantList pointList = pointVariant.toList();
        if (pointList.size() == 2)
        {
            // 获取 x 和 y 坐标

            double x = pointList[0].toDouble();
            double y = pointList[1].toDouble();
             QPointF p;
             p.setX(x);
             p.setY(y);
            store_multiPolyon.append(p);
            qDebug() << "Received point: (" << x << ", " << y << ")";
        }

    }

}
void MouseDrawAirspace::receiveCoordinates(QVector<QPointF> coordinates1)
{

    for (const auto &point : coordinates1) {
        qDebug() << "Coordinate:" << point;
    }
}

通过上下文,把接口暴露个qml端。
意思:qml端可以调用这个类对象

  //手动拾取空域点
    mouseDrawAirSpace=new MouseDrawAirspace();
  //  MouseDrawAirspace temdddd;
    ui->quickWidget->rootContext()->setContextProperty("MouseDrawAirspace",mouseDrawAirSpace);

来看qml端
核心代码

 MouseArea{
 //用来存放鼠标选取的经纬度点
   property var points: []
   onClicked: {
	 var coord = the_map.toCoordinate(Qt.point(mouseX,mouseY),false);
          templist.push(coord);

	}
	//双击后,把里面保存到经纬度点发到c++端
 onDoubleClicked: {
  // 遍历 templist 提取经纬度并添加到 points 中
            for (var i = 0; i < templist.length; i++)
            {
                var currentCoordinate = templist[i];
                var longti = currentCoordinate.longitude;
                var lati = currentCoordinate.latitude;
                var point1 = [longti, lati];
                points.push(point1);
            }
     //MouseDrawAirspace就是通过上下文注册的那个对象
 	 MouseDrawAirspace.receivePoints(points)
}

}


全部模块代码

 /****************双击生成多边形******************/
  MouseArea{
    id:mouse_polygon
    property var list: [[]]
    property var templist: []
    property var points: []

    anchors.fill: parent
    hoverEnabled: true;
    enabled:polygon_flag != 0
    onClicked: {
      if(polygon_flag == 1 && mouse.button == Qt.LeftButton)
      {

        if(!ruler)
        {
          ruler = ruler_comp.createObject(the_map);
          if(ruler)
          {
            the_map.addMapItemGroup(ruler)
          }
        }
        if(ruler){
          console.log("111 " + i);
          var coord = the_map.toCoordinate(Qt.point(mouseX,mouseY),false);
          templist.push(coord);
          console.log(item_rect_point_List)
          ruler.appendPoint(coord);
        }
      }
    }
    onPositionChanged: {
      if(polygon_flag === 1)
      {
        if(ruler)
        {
          var coord = the_map.toCoordinate(Qt.point(mouseX,mouseY),false);

          ruler.followMouse(coord);
            update()
        }
      }
    }
    onDoubleClicked: {
      if(polygon_flag === 1){
        if(ruler)
        {
          ruler.closePath();
          ruler.destoryLine();
          ruler = null;
        }
        var component = Qt.createComponent("MyPolygon.qml");
        console.log(component.errorString());
        if(component.status === Component.Ready)
        {

          var polygon = component.createObject(the_map)
          polygon._list = templist

            // 遍历 templist 提取经纬度并添加到 points 中
            for (var i = 0; i < templist.length; i++)
            {
                var currentCoordinate = templist[i];
                var longti = currentCoordinate.longitude;
                var lati = currentCoordinate.latitude;
                var point1 = [longti, lati];
                points.push(point1);
            }
   // 发送坐标点到 C++ 端  
             MouseDrawAirspace.receivePoints(points)

//测试,通不通
//            var coordinates = []
//            for (var i = 0; i < 30; ++i) {
//                // 这里简单生成一些示例坐标点,你可以根据实际需求修改
//                coordinates.push(Qt.point(i * 10.2, i * 20))
//            }
// 			MouseDrawAirspace.receiveCoordinates(points)
         
           
          the_map.addMapItemGroup(polygon)
        }
        templist.splice(0,templist.length)
        polygon_flag = 0;
        update()
      }
    }

  }

http://www.kler.cn/a/536936.html

相关文章:

  • 硬件工程师思考笔记02-器件的隐秘角落:磁珠与电阻噪声
  • Android13-系统服务大管家-ServiceManager进程-启动篇
  • 介绍10个比较优秀好用的Qt相关的开源库
  • 【Android开发AI实战】基于CNN混合YOLOV实现多车牌颜色区分且针对车牌进行矫正识别(含源码)
  • 华水967数据结构2024真题(回忆版)
  • 工业物联网平台-视频识别视频报警新功能正式上线
  • 第九天 动手实践ArkTS,创建简单的UI组件
  • BFS算法——广度优先搜索,探索未知的旅程(下)
  • 陶氏环面包络减速机:为工业视觉检测注入“精准动力”!
  • 【机器学习】深入探索SVM概念及其核方法
  • 3NF讲解
  • Web3D基础: GLTF文件材质和纹理扫盲
  • matlab simulink 117-电路故障分析
  • Day48_20250130【回校继续打卡】_单调栈part1_739.每日温度|496.下一个更大元素I|503.下一个更大元素II
  • SQL高级技巧:高效获取两表交集数据的三种方法(JOIN、IN、EXISTS)
  • Spring Cloud 01 - 微服务概述
  • “无痕模式”VS指纹浏览器,哪个更安全?
  • 自定义飞书Webhook机器人api接口
  • 【vscode源码】如何编译运行vscode及过程中问题解决
  • 在 Java 中使用 JDBC 连接数据库时,DriverManager 的主要作用是什么?请简要描述其工作原理。
  • Linux在x86环境下制作ARM镜像包
  • git代理设置
  • 65.棋盘 C#例子 WPF例子
  • 计算机考研复试上机02
  • 网安三剑客:DNS、CDN、VPN
  • 一文讲解Spring中事务的传播机制