pyecharts从入门到精通-地图专题BMap-世界地图和中国城市地图

本文主要是介绍pyecharts从入门到精通-地图专题BMap-世界地图和中国城市地图,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 参考
    • 安装与查看pyecharts
    • 地图实现-BMap
    • 案例演示
    • 案例演示-杭州热门旅行线路图
    • 拓展-pyecharts中BMap源码

参考

官方文档:https://pyecharts.org/#/zh-cn/quickstart
Bmap - Hiking_trail_in_hangzhou

安装与查看pyecharts

安装pyecharts

pip install pyecharts==2.0.3
# Successfully installed prettytable-3.7.0 pyecharts-2.0.3 simplejson-3.19.1

查看版本

import pyecharts
print(pyecharts.__version__) 
# 2.0.3

地图实现-BMap

pyecharts的地图实现包括:

Geo:地理坐标系
Map:地图
BMap:百度地图

本部分完成BMap坐标系实现。

案例演示

from pyecharts import options as opts
from pyecharts.charts import BMap
from pyecharts.faker import Fakerc = (BMap().add_schema(baidu_ak="FAKE_AK", center=[120.13066322374, 30.240018034923]).add("bmap",[list(z) for z in zip(Faker.provinces, Faker.values())],label_opts=opts.LabelOpts(formatter="{b}"),).set_global_opts(title_opts=opts.TitleOpts(title="BMap-基本示例")).render("bmap_base.html")
)

在这里插入图片描述

案例演示-杭州热门旅行线路图

import asyncio
from aiohttp import TCPConnector, ClientSessionfrom pyecharts.charts import BMap
from pyecharts import options as opts
from pyecharts.globals import BMapType, ChartTypeimport nest_asyncio
nest_asyncio.apply()async def get_json_data(url: str) -> dict:async with ClientSession(connector=TCPConnector(ssl=False)) as session:async with session.get(url=url) as response:return await response.json()# 获取官方的数据
data = asyncio.run(get_json_data(url="https://echarts.apache.org/examples/data/asset/data/hangzhou-tracks.json")
)map_data = [[y["coord"] for y in x] for x in data](BMap(init_opts=opts.InitOpts(width="1200px", height="800px")).add_schema(baidu_ak="FAKE_AK",# center=[120.13066322374, 30.240018034923],zoom=14,is_roam=True,map_style={"styleJson": [{"featureType": "water","elementType": "all","stylers": {"color": "#d1d1d1"},},{"featureType": "land","elementType": "all","stylers": {"color": "#f3f3f3"},},{"featureType": "railway","elementType": "all","stylers": {"visibility": "off"},},{"featureType": "highway","elementType": "all","stylers": {"color": "#fdfdfd"},},{"featureType": "highway","elementType": "labels","stylers": {"visibility": "off"},},{"featureType": "arterial","elementType": "geometry","stylers": {"color": "#fefefe"},},{"featureType": "arterial","elementType": "geometry.fill","stylers": {"color": "#fefefe"},},{"featureType": "poi","elementType": "all","stylers": {"visibility": "off"},},{"featureType": "green","elementType": "all","stylers": {"visibility": "off"},},{"featureType": "subway","elementType": "all","stylers": {"visibility": "off"},},{"featureType": "manmade","elementType": "all","stylers": {"color": "#d1d1d1"},},{"featureType": "local","elementType": "all","stylers": {"color": "#d1d1d1"},},{"featureType": "arterial","elementType": "labels","stylers": {"visibility": "off"},},{"featureType": "boundary","elementType": "all","stylers": {"color": "#fefefe"},},{"featureType": "building","elementType": "all","stylers": {"color": "#d1d1d1"},},{"featureType": "label","elementType": "labels.text.fill","stylers": {"color": "#999999"},},]},).add(series_name="",type_=ChartType.LINES,data_pair=map_data,is_polyline=True,is_large=True,linestyle_opts=opts.LineStyleOpts(color="purple", opacity=0.6, width=1),effect_opts=opts.EffectOpts(trail_length=0.5),).add_control_panel(copyright_control_opts=opts.BMapCopyrightTypeOpts(position=3),maptype_control_opts=opts.BMapTypeControlOpts(type_=BMapType.MAPTYPE_CONTROL_DROPDOWN),scale_control_opts=opts.BMapScaleControlOpts(),overview_map_opts=opts.BMapOverviewMapControlOpts(is_open=True),navigation_control_opts=opts.BMapNavigationControlOpts(),geo_location_control_opts=opts.BMapGeoLocationControlOpts(),).render("hiking_trail_in_hangzhou.html")
)

在这里插入图片描述

拓展-pyecharts中BMap源码

百度地图需要申请开发者 AK,官网申请。

class pyecharts.charts.BMap

class BMap(# 初始化配置项,参考 `global_options.InitOpts`init_opts: opts.InitOpts = opts.InitOpts()# 是否忽略不存在的坐标,默认值为 False,即不忽略is_ignore_nonexistent_coord: bool = False
)

func pyecharts.charts.BMap.add_schema

def add_schema(# 百度地图开发应用 appkey,请使用到百度地图的开发者自行到百度地图开发者中心# 注册百度 ak。baidu_ak: str,# 当前视角的中心点,用经纬度表示center: Optional[Sequence] = None,# 当前视角的缩放比例。zoom: Optional[Numeric] = None,# 是否开启鼠标缩放和平移漫游。is_roam: bool = True,# 地图样式配置项map_style: Optional[dict] = None,
)

func pyecharts.charts.BMap.add

def add(# 系列名称,用于 tooltip 的显示,legend 的图例筛选。series_name: str,# 数据项 (坐标点名称,坐标点值)data_pair: Sequence,# Geo 图类型,有 scatter, effectScatter, heatmap, lines 4 种,建议使用# from pyecharts.globals import GeoType# GeoType.GeoType.EFFECT_SCATTER,GeoType.HEATMAP,GeoType.LINEStype_: str = "scatter",# 是否选中图例is_selected: bool = True,# 标记图形形状symbol: Optional[str] = None,# 标记的大小symbol_size: Numeric = 12,# 系列 label 颜色color: Optional[str] = None,# 是否是多段线,在画 lines 图情况下is_polyline: bool = False,# 是否启用大规模线图的优化,在数据图形特别多的时候(>=5k)可以开启is_large: bool = False,# 开启绘制优化的阈值。large_threshold: Numeric = 2000,# 标签配置项,参考 `series_options.LabelOpts`label_opts: Union[opts.LabelOpts, dict] = opts.LabelOpts(),# 涟漪特效配置项,参考 `series_options.EffectOpts`effect_opts: Union[opts.EffectOpts, dict] = opts.EffectOpts(),# 线样式配置项,参考 `series_options.LineStyleOpts`linestyle_opts: Union[opts.LineStyleOpts, dict] = opts.LineStyleOpts(),# 提示框组件配置项,参考 `series_options.TooltipOpts`tooltip_opts: Union[opts.TooltipOpts, dict, None] = None,# 图元样式配置项,参考 `series_options.ItemStyleOpts`itemstyle_opts: Union[opts.ItemStyleOpts, dict, None] = None,
)

func pyecharts.charts.BMap.add_control_panel

def add_control_panel(# 地图的平移缩放控件navigation_control_opts: Union[opts.BMapNavigationControlOpts, dict, None] = None,# 缩略地图控件overview_map_opts: Union[opts.BMapOverviewMapControlOpts, dict, None] = None,# 比例尺控件scale_control_opts: Union[opts.BMapScaleControlOpts, dict, None] = None,# 切换地图类型的控件maptype_control_opts: Union[opts.BMapTypeControlOpts, dict, None] = None,# 版权控件,您可以在地图上添加自己的版权信息。# 每一个版权信息需要包含如下内容:版权的唯一标识、版权内容和其适用的区域范围。copyright_control_opts: Union[opts.BMapCopyrightTypeOpts, dict, None] = None,# 地图定位的控件,使用 HTML5 浏览器定位功能geo_location_control_opts: Union[opts.BMapGeoLocationControlOpts, dict, None] = None,
)

class pyecharts.options.BMapNavigationControlOpts
BMapNavigationControlOpts:地图的平移缩放控件

class BMapNavigationControlOpts(# 控件的停靠位置# ANCHOR_TOP_LEFT,控件将定位到地图的左上角,值为 0# ANCHOR_TOP_RIGHT,控件将定位到地图的右上角,值为 1# ANCHOR_BOTTOM_LEFT,控件将定位到地图的左下角,值为 2# ANCHOR_BOTTOM_RIGHT,控件将定位到地图的右下角,值为 3position: Numeric = BMapType.ANCHOR_TOP_LEFT,# 控件的水平偏移值offset_width: Numeric = 10,# 控件的竖直偏移值offset_height: Numeric = 10,# 平移缩放控件的类型# NAVIGATION_CONTROL_LARGE,标准的平移缩放控件(包括平移、缩放按钮和滑块,值为 0# NAVIGATION_CONTROL_SMALL,仅包含平移和缩放按钮,值为 1# NAVIGATION_CONTROL_PAN,仅包含平移按钮,值为 2# NAVIGATION_CONTROL_ZOOM,仅包含缩放按钮,值为 3type_: Numeric = BMapType.NAVIGATION_CONTROL_LARGE,# 是否显示级别提示信息is_show_zoom_info: bool = False,# 控件是否集成定位功能is_enable_geo_location: bool = False,
)

class pyecharts.options.BMapOverviewMapControlOpts
BMapOverviewMapControlOpts:缩略地图控件

class BMapOverviewMapControlOpts(# 控件的停靠位置# ANCHOR_TOP_LEFT,控件将定位到地图的左上角,值为 0# ANCHOR_TOP_RIGHT,控件将定位到地图的右上角,值为 1# ANCHOR_BOTTOM_LEFT,控件将定位到地图的左下角,值为 2# ANCHOR_BOTTOM_RIGHT,控件将定位到地图的右下角,值为 3position: Numeric = BMapType.ANCHOR_BOTTOM_RIGHT,# 控件的水平偏移值offset_width: Numeric = 10,# 控件的竖直偏移值offset_height: Numeric = 50,# 缩略地图添加到地图后的开合状态,默认为 False 关闭is_open: bool = False,
)

class pyecharts.options.BMapScaleControlOpts
BMapScaleControlOpts:比例尺控件

class BMapScaleControlOpts(# 控件的停靠位置# ANCHOR_TOP_LEFT,控件将定位到地图的左上角,值为 0# ANCHOR_TOP_RIGHT,控件将定位到地图的右上角,值为 1# ANCHOR_BOTTOM_LEFT,控件将定位到地图的左下角,值为 2# ANCHOR_BOTTOM_RIGHT,控件将定位到地图的右下角,值为 3position: Numeric = BMapType.ANCHOR_BOTTOM_RIGHT,# 控件的水平偏移值offset_width: Numeric = 10,# 控件的竖直偏移值offset_height: Numeric = 50,
)

BMapTypeControl:切换地图类型的控件
class pyecharts.options.BMapTypeControl

class BMapTypeControl(# 控件的停靠位置# ANCHOR_TOP_LEFT,控件将定位到地图的左上角,值为 0# ANCHOR_TOP_RIGHT,控件将定位到地图的右上角,值为 1# ANCHOR_BOTTOM_LEFT,控件将定位到地图的左下角,值为 2# ANCHOR_BOTTOM_RIGHT,控件将定位到地图的右下角,值为 3position: Numeric = BMapType.ANCHOR_TOP_RIGHT,# 地图类型属性# MAPTYPE_CONTROL_HORIZONTAL,按钮水平方式展示,默认采用此类型展示。值为 0# MAPTYPE_CONTROL_DROPDOWN,按钮呈下拉列表方式展示,值为 1# MAPTYPE_CONTROL_MAP,以图片方式展示类型控件,设置该类型后无法指定 maptypes 属性,值为 2type_: Numeric = BMapType.MAPTYPE_CONTROL_HORIZONTAL,
)

BMapCopyrightType:版权控件
class pyecharts.options.BMapCopyrightType

class BMapCopyrightType(# 控件的停靠位置# ANCHOR_TOP_LEFT,控件将定位到地图的左上角,值为 0# ANCHOR_TOP_RIGHT,控件将定位到地图的右上角,值为 1# ANCHOR_BOTTOM_LEFT,控件将定位到地图的左下角,值为 2# ANCHOR_BOTTOM_RIGHT,控件将定位到地图的右下角,值为 3position: Numeric = BMapType.ANCHOR_BOTTOM_RIGHT,# 控件的水平偏移值offset_width: Numeric = 10,# 控件的竖直偏移值offset_height: Numeric = 50,# Copyright 的文本内容, 可以放入 HTML 标签copyright_: str = "",
)

BMapGeoLocationControlOpts:地图定位的控件
class pyecharts.options.BMapGeoLocationControlOpts

class BMapGeoLocationControlOpts(# 控件的停靠位置# ANCHOR_TOP_LEFT,控件将定位到地图的左上角,值为 0# ANCHOR_TOP_RIGHT,控件将定位到地图的右上角,值为 1# ANCHOR_BOTTOM_LEFT,控件将定位到地图的左下角,值为 2# ANCHOR_BOTTOM_RIGHT,控件将定位到地图的右下角,值为 3position: Numeric = BMapType.ANCHOR_BOTTOM_RIGHT,# 控件的水平偏移值offset_width: Numeric = 10,# 控件的竖直偏移值offset_height: Numeric = 50,# 是否显示定位信息面板。默认显示定位信息面板is_show_address_bar: bool = True,# 添加控件时是否进行定位。默认添加控件时不进行定位is_enable_auto_location: bool = False,
)

在这里插入图片描述

这篇关于pyecharts从入门到精通-地图专题BMap-世界地图和中国城市地图的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

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

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

跨国公司撤出在华研发中心的启示:中国IT产业的挑战与机遇

近日,IBM中国宣布撤出在华的两大研发中心,这一决定在IT行业引发了广泛的讨论和关注。跨国公司在华研发中心的撤出,不仅对众多IT从业者的职业发展带来了直接的冲击,也引发了人们对全球化背景下中国IT产业竞争力和未来发展方向的深思。面对这一突如其来的变化,我们应如何看待跨国公司的决策?中国IT人才又该如何应对?中国IT产业将何去何从?本文将围绕这些问题展开探讨。 跨国公司撤出的背景与

【专题】2024飞行汽车技术全景报告合集PDF分享(附原数据表)

原文链接: https://tecdat.cn/?p=37628 6月16日,小鹏汇天旅航者X2在北京大兴国际机场临空经济区完成首飞,这也是小鹏汇天的产品在京津冀地区进行的首次飞行。小鹏汇天方面还表示,公司准备量产,并计划今年四季度开启预售小鹏汇天分体式飞行汽车,探索分体式飞行汽车城际通勤。阅读原文,获取专题报告合集全文,解锁文末271份飞行汽车相关行业研究报告。 据悉,业内人士对飞行汽车行业

数论入门整理(updating)

一、gcd lcm 基础中的基础,一般用来处理计算第一步什么的,分数化简之类。 LL gcd(LL a, LL b) { return b ? gcd(b, a % b) : a; } <pre name="code" class="cpp">LL lcm(LL a, LL b){LL c = gcd(a, b);return a / c * b;} 例题:

Java 创建图形用户界面(GUI)入门指南(Swing库 JFrame 类)概述

概述 基本概念 Java Swing 的架构 Java Swing 是一个为 Java 设计的 GUI 工具包,是 JAVA 基础类的一部分,基于 Java AWT 构建,提供了一系列轻量级、可定制的图形用户界面(GUI)组件。 与 AWT 相比,Swing 提供了许多比 AWT 更好的屏幕显示元素,更加灵活和可定制,具有更好的跨平台性能。 组件和容器 Java Swing 提供了许多

【IPV6从入门到起飞】5-1 IPV6+Home Assistant(搭建基本环境)

【IPV6从入门到起飞】5-1 IPV6+Home Assistant #搭建基本环境 1 背景2 docker下载 hass3 创建容器4 浏览器访问 hass5 手机APP远程访问hass6 更多玩法 1 背景 既然电脑可以IPV6入站,手机流量可以访问IPV6网络的服务,为什么不在电脑搭建Home Assistant(hass),来控制你的设备呢?@智能家居 @万物互联

poj 2104 and hdu 2665 划分树模板入门题

题意: 给一个数组n(1e5)个数,给一个范围(fr, to, k),求这个范围中第k大的数。 解析: 划分树入门。 bing神的模板。 坑爹的地方是把-l 看成了-1........ 一直re。 代码: poj 2104: #include <iostream>#include <cstdio>#include <cstdlib>#include <al

MySQL-CRUD入门1

文章目录 认识配置文件client节点mysql节点mysqld节点 数据的添加(Create)添加一行数据添加多行数据两种添加数据的效率对比 数据的查询(Retrieve)全列查询指定列查询查询中带有表达式关于字面量关于as重命名 临时表引入distinct去重order by 排序关于NULL 认识配置文件 在我们的MySQL服务安装好了之后, 会有一个配置文件, 也就

从戴尔公司中国大饭店DTF大会,看科技外企如何在中国市场发展

【科技明说 | 科技热点关注】 2024戴尔科技峰会在8月如期举行,虽然因事未能抵达现场参加,我只是观看了网上在线直播,也未能采访到DTF现场重要与会者,但是通过数十年对戴尔的跟踪与观察,我觉得2024戴尔科技峰会给业界传递了6大重要信号。不妨简单聊聊:从戴尔公司中国大饭店DTF大会,看科技外企如何在中国市场发展? 1)退出中国的谣言不攻自破。 之前有不良媒体宣扬戴尔将退出中国的谣言,随着2