微信小程序ec-canvas(echarts)显示地图【以甘肃省为例】

文章目录

  • 一、效果图
  • 二、实现
    • 1、下载echarts插件
    • 2、定制图形,生成 echarts.min.js 文件
    • 3、小程序中使用
      • (1)下载甘肃地图
      • (2)使用

参考文档《微信小程序使用echarts显示全国地图》《如何在微信小程序开发中使用echarts以及踩坑记录(最全教程)》

一、效果图

在这里插入图片描述

二、实现

1、下载echarts插件

  • echarts-for-weixin 项目提供了一个小程序组件,用这种方式可以方便地使用 ECharts
  • echarts-for-weixin 下载地址:https://github.com/ecomfe/echarts-for-weixin
  • 下载压缩包解压后如下图:

在这里插入图片描述

  • ec-canvas文件夹放置小程序的项目目录下( components或pages下 均可,根据个人习惯)

在这里插入图片描述

  • github 网页下载时,可以看到 ec-canvas 的版本号为 5.3.3 版本(定制图表时需要版本一致,若不定制可忽略)

在这里插入图片描述

2、定制图形,生成 echarts.min.js 文件

ec-canvas目录中的 echarts.js有些大(包含了所有图表),小程序后期上线对文件大小有要求,所以建议进行定制可减少文件大小占比。

  • 进入echarts官网
  • 点击下载

在这里插入图片描述

  • 点击在线定制
    在这里插入图片描述
  • 选择版本(必须和前面下载的ec-canvas中的echarts.js版本保持一致)
  • 选择需要定制的图表(我需要的是地图map和视觉映射visualMap),其它保持默认

在这里插入图片描述

  • 其它选项包保持默认,点击下载。

在这里插入图片描述

  • 下载完成后,把项目中 ec-canvas目录中的 echarts.js 文件替换为下载的文件:echarts.min.js

在这里插入图片描述

  • 注意: ec-canvas.jsimport引入的是原来的echarts.js文件,需要自己改成刚才下载的文件,如下图所示

在这里插入图片描述

3、小程序中使用

(1)下载甘肃地图

  • 下载地址:https://datav.aliyun.com/portal/school/atlas/area_selector
  • 搜索想要的地图节点,选择 JSON API(包含子域),我下载的是甘肃省
  • 复制链接并在新窗口打开,这个文件原本为json格式,我们在小程序项目的文件目录下新建一个 mapData.js ,将页面中的所有内容复制到这个js文件中并将其公开(module.exports = 页面上复制的内容)。

在这里插入图片描述
在这里插入图片描述

(2)使用

analysis.json文件中引入ec-canvas组件

 "usingComponents": {"ec-canvas": "../../ec-canvas/ec-canvas",},

analysis.js文件中引入 mapData.jsec-canvas 中的 echarts.js

import * as echartsAll from '../../ec-canvas/echarts.min'
import geoJson from './mapData';

在页面analysis.wxml文件

<view class="chatdt"><ec-canvas-all id="mychart-dom-area" canvas-id="mychart-area" ec="{{ dtMap }}"></ec-canvas-all>
</view>

在页面analysis.wxss文件

.chatdt {width: 750rpx;height: 750rpx;margin: 0 auto;
}

analysis.js文件

let defaultDtObj = {tooltip: {show: false,},visualMap: {type: 'continuous',inRange: {color: '#7ecac6', //地图用一种颜色显示,不同程度的话,写成数组形式的颜色},show: false},series: [{type: 'map',mapType: 'gansu',left: 10,right: 10,label: {normal: {show: true, //在省市区是否显示省市区名称formatter: '{b}\n{c}',fontSize: 10,lineHeight: 13,},},itemStyle: {borderColor: '#ffffff',emphasis: {areaColor: '#6aa4ce',borderWidth: 0},},animation: false,selectedMode: false,data: [{ name: '兰州', value: 0 },{ name: '平凉', value: 0 },{ name: '张掖', value: 0 },{ name: '酒泉', value: 0 },{ name: '白银', value: 0 },{ name: '庆阳', value: 0 },{ name: '嘉峪关', value: 0 },{ name: '武威', value: 0 },{ name: '临夏', value: 0 },{ name: '定西', value: 0 },{ name: '天水', value: 0 },{ name: '陇南', value: 0 },{ name: '甘南', value: 0 },{ name: '金昌', value: 0 },],}]
}
Page({data: {dtMap: {onInit: function (canvas, width, height, dpr) {dtChart = echartsAll.init(canvas, null, {width: width,height: height,devicePixelRatio: dpr // new});canvas.setChart(dtChart);echartsAll.registerMap('gansu', geoJson);dtChart.setOption(getDtOption());return dtChart;}},},getDtData() {let obj1 = { ...defaultDtObj }obj1.series[0].data = [{ name: '兰州', value: 10 },{ name: '平凉', value: 20 },{ name: '张掖', value: 30 },{ name: '酒泉', value: 40 },{ name: '白银', value: 41 },{ name: '庆阳', value: 15 },{ name: '嘉峪关', value: 10 },{ name: '武威', value: 20 },{ name: '临夏', value: 30 },{ name: '定西', value: 40 },{ name: '天水', value: 41 },{ name: '陇南', value: 15 },{ name: '甘南', value: 15 },{ name: '金昌', value: 15 },]dtChart.setOption(obj1)},onReady() {this.getDtData()}
})function getDtOption() {return defaultDtObj
}

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

山峰个数 - 华为OD统一考试

OD统一考试 分值: 100分 题解: Java / Python / C++ 题目描述 给定一个数组,数组中的每个元素代表该位置的海拔高度。0表示平地,>=1时表示属于某个山峰,山峰的定义为当某个位置的左右海拔均小于自己的海拔时,该位置为山峰。数组起始位置计算时可只满足一边的条件。 …

【node】 地址标准化 解析手机号、姓名、行政区

地址标准化 解析手机号、姓名、行政区 实现效果链接源码 实现效果 将东光县科技园南路444号马晓姐13243214321 解析为 东光县科技园南路444号 13243214321 河北省;沧州市;东光县;东光镇 马晓姐 console.log(address, phone, divisions,name);链接 API概览 源码 https://gi…

node.js+postman+mongodb搭建测试注册接口的实现

准备工作 申请一个免费的MongoDB 到https://www.mlab.com注册申请一个500M的MongoDB数据库。登录后手动在创建Databases下的Collections中手动创建一个数据库node_app。 在个人首页点击Connect获取node.js连接MongoDB数据库的字符串为 1 mongodbsrv://<username>:<…

Elasticsearch的 8.x常用api汇总

ES的查询语法比较复杂,对于初学者需要在不断练习中才会逐渐掌握,本文汇总了ES各种查询语法以及常用api,可以作为新手的实用笔记 首先,安装 Kibana! 下载Elasticsearch,官方下载页面;Elasticsearch 参考,官方文档;<

读书笔记-《数据结构与算法》-摘要6[快速排序]

快速排序 核心&#xff1a;快排是一种采用分治思想的排序算法&#xff0c;大致分为三个步骤。 定基准——首先随机选择一个元素最为基准划分区——所有比基准小的元素置于基准左侧&#xff0c;比基准大的元素置于右侧递归调用——递归地调用此切分过程 快排的实现与『归并排…

STP笔记总结

STP --- 生成树协议 STP&#xff08;Spanning Tree Protocol&#xff0c;生成树协议&#xff09;是根据 IEEE802.1D标准建立的&#xff0c;用于在局域网中消除数据链路层环路的协议。运行STP协议的设备通过彼此交互信息发现网络中的环路&#xff0c;并有选择地对某些端口进行阻…

C++ 指针基础

指针的定义 #define _CRT_SECURE_NO_WARNINGS #include <stdio.h>int main() {int a 10;printf("%p\n", &a); // &a 表示取&#xff08;a&#xff09;的地址 000000842FD9FB64// 存放指针&#xff08;地址&#xff09;的变量就是指针变量&#xff0c…

力扣第一题-两数之和[简单]

题目描述 给定一个整数数组 nums 和一个整数目标值 target&#xff0c;请你在该数组中找出 和为目标值 target 的那 两个 整数&#xff0c;并返回它们的数组下标。 你可以假设每种输入只会对应一个答案。但是&#xff0c;数组中同一个元素在答案里不能重复出现。 你可以按任…

UE4 图片环形轮播 蓝图

【需求】 图片环形轮播 任意图片之间相互切换 切换图片所需时间均为1s 两个图片之间切换使用就近原则 播放丝滑无闪跳 【Actor的组成】 每个图片的轴心都在原点 【蓝图节点】

内网穿透的应用-如何在群辉7.2中使用Docker安装并远程访问本地网心云容器魔方管理界面

文章目录 1. 拉取容器魔方镜像2. 运行容器魔方3. 本地访问容器魔方4. 群辉安装Cpolar5. 配置容器魔方远程地址6. 远程访问测试7. 固定公网地址 本文主要介绍如何在群辉7.2版本中使用Docker安装容器魔方&#xff0c;并结合Cpolar内网穿透工具实现远程访问本地网心云容器魔方界面…

CMS—评论功能设计

一、需求分析 1.1、常见行为 1.敏感词过滤 2.新增评论&#xff08;作品下、评论下&#xff09; 3.删除评论&#xff08;作品作者、上级评论者、本级作者&#xff09; 4.上级评论删除关联下级评论 5.逻辑状态变更&#xff08;上线、下线、废弃...&#xff09; 6.上逻辑状态变更…

如何在jenkins容器中安装python+httprunner+pytest+git+allure(一)

背景&#xff1a; API接口自动化使用python语言实现&#xff0c;利用httprunner框架编写自动化用例场景&#xff08;执行的时候还是依赖pytest),使用jenkins自动构建git上的源代码&#xff0c;并产生allure报告可视化展示API执行结果。 步骤 1.进入jenkins容器 注意使用roo…