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)
随机推荐
- 【面试】MySQL的事务和索引
MySQL事务 MySQL事务主要用于处理操作量大,复杂度高的数据. 比如说,在人员管理系统中,你删除一个人员,你既需要删除人员的基本资料,也要删除和该人员相关的信息,如信箱,文章等等,这些数据库操作 ...
- mybatis源码分析(一)------------入门
在进行源码分析前,先写一个使用mybatis进行开发的demo,方便我们后面进行分析. 一 关于mybatis的demo pom.xml文件 <project xmlns="http ...
- MyBatis全局配置文件的各项标签3
mapper 将sql映射注册到全局配置中,这个我们在上一章已经使用过了, resource 这个属性是用来引用类路径下的sql映射文件 url 这个属性是用来引用网络路径或磁盘路径下的sql映射文件 ...
- liunx 运维知识二部分
Windows下的目录和Linux系统下的目录有什么区别? Windows目录下的文件一般都是分区(C盘,D盘...),C盘下面有什么目录,目录下面还有其他目录加上文件. Linux系统目录结构一切都 ...
- k8s调度器、预选策略及调度方式
一.k8s调度流程 1.(预选)先排除完全不符合pod运行要求的节点2.(优先)根据一系列算法,算出node的得分,最高没有相同的,就直接选择3.上一步有相同的话,就随机选一个 二.调度方式 1.no ...
- AI算法第三天【矩阵分析与应用】
- How to reset macOS Icon Cache
find . -name cuthead.txt find /private/var/folders/ -name 'com.apple.dock.iconcache' -delete find /p ...
- Previous Workflow Versions in Nintex Workflow
Previous Workflow Versions in Nintex Workflow September 4, 2013 It occurred to me that even though I ...
- bzoj2152-[国家集训队]聪聪可可
Description 聪聪和可可是兄弟俩,他们俩经常为了一些琐事打起来,例如家中只剩下最后一根冰棍而两人都想吃.两个人都想玩儿电脑(可是他们家只有一台电脑)--遇到这种问题,一般情况下石头剪刀布就好 ...
- Centos 7安装和配置 ElasticSearch入门小白
实验环境: 操作系统:Centos 7.5 服务器ip:192.168.1.198 运行用户:root 网络环境:Internet 在企业生产环境有很多服务器的时候.很多业务模块的日志的时候运维人员需 ...