当前位置: 首页 > news >正文

简述电子商务网站开发的基本流程易推广

简述电子商务网站开发的基本流程,易推广,山西省委组织部网站两学一做,河北手机网站制作哪家好文章目录 概要效果预览技术思路技术细节小结 概要 本篇文章还是关于最近做到的 mapboxgl 地图展开的。 借鉴官方示例:https://iclient.supermap.io/examples/mapboxgl/editor.html#heatMapLayer 效果预览 技术思路 将接口数据渲染到地图中形成热力图。还需要将热…

文章目录

    • 概要
    • 效果预览
    • 技术思路
    • 技术细节
    • 小结

概要

本篇文章还是关于最近做到的 mapboxgl 地图展开的。
借鉴官方示例:https://iclient.supermap.io/examples/mapboxgl/editor.html#heatMapLayer

效果预览

请添加图片描述

技术思路

  1. 将接口数据渲染到地图中形成热力图。
  2. 还需要将热力图中渲染的点做鼠标移上显示详情 popup 的效果。

注意:因为热力图本身不可以添加鼠标以上效果,所以还是使用了点,将鼠标以上效果加给点,然后把点的透明度设置为0,大小和热力图中点相同,即可完成上图中效果。

技术细节

  1. 地图的加载不再赘述,之前文章中写到了。
  2. 所需要规范的点数据
    其中point是自定义的,传啥都可以, createPopupStyle 就是生成 popup 的 html
featuresList.push({'type': 'Feature','properties': {...point,'description': that.createPopupStyle(point)},'geometry': {'type': 'Point','coordinates': [Number(point.lng), Number(point.lat)]}})
  1. 新建热力图
/*** 添加热力图*/
createHeatPoints(featuresList) {const that = thisconst map = this.map      let heatMapLayer = new mapboxgl.supermap.HeatMapLayer("heatMap",{"map": map,"id": "heatmap","radius": 50,// 设置图层透明度:(参数方式)"opacity": 0.6,// featureWeight指定以哪个属性值为热力权重值创建热力图:"featureWeight": "value",});let heatPoints = {"type": "FeatureCollection","features": featuresList};heatMapLayer.addFeatures(heatPoints);//        设置图层透明度:(函数方式)//        heatMapLayer.setOpacity(0.5);map.addLayer(heatMapLayer);      
},
  1. 添加透明度为0的点以及鼠标移上效果
/*** 添加坐标点及鼠标移上效果*/
addPoints(featuresList) {      const map = this.mapmap.addSource('places', {'type': 'geojson','data': {'type': 'FeatureCollection','features': featuresList}})// 加载 circle 定位圆let img = {name: 'circle_img',sdf: true}this.addCircleImage(img)map.addLayer({'id': 'places','type': 'symbol','source': 'places','layout': {'icon-image': img.name, // 图标ID'icon-size': 0.4, // 图标的大小// 'icon-size': ['get', 'imgSize'], // 图标的大小'icon-anchor': 'center', // 图标的位置// 'text-field': ['get', 'num'],},'paint': {'text-color': '#333','icon-color': 'rgba(0,0,0,0)'},});// Create a popup, but don't add it to the map yet.const popup = new mapboxgl.Popup({closeButton: false,closeOnClick: false});map.on('mouseenter', 'places', (e) => {// Change the cursor style as a UI indicator.map.getCanvas().style.cursor = 'pointer';// Copy coordinates array.const coordinates = e.features[0].geometry.coordinates.slice();const description = e.features[0].properties.description;// Ensure that if the map is zoomed out such that multiple// copies of the feature are visible, the popup appears// over the copy being pointed to.while (Math.abs(e.lngLat.lng - coordinates[0]) > 180) {coordinates[0] += e.lngLat.lng > coordinates[0] ? 360 : -360;}// Populate the popup and set its coordinates// based on the feature found.popup.setLngLat(coordinates).setHTML(description).addTo(map);});map.on('mouseleave', 'places', () => {map.getCanvas().style.cursor = '';popup.remove();});
},
  1. 引入图片使用方法
    注意:vue中引入图片要使用require引入,路径不能以传参的形式传入,最好写相对路径。不然都会报错。
/**
* 引入图片* img obj : name, sdf*/
addCircleImage(img) {const map = this.mapmap.loadImage(require('./circle.png'), (error, image) => {if (error) throw error;if (!map.hasImage(img.name)) map.addImage(img.name, image, {sdf: img.sdf || false});})
}

小结

本方法主要还是使用点和热力图重叠同时显示效果。

http://www.zhongyajixie.com/news/21552.html

相关文章:

  • 服务好的南昌网站制作网络营销课程有哪些
  • wordpress固定链接精简seo搜索引擎招聘
  • 网站建设规划方案.ppt太原seo建站
  • 深圳网站建设外包公司搜索引擎推广的常见形式有
  • 现在还可以做夺宝网站百度搜索推广是什么
  • 做网站放博彩广告哪些平台可以发布软文
  • 58网站怎么样做效果会更好惠州seo外包服务
  • 在线做头像网站有哪些seo优化网站网页教学
  • 网站建设要那些收费项百度关键词排名原理
  • 睢宁做网站城关网站seo
  • 做竞价的网站可以做优化吗今日头条最新版
  • 服装官网网站建设如何在百度上打广告
  • 网络工程师证深圳百度推广seo公司
  • 网站销售怎么做的长春网站建设设计
  • 苹果软件做ppt模板下载网站黑帽seo联系方式
  • 长春做网站用的软件网站查找工具
  • 做物流网站注意什么cps推广接单平台
  • 南宁手机网站制作b站视频推广网站
  • 滴滴注册网站百度网盘电脑版
  • 做问卷的网站有哪些广告公司业务推广
  • 投票网站怎么做的石家庄关键词排名提升
  • 神马网站可以做兼职山东关键词优化联系电话
  • 美食网站联系我们怎么做国外推广网站有什么
  • 网站建设公司是什么seo引擎优化外包
  • 做网站怎么连数据库什么网站都能进的浏览器
  • 国内设计师个人网站seo管理软件
  • 申请网站一年多少钱指数运算法则
  • 枣强网站建设代理品牌营销推广公司
  • 用jquery做网站好吗大数据比较好的培训机构
  • 网站为什么做静态深圳网站关键词