uniapp使用地图开发app, renderjs使用方法及注意事项

上次提到uniapp开发地图app时得一些问题,最后提到使用renderjs实现app中使用任何地图(下面将以腾讯地图为例,uniapp中写app时推荐使用得是高德地图,无法使用腾讯地图(renderjs方式除外))。

1、renderjs介绍,这里直接参照uniapp开发官网介绍即可:renderjs | uni-app官网

 

官网也有示例,示例是使用echart得,不过使用方法和地图相类似。

下面先看一下demo效果:

 

这是一个app中使用地图得makers,点击单个makers会显示对应得图片在上面,并且点击得maker会被放大,这个功能使用uniapp得map组件时是会有很大得问题得,再次就不再赘述。下面看看代码实现。

1、先来看看整个页面得组成(文章最后附上相关示例代码):

从上面可以看到script标签有两个,一个是普通得script标签,另一个是lang="renderjs"得标签。

2、注意事项:上面提到得renderjs中,module得名字需要和template上得标签名称一致,如图:

 

mapModule.update中update是该模块下面得一个方法。

3、接下来介绍一下

<view class="curr" id="container" :prop="mapModel" :change:prop="mapModule.update"></view>

改代码,mapModel为script普通标签里面得一个响应式变量

:change:prop="mapModule.update" 含义,当script里面得mapModel数据发生变化时,会通过该处触发renderjs里面得update方法。

4、renderjs中不能使用http请求,相关请求只能放在普通标签里面,renderjs仅根据数据变化做逻辑处理(可以理解为一个子组件)

5、最后附上相关代码(mapDemo.vue):

<template><view class="index-wrap"><view class="curr-position" @click="mapModule.setPosition"><image src="../../static/mapImg/5.png"></image></view><view class="curr" id="container" :prop="mapModel" :change:prop="mapModule.update"></view></view>
</template><script>
export default {components: { IndexTabs, UpdateApp },data() {return {showMenu: false,id: 0, // 使用 marker点击事件 需要填写idmapModel: {}};},computed: {getShow() {if (this.showMenu) {return true;} else {const timer = setTimeout(() => {clearTimeout(timer);return false;}, 3000)}}},methods: {init() {this.mapModel = {markerLatlng: [{ lat: 40.77460069719003, lng: 114.8868407358159 },{ lat: 40.7746130606868, lng: 114.88729786752276 },{ lat: 40.7746130606868, lng: 114.88739786752276 },{ lat: 40.77465839357235, lng: 114.88736317180303 },]}}}};
</script><script module="mapModule" lang="renderjs">import {initScript,getMap,getLatLng,getMultiMarker,getGeometriesItem,getFitBounds} from '../../utils/tmap';import {getPosition} from '../../utils/utils';export default {data() {return {ownerInstance: null,  map: null,center: null,marker: null,infoWindow: null,currPosition: {},mapModel: {},};},methods: {async setPosition(){this.currPosition = await getPosition()this.center = getLatLng(this.currPosition.lat, this.currPosition.lng)this.map.setCenter(this.center)},init(){this.ownerInstance.ownerInstance('init')},async refresh() {// 待处理if(this.mapModel.markerLatlng.length){const first = this.mapModel.markerLatlng[0]this.center = getLatLng(first.lat, first.lng)}if(this.map){getFitBounds(this.map, this.mapModel.markerLatlng)}else{this.map = getMap(this.center);}getFitBounds(this.map, this.mapModel.markerLatlng, 0.2)this.marker = getMultiMarker(this.map, this.mapModel.markerLatlng.map((item, index )=> getGeometriesItem(item, 'marker'+index)))this.marker.on('click', this.onMarker)},onMarker(e){const markers = this.marker.geometries.map(item => item.id === e.geometry.id ? {...item, styleId: 'currMarker'} : {...item, styleId: 'marker'})this.marker.updateGeometries(markers)this.dealInfoWindow(e.geometry.position)},dealInfoWindow(center){if(this.infoWindow){this.infoWindow.close()}this.infoWindow = new TMap.InfoWindow({map: this.map,position: center,offset: {x: 0, y: -80},content: "<div><img src='https://mapapi.qq.com/web/lbs/javascriptGL/demo/img/em.jpg'></div>"});},update(newValue, _, ownerInstance) {this.mapModel = newValueif (this.ownerInstance) {this.refresh()} else {this.ownerInstance = ownerInstance;initScript(this.init)}}}};
</script><style lang="scss" scoped>
.index-wrap {height: 100vh;width: 100%;display: flex;flex-direction: column;justify-content: center;.curr-position {position: fixed;bottom: 340rpx;right: 32rpx;z-index: 1001;display: flex;justify-content: center;align-items: center;background: #fff;border-radius: 12rpx;height: 80rpx;width: 80rpx;image {display: inline-block;width: 48rpx;height: 48rpx;}}.curr {display: flex;justify-content: center;align-items: center;flex: 1;}.map-container {flex: 1;width: 100%;height: 100%;z-index: 100;display: block;// transition: all 0 ease-in-out 0;&.active {display: none;// transition: all 0 ease-in-out 0.3s;}// margin-top: 200rpx;}
}
</style>

下面时renderjs中引入得utils.js和tmap.js:

utils.js

/*** @description 通过uni.getLocation获取相关地理信息* @returns*/
export function getPosition() {return new Promise((resolve) => {uni.getLocation({type: "gcj02",//"wgs84",geocode: true,timeout: 6,fail: () => {resolve({ ...getLocationLatLng(), errMsg: "getLocation:fail" });},success: (res) => {const {province, city, district, street, streetNum, poiName} = res.addressconst params = {...res,latitude: res.latitude,longitude: res.longitude,address_info: `${province}${city}${district}${street}${streetNum}`,address: poiName,};uni.setStorageSync("LatLng", JSON.stringify(res));resolve(params);},});const timer = setTimeout(() => {clearTimeout(timer);resolve({ ...getLocationLatLng(), errMsg: "getLocation:fail" });}, 1000);});
}

tmap.js: (key值需要替换成你自己项目中地图的key)

import {icon1} from './mapIcon'
const key = '此处为你申请的腾讯地图得key'export function getLocation() {return new TMap.maps.Geolocation(key, "腾讯地图API示例")
}export function initScript(callback) {var script = document.createElement("script");script.type = "text/javascript";script.src = "https://map.qq.com/api/gljs?v=1.exp&key=" + key;// script.src = "https://map.qq.com/api/js?v=2.exp&key=";document.body.appendChild(script);script.onload = () => {callback()}
}export function getMap(center, id, zoom = 15) {return new TMap.Map(document.getElementById(id || 'container'), {center,//设置地图中心点坐标zoom,   //设置地图缩放级别showControl: false,})
}/*** * @param {Number} lat 经度* @param {Number} lng 维度* @returns */
export function getLatLng(lat, lng) {return new TMap.LatLng(lat, lng);
}/*** @description 获取路径数组* @param {Array} pathList 经纬度数组 * @returns */
export function getPath(pathList) {return pathList.map(item => getLatLng(item.lat, item.lng));
}/*** @description 地图设置会放路径* @param {Object} map 地图对象 * @param {Array} pathList 路径数组 * @returns */export function getPolylineLayer(map, pathList) {return new TMap.MultiPolyline({map, // 绘制到目标地图// 折线样式定义styles: {style_blue: new TMap.PolylineStyle({color: '#3777FF', // 线填充色width: 4, // 折线宽度borderWidth: 2, // 边线宽度borderColor: '#FFF', // 边线颜色lineCap: 'round', // 线端头方式eraseColor: 'rgba(190,188,188,1)',}),},geometries: [{id: 'erasePath',styleId: 'style_blue',paths: getPath(pathList),},],})
}/*** * @param {Object} LatLng 经纬度对象{lat,lng} * @param {String} id  标注点Id* @param {String} styleId 样式id* @returns */
export function getGeometriesItem(LatLng, id, styleId = 'marker') {return { //点标注数据数组id,styleId,"position": getLatLng(LatLng.lat, LatLng.lng),// "properties": {//     "title": "marker"// }}
}export function getMarkerUrlByType(type) {return 'static/mapImg/marker.png'
}export function getMarkerStyle(key, src, width = 70, height = 70) {return {[key]: new TMap.MarkerStyle({width,height,src,})}
}export function getMultiMarker(map, geometries) {return new TMap.MultiMarker({id: "marker-layer", //图层idmap,styles: { //点标注的相关样式...getMarkerStyle('marker', icon1),...getMarkerStyle('currMarker', icon1, 90, 90),'car': new TMap.MarkerStyle({width: 40,height: 40,anchor: {x: 20,y: 20,},faceTo: 'map',rotate: 180,src: icon1// src: 'https://mapapi.qq.com/web/lbs/javascriptGL/demo/img/car.png',})},geometries});
}function getfitBoundItemNum(base, add){return base + add
}/*** * @param {Object} map 地图对象 * @param {Array} latlngList 坐标点集合,示例:[{lat: 0, lng: 0}] */
export function getFitBounds(map, latlngList, scale = 1) {let latlist = []let lnglist = []latlngList.forEach(item => {latlist.push(item.lat)lnglist.push(item.lng)})const latMax = Math.max(...latlist) const latMin = Math.min(...latlist) const lngMax = Math.max(...lnglist) const lngMin = Math.min(...lnglist)const latDiff = (latMax - latMin) * scaleconst lngDiff = (lngMax - lngMin) * scaleconst ne = getLatLng(getfitBoundItemNum(latMax, latDiff), getfitBoundItemNum(lngMax, lngDiff))const sw = getLatLng(getfitBoundItemNum(latMin, -latDiff*2.5), getfitBoundItemNum(lngMin, -lngDiff))const latLngBounds = new TMap.LatLngBounds(sw, ne)map.fitBounds(latLngBounds); //根据指定的范围调整地图视野
}

 mapIcon.js(图片base64字符串),注意:腾讯地图中图片地址必须是绝对地址,如果你们可以使用相对地址,欢迎留言讨论:


export const icon1 = ``

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/3032602.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

力扣HOT100 - 279. 完全平方数

解题思路&#xff1a; 动态规划 class Solution {public int numSquares(int n) {int[] dp new int[n 1];// 初始化dp数组&#xff0c;默认最坏情况是每个数都是由1相加得到的for (int i 1; i < n; i) {dp[i] i;}for (int i 1; i < n; i) {for (int j 1; j * j &…

【案例教程】土地利用/土地覆盖遥感解译与基于CLUE模型未来变化情景预测

查看原文>>>土地利用/土地覆盖遥感解译与基于CLUE模型未来变化情景预测 土地利用/土地覆盖数据是生态、环境和气象等领域众多模型的重要输入参数之一。基于遥感影像解译&#xff0c;可获取历史或当前任何一个区域的土地利用/土地覆盖数据&#xff0c;用于评估区域的生…

【挑战全网】最全高德地图充电桩接入指南,流量必火!

分享《一套免费开源充电桩物联网系统&#xff0c;是可以立马拿去商用的&#xff01;》 一、和高德直接互联互通的优势&#xff1a; 1、高德官方直接互联互通&#xff0c;提供给合作商户独立发展自主权&#xff0c;不依赖任何第三方平台; 2、自己控制电站的上线、下线、修改电…

Pytorch代码基础—张量

Pytorch代码—张量 Pytorch张量 张量的属性&#xff1a; data&#xff1a;被包装的Tensorgrad&#xff1a;data的梯度grad_fn:创建Tensor的Function&#xff0c;是自动求导的关键requires_grad&#xff1a;指示是否需要梯度isleaf&#xff1a;指示是否是叶子结点&#xff0…

多维 HighChart

showHighChart.html <!DOCTYPE html> <html lang"zh-CN"><head><meta charset"UTF-8"><!-- js脚本都是官方的,后两个是highchart脚本 --><script type"text/javascript" src"jquery1.7.1.min.js"&g…

麒麟 V10 安装docker2

1. 查看系统版本 2.安装docker-ce 添加源 yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo 安装docker yum install docker-ce --allowerasing 重启docker systemctl start docker 3.安装nvidia-container-runtime 添…

Spring初学入门(跟学笔记)

一、Spring概述 Spring是一款主流的Java EE轻量级开源框架。 Spring的核心模块&#xff1a;IoC&#xff08;控制反转&#xff0c;指把创建对象过程交给Spring管理 &#xff09;、AOP&#xff08;面向切面编程&#xff0c;在不修改源代码的基础上增强代码功能&#xff09; 二、…

MT2057 门票

思路&#xff1a; 此题是求有多少个区间的平均值>t&#xff0c; 那么可以把每个值-t。如果新的数列的某个区间的和>0&#xff0c;那么说明这个区间满足条件。 令新数列的前缀和为b[i]&#xff0c;所以求[i, j]区间是否满足条件&#xff0c;即求b[j]-b[i-1]是否>0&am…

端午佳节,品尝食家巷传统面点与黄米粽子礼盒

端午佳节&#xff0c;品尝食家巷传统面点与黄米粽子礼盒 在这个端午节来临之际&#xff0c;食家巷倾情推出一款别具特色的端午礼盒&#xff0c;将甘肃的传统面点与地方特色黄米粽子完美融合&#xff0c;为您带来一场美味与传统的邂逅。 这款礼盒以甘肃传统面点一窝丝、油饼和烤…

Python GUI开发- PyQt5 开发小工具环境入门

前言 常见的python开发gui的库有 Tkinter&#xff0c; PyQt5&#xff0c; wxPython等。本教程是选择PyQt5 开发桌面小工具。 环境准备 只需pip安装即可快速准备好开发环境 pip install pyqt5快速开始 创建一个空的window窗口 Qapplication()&#xff1a;每个GUI都必须包含…

如何安全高效地进行4S店文件分发,保护核心资产?

4S店与总部之间的文件分发是确保双方沟通顺畅、信息共享和决策支持的重要环节。4S店文件分发涉及到以下文件类型&#xff1a; 销售报告&#xff1a;4S店需要定期向总部提交销售报告&#xff0c;包括销售数量、销售额、市场份额等关键指标。 库存管理文件&#xff1a;包括车辆库…

电脑版的学浪课程下载方法

想在你的电脑上无限制地访问你最爱的学浪课程吗&#xff1f;现在&#xff0c;让我揭秘如何用几个简单步骤&#xff0c;轻松下载任何学浪课程到你的电脑&#xff0c;让学习不再受时间和地点的限制&#xff0c;随时随地都是你的课堂。 下载学浪视频的工具&#xff0c;我已经打包…

使用python开发的闭运算调试器

使用python开发的开运算调试器 简介效果代码 简介 用来调试闭运算效果的小工具&#xff0c;滑动条可以控制滤波核的大小&#xff0c;用来查看不同滤波核下的闭运算效果。 效果 代码 import sys from PyQt5.QtWidgets import QApplication, QWidget, QVBoxLayout, QHBoxLayou…

《新生向》什么是Python环境?

观前提醒&#xff1a;本文详细介绍了Python环境的结构&#xff0c;介绍了python虚拟环境基础用法&#xff0c;以及python中的环境&依赖管理 0.什么是Python环境 Python环境是指一个特定的设置&#xff0c;其中包含了运行Python代码所需的一系列软件工具和包。这个环境可以…

TiDB学习2:TiDB Sever

目录 1. TiDB Server架构 2. sql语句的解析和编译 2.1 Parse ​编辑 2.2 compile 3. 行转化为KV对(聚簇表) ​编辑4. SQL 读写相关模块 4.1 DistSQL(复杂查询) 4.2 KV(简单查询) 5. 在线DDL相关模块 6. GC机制与相关模块 7. TiDB Server的缓存 8. 热点小表缓存 9. …

【数据结构】图和基本算法

文章目录 1. 图的基本概念1.1 图本身的定义1.2 相关概念 2. 图的存储结构2.1 邻接矩阵2.2 邻接表 3. 图的遍历3.1 广度优先遍历&#xff08;BFS&#xff09;3.2 深度优先遍历&#xff08;DFS&#xff09; 4. 最小生成树4.1 Kruskal算法4.2 Prim算法 5. 最短路径5.1 单源最短路径…

【Linux】用户组、用户、文件权限(ugo权限),权限掩码,chmod,chown,suid,sgid,sticky,su,sudo

用户组 注意&#xff1a;普通用户只能查看有哪些组&#xff0c;不能创建/修改/删除&#xff0c;会提示&#xff1a;用户名 is not in the sudoers file.This incident will be reported. groupadd 用户组名新建用户组cat /etc/group查看有哪些组&#xff08;普通用户可以操作…

关于DOCKER启动后如何添加新的端口映射

前段时间在用docker部署服务的时候发现&#xff0c;容器已经启动&#xff0c;但是需要新的端口映射&#xff08;即容器在启动的时候只进行了部分的端口映射&#xff09;&#xff0c;经过查询资料后发现现在网上有2种方法&#xff0c;一中是修改json文件。另一种是将已经运行的容…

FreeRtos内核源码分析(九)——协程

目录 一、协程简介 二、协程工作机制 2.1 协程控制块结构 2.2 协程管理方式 2.3 协程调度方式 2.4 协程通信机制 三、协程状态及状态切换 3.1 协程状态 3.2 状态切换 四、协程创建 五、协程调度分析 5.1 源码分析 5.2 逻辑图分析 六、协程通信 6.1 协程发送消息…

Centos7 配置 DNS服务器

Centos 7 配置DNS服务器 环境描述&#xff1a; 一台服务器和一台用于测试的客户机 服务器IP&#xff1a;192.168.200.132 客户机IP&#xff1a;192.168.200.143 服务器配置 yum install bind bind-utils -y #安装软件包vim /etc/named.conf //编辑named主配置文件listen-on p…