OpenLayers学习笔记(三)— QML与HTML通信之 地图上点击添加自由文本
实现在地图随意点击,弹出文本输入框,输入任意文字,完成自由文本添加的功能
作者: 狐狸家的鱼
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通信之 地图上点击添加自由文本的更多相关文章
- ArcGIS for qml -添加自由文本
源码:https://github.com/sueRimn/ArcGIS-for-qml-demos 实现地图上鼠标点击后添加自由文本功能 作者: 狐狸家的鱼 Github: 八至 版权声明:如需转载 ...
- angular学习笔记(三十一)-$location(2)
之前已经介绍了$location服务的基本用法:angular学习笔记(三十一)-$location(1). 这篇是上一篇的进阶,介绍$location的配置,兼容各版本浏览器,等. *注意,这里介绍 ...
- VSTO学习笔记(三) 开发Office 2010 64位COM加载项
原文:VSTO学习笔记(三) 开发Office 2010 64位COM加载项 一.加载项简介 Office提供了多种用于扩展Office应用程序功能的模式,常见的有: 1.Office 自动化程序(A ...
- 学习笔记(三)--->《Java 8编程官方参考教程(第9版).pdf》:第十章到十二章学习笔记
回到顶部 注:本文声明事项. 本博文整理者:刘军 本博文出自于: <Java8 编程官方参考教程>一书 声明:1:转载请标注出处.本文不得作为商业活动.若有违本之,则本人不负法律责任.违法 ...
- angular学习笔记(三十)-指令(10)-require和controller
本篇介绍指令的最后两个属性,require和controller 当一个指令需要和父元素指令进行通信的时候,它们就会用到这两个属性,什么意思还是要看栗子: html: <outer‐direct ...
- angular学习笔记(三十)-指令(5)-link
这篇主要介绍angular指令中的link属性: link:function(scope,iEle,iAttrs,ctrl,linker){ .... } link属性值为一个函数,这个函数有五个参数 ...
- Liunx学习笔记(三) 文件权限
一.文件权限 1.查看文件权限 (1)文件权限 在 Linux 中对于文件有四种访问权限,列举如下: 可读取:r,Readable 可写入:w,Writable 可执行:x,Execute 无权限:- ...
- 物联网学习笔记三:物联网网关协议比较:MQTT 和 Modbus
物联网学习笔记三:物联网网关协议比较:MQTT 和 Modbus 物联网 (IoT) 不只是新技术,还是与旧技术的集成,其关键在于通信.可用的通信方法各不相同,但是,各种不同的协议在将海量“事物”连接 ...
- Oracle学习笔记三 SQL命令
SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)
随机推荐
- AngularJS集合数据遍历显示
AngularJS集合数据遍历显示 <!DOCTYPE html> <html> <head> <meta charset="UTF-8" ...
- 50分钟学会Laravel 50个小技巧(基于laravel5.2,仅供参考)
转载请注明:转载自 Yuansir-web菜鸟 | LAMP学习笔记 本文链接地址: 50分钟学会Laravel 50个小技巧 原文链接:< 50 Laravel Tricks in 50 Mi ...
- spring boot 获取bean
在写测试用例的时候,如果是springboot的应该加上 springboot的标签: @SpringBootTest(classes = ApplicationLoader.class) @Acti ...
- Python自动化运维之pexpect从入门到精通
1. 应用场景 模拟ssh, telnet远程登录, 模拟ftp文件上传 2. 安装 参考资料: <pexpect实例分析>https://www.ibm.com/developerwor ...
- 去掉AMD锐龙和Intel Kaby Lake的不支持的硬件的提示
Windows 7和Windows 8.1都不支持AMD Ryzen 锐龙系列和Intel最新的Kaby Lake系列,Windows Update 更新之后总是会提示“不支持的硬件(Unsuppor ...
- Vasya and a Tree CodeForces - 1076E(线段树+dfs)
I - Vasya and a Tree CodeForces - 1076E 其实参考完别人的思路,写完程序交上去,还是没理解啥意思..昨晚再仔细想了想.终于弄明白了(有可能不对 题意是有一棵树n个 ...
- Tomcat启动特慢之SecureRandom问题解决
tomcat启动日志: 08-Jun-2018 09:23:00.445 WARNING [localhost-startStop-1] org.apache.catalina.util.Sessio ...
- 欧拉筛,线性筛,洛谷P2158仪仗队
题目 首先我们先把题目分析一下. emmmm,这应该是一个找规律,应该可以打表,然后我们再分析一下图片,发现如果这个点可以被看到,那它的横坐标和纵坐标应该互质,而互质的条件就是它的横坐标和纵坐标的最大 ...
- 【XSY2772】数列 特征多项式 数学
题目描述 给你一个数列: \[ f_n=\begin{cases} a^n&1\leq n\leq k\\ \sum_{i=1}^k(a-1)f_{n-i}&n>k \end{c ...
- Ionic3的http请求如何实现token验证,并且超时返回登录页
要求 后台提供的接口,不能让人随便输入个链接就能访问,而是要加入一个token,token是动态的,每次访问的时候判断,有权限并且未过期的时候才可以访问接口. 后台的设计是 在登录的时候,首先要pos ...