QCustomPlot获取选点坐标

QCustomPlot的plottableClick(QCPAbstractPlottable* plottable, int dataIndex, QMouseEvent* event)信号在鼠标单击绘图层上的数据点时发出,plottable是接收点击的绘图层,dataIndex是最接近点击位置的数据点索引,event是鼠标点击事件。

首先需要设置QCustomPlot可选点,关联plottableClick信号:

//设置可选点
ui->m_pPlotZoom->setInteractions(QCP::iSelectPlottables);

//关联选点信号
connect(ui->m_pPlotZoom, SIGNAL(plottableClick(QCPAbstractPlottable*, int, QMouseEvent*)), this, SLOT(OnPlotClick(QCPAbstractPlottable*, int, QMouseEvent*)));

//选点处理函数
void MainWindow::OnPlotClick(QCPAbstractPlottable *plottable, int dataIndex, QMouseEvent *event)
{
  //先获取点击的绘图层名称,然后通过名称找到图层ID,再找到对应的数据点
  int graphId = m_vecDataName.indexOf(plottable->name());
  const QCPGraphData *ghd = ui->m_pPlotZoom->graph(graphId)->data()->at(dataIndex);
  qDebug() << ghd->key << ghd->value;
}

 

  • 1
    点赞
  • 33
    收藏
    觉得还不错? 一键收藏
  • 9
    评论
您可以使用百度地图API来实现前端内网开发的地图选点获取坐标和具体省市区地址。以下是实现步骤: 1. 注册百度地图开发者账号,创建应用,获取密钥。 2. 在前端页面中引入百度地图API的JavaScript库: ``` <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=您的密钥"></script> ``` 3. 创建地图容器: ``` <div id="map" style="width: 100%; height: 500px;"></div> ``` 4. 初始化地图: ``` var map = new BMap.Map("map"); // 创建地图实例 var point = new BMap.Point(116.404, 39.915); // 创建坐标 map.centerAndZoom(point, 15); // 初始化地图,设置中心坐标和缩放级别 map.enableScrollWheelZoom(true); // 启用滚轮缩放 ``` 5. 添加地图控件: ``` var geolocationControl = new BMap.GeolocationControl(); // 定位控件 var navigationControl = new BMap.NavigationControl(); // 缩放平移控件 var overviewMapControl = new BMap.OverviewMapControl(); // 缩略图控件 var scaleControl = new BMap.ScaleControl(); // 比例尺控件 map.addControl(geolocationControl); map.addControl(navigationControl); map.addControl(overviewMapControl); map.addControl(scaleControl); ``` 6. 添加地图事件监听: ``` map.addEventListener("click", function(e) { var point = e.point; // 获取击的坐标 var geoc = new BMap.Geocoder(); // 创建地理编码实例 geoc.getLocation(point, function(rs) { var addComp = rs.addressComponents; // 获取地址信息 var address = addComp.province + addComp.city + addComp.district + addComp.street + addComp.streetNumber; // 拼接地址信息 console.log(point.lng + ", " + point.lat); // 输出坐标 console.log(address); // 输出地址 }); }); ``` 以上就是实现前端内网开发的地图选点获取坐标和具体省市区地址的步骤。百度地图API提供了丰富的功能和文档,您可以参考官方文档进行更详细的开发。
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值