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

2024-05-16 05:44

本文主要是介绍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 = ``

这篇关于uniapp使用地图开发app, renderjs使用方法及注意事项的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/994036

相关文章

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof