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)
随机推荐
- [转帖]TCP和UDP的135、137、138、139、445端口的作用
TCP和UDP的135.137.138.139.445端口的作用 https://www.cnblogs.com/IvanChen/p/4500698.html 竟然不知道 端口具体是干什么的.. 如 ...
- [2018.05].NET Core 3 and Support for Windows Desktop Applications
.NET Core 3 and Support for Windows Desktop Applications Richard 微软官网的内容...net 3.0 升级任务 任重道远 https:/ ...
- PDO连接mysql数据库加载慢
今天在使用PDO连接mysql操作数据库的时候,发现速度特别慢,都1~2s的时间,不知道怎么回事,后来一步一步排除到new PDO 导致过慢的原因, 这个尴尬了...,调试了半天都没想到问下度娘,才知 ...
- 【转】 Golang输入输出格式化Printf Springf Fprintf..
// Go 在传统的`printf` 中对字符串格式化提供了优异的支持. // 这里是一些基本的字符串格式化的人物的例子. package main import "fmt" im ...
- C/S和B/S应用程序的区别
一.C/S和B/S介绍: 1.C/S介绍: Client/Server架构,即客户端/服务器架构.是大家熟知的软件系统体系结构,通过将任务合理分配到Client端和Server端,降低了系统的通讯开销 ...
- scrapy全站爬取拉勾网及CrawSpider介绍
一.指定模板创建爬虫文件 命令 创建成功后的模板,把http改为https 二.CrawSpider源码介绍 1.官网介绍: 这是用于抓取常规网站的最常用的蜘蛛,因为它通过定义一组规则为跟踪链接提供了 ...
- 无法将从VSS中的解决方案添加到TFS的源代码管理器中
VSS是一种非常有用的项目文件管理工具,百度百科的解释是:VSS 的全称为 Visual Source Safe .作为 Microsoft Visual Studio 的一名成员,它主要任务就是负责 ...
- How to execute a Stored Procedure with Entity Framework Code First
Recently I worked on a project, which I started as code first and then I forced to switch to Databas ...
- vuex2.0 基本使用(2) --- mutation 和 action
我们的项目非常简单,当点击+1按钮的时候,count 加1,点击-1按钮的时候,count 减1. 1, mutation The only way to actually change state ...
- Random Processes
对于信号处理来说,有一类信号是非常重要的,这类信号就是随机信号(random signal),也被称为随机过程(random processes/stochastic processes).在各种书籍 ...