实现在地图随意点击,弹出文本输入框,输入任意文字,完成自由文本添加的功能

作者: 狐狸家的鱼

GitHub:八至

本文链接:地图上点击添加自由文本

关于如何QML与HTML通信已经在上一篇文章 QML与HTML通信之画图 详细讲述了。

1.html

//添加文本
var addTextBoxContent;//添加文本弹出框的内容
var addTextBoxCloser;//添加文本弹出框的关闭
var addTextBoxTitle;
var inputText;
var confirmBtn;//确定按钮
var clickCoordinate;//鼠标点击坐标
var addCoordinate;//鼠标点击坐标转换为投影坐标
var textLabelElement;//文本元素
var textOverlayer;//文本叠加层
var addTextOverlay;
//创建弹出框叠加层
var createTextPopup = () =>{
addTextBox = document.createElement('div');
addTextBox.className = 'add-text-popup';
addTextBoxCloser = document.createElement('a');
addTextBoxCloser.className = 'ol-popup-closer';
addTextBox.appendChild(addTextBoxCloser);
addTextBoxContent = document.createElement('div');
addTextBoxContent.className = 'popup-content';
addTextBox.appendChild(addTextBoxContent);
addTextBoxTitle = document.createElement('p');
addTextBoxTitle.className = 'content-title';
inputText = document.createElement('input');
inputText.className = 'inputText';
confirmBtn = document.createElement('input');
confirmBtn.className = 'btn btn-primary confirmBtn';
confirmBtn.type = 'button';
confirmBtn.value = 'Confirm';
addTextBoxContent.appendChild(addTextBoxTitle);
addTextBoxContent.appendChild(inputText);
addTextBoxContent.appendChild(confirmBtn);
addTextBoxCloser.onclick = function(){//添加一个单击处理程序来隐藏弹出窗口
addTextOverlay.setPosition(undefined);
addTextBoxCloser.blur();
return false;
};
confirmBtn.onclick = ()=>{//弹出框的确定按钮来添加文本
createTextLabel();//调用创建文本叠加层的函数
textLabelElement.innerHTML = $('.inputText').val();
textOverlayer.setPosition(clickCoordinate);//文本叠加层的位置
addTextOverlay.setPosition(undefined);//弹出框关闭
};
inputText.addEventListener('keypress',()=>{//给输入框添加回车键监听事件
if(event.keyCode == 13){
createTextLabel();//调用创建文本叠加层的函数
textLabelElement.innerHTML = $('.inputText').val();
textOverlayer.setPosition(clickCoordinate);//文本叠加层的位置
addTextOverlay.setPosition(undefined);//弹出框关闭
}
});
addTextOverlay = new ol.Overlay({//弹出框的叠加层
element:addTextBox,
autoPan:true,
autoPanAnimation:{
duration:250
}
});
map.addOverlay(addTextOverlay);
}
//创建文本元素叠加层
var createTextLabel = () =>{
textLabelElement = document.createElement('div');
textLabelElement.className = 'text-label';//设置p标签的样式
textOverlayer = new ol.Overlay({
element:textLabelElement,
stopEvent: false
});
map.addOverlay(textOverlayer);
};

2.QML

在WebChannel添加信号

signal addFreeText()                    //添加自由文本

添加文本按钮调用信号

CLButton{
id:txaBtn;
anchors.fill: parent;
btnText: "TXA";
onClicked: {
map.addFreeText();//信号
console.log("clicked addTextBtn");
}
}

html中连接信号

//添加自由文本
content.addFreeText.connect(()=>{
createTextPopup();//添加到地图中
map.on('singleclick',(evt) => {//地图响应鼠标左键点击数事件
clickCoordinate = evt.coordinate;//鼠标左键获取点击坐标
addCoordinate = ol.proj.transform(clickCoordinate, 'EPSG:3857', 'EPSG:4326');//转换鼠标左键获取的坐标
addTextOverlay.setPosition(clickCoordinate);
console.log("before:",clickCoordinate,"\n","after:",addCoordinate);//打印坐标
});
});

OpenLayers学习笔记(三)— QML与HTML通信之 地图上点击添加自由文本的更多相关文章

  1. ArcGIS for qml -添加自由文本

    源码:https://github.com/sueRimn/ArcGIS-for-qml-demos 实现地图上鼠标点击后添加自由文本功能 作者: 狐狸家的鱼 Github: 八至 版权声明:如需转载 ...

  2. angular学习笔记(三十一)-$location(2)

    之前已经介绍了$location服务的基本用法:angular学习笔记(三十一)-$location(1). 这篇是上一篇的进阶,介绍$location的配置,兼容各版本浏览器,等. *注意,这里介绍 ...

  3. VSTO学习笔记(三) 开发Office 2010 64位COM加载项

    原文:VSTO学习笔记(三) 开发Office 2010 64位COM加载项 一.加载项简介 Office提供了多种用于扩展Office应用程序功能的模式,常见的有: 1.Office 自动化程序(A ...

  4. 学习笔记(三)--->《Java 8编程官方参考教程(第9版).pdf》:第十章到十二章学习笔记

    回到顶部 注:本文声明事项. 本博文整理者:刘军 本博文出自于: <Java8 编程官方参考教程>一书 声明:1:转载请标注出处.本文不得作为商业活动.若有违本之,则本人不负法律责任.违法 ...

  5. angular学习笔记(三十)-指令(10)-require和controller

    本篇介绍指令的最后两个属性,require和controller 当一个指令需要和父元素指令进行通信的时候,它们就会用到这两个属性,什么意思还是要看栗子: html: <outer‐direct ...

  6. angular学习笔记(三十)-指令(5)-link

    这篇主要介绍angular指令中的link属性: link:function(scope,iEle,iAttrs,ctrl,linker){ .... } link属性值为一个函数,这个函数有五个参数 ...

  7. Liunx学习笔记(三) 文件权限

    一.文件权限 1.查看文件权限 (1)文件权限 在 Linux 中对于文件有四种访问权限,列举如下: 可读取:r,Readable 可写入:w,Writable 可执行:x,Execute 无权限:- ...

  8. 物联网学习笔记三:物联网网关协议比较:MQTT 和 Modbus

    物联网学习笔记三:物联网网关协议比较:MQTT 和 Modbus 物联网 (IoT) 不只是新技术,还是与旧技术的集成,其关键在于通信.可用的通信方法各不相同,但是,各种不同的协议在将海量“事物”连接 ...

  9. Oracle学习笔记三 SQL命令

    SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)  

随机推荐

  1. [转帖]How To Be Successful

    How To Be Successful http://blog.samaltman.com/how-to-be-successful 总结一下文章的重点: 1. Compound yourself2 ...

  2. 在Laravel中使用数据库事务以及捕获事务失败后的异常

    Description 在Laravel中要想在数据库事务中运行一组操作,则可以在 DB facade 中使用 transaction 方法.如果在事务的闭包内抛出异常,事务将会被自动还原.如果闭包运 ...

  3. java.lang.Comparable 接口 详解

    参考https://blog.csdn.net/itm_hadf/article/details/7432782 http://www.blogjava.net/jjshcc/archive/2011 ...

  4. C# json解析

    json格式数 [{ , , , "ItemCode": "UBAC11211OF-A54", "basicName_bg": " ...

  5. EChart.js 笔记一

    一直对数据可视化比较感兴趣,当年 Alibaba 年报晚会上的大屏显示可谓是技惊四座,够震撼,将数据之美展现得淋漓尽致. 国内的前端数据可视化插件中,echart.js 算是热度很高的,也容易上手,算 ...

  6. codeforces703B

    Mishka and trip CodeForces - 703B 小米什卡是一个伟大的旅行者,她访问了许多国家.在这次考虑去哪里旅行之后,她选择了XXX--这个美丽,但鲜为人知的北方国家. 以下是关 ...

  7. bzoj4152-[AMPPZ2014]The_Captain

    Description 给定平面上的n个点,定义(x1,y1)到(x2,y2)的费用为min(|x1-x2|,|y1-y2|),求从1号点走到n号点的最小费用. Input 第一行包含一个正整数n(2 ...

  8. http协议状态码大全

    100 Continue:初始的请求已经接受,客户应当继续发送请求的其余部分.  101 Switching Protocols:服务器将遵从客户的请求转换到另外一种协议.  200 OK:一切正常, ...

  9. 基于OpenCv和swing的图片/视频展示Java实现

    基于OpenCv和swing实现图片/视频的展示 图片的展示 swing展示图片,多为操作BufferedImage,这里要关注的核心是将Mat转为BufferedImage. 代码如下: publi ...

  10. kubernetes ceph-rbd挂载步骤 类型storageClass

    由于kubelet本身并不支持rbd的命令,所以需要添加一个kube系统插件: 下载插件 quay.io/external_storage/rbd-provisioner 下载地址: https:// ...