2025.04.18|【Map】地图绘图技巧全解

Add circles
Add circles on a Leaflet map

Change tile
Several background tiles are offered by leaflet. Learn how to load them, and check the possibilities.

文章目录
- Add circles
- Change tile
- 2025.04.18【Map】| 地图绘图技巧全解
- 1. 准备工作
- 2. 地理区域着色图(Choropleth)
- 3. 气泡图(Bubble Map)
- 4. 连接图(Connection Map)
- 5. 变形图(Cartogram)
- 结语
2025.04.18【Map】| 地图绘图技巧全解
在生物信息学领域,地理信息系统(GIS)和地图可视化是分析和展示数据空间分布的重要工具。本文将介绍如何在R语言中使用不同的地图样式来创建静态和交互式地图。R-graph-gallery网站提供了丰富的地图绘制教程,包括如何根据不同的输入数据构建地图,但不涉及如何在地图上绘制数据点。这些地图样式包括但不限于:地理区域着色图(choropleth)、气泡图(bubble map)、连接图(connection map)和变形图(cartogram)。这些地图样式在生物信息学中尤其有用,可以帮助我们理解基因表达、疾病分布、物种多样性等数据的空间模式。通过这些教程,即使是初学者也能快速上手,利用R语言的强大功能,将复杂的空间数据转化为直观的地图可视化,从而更深入地分析和解释生物信息数据。
1. 准备工作
在开始之前,我们需要安装一些必要的R包。这些包将帮助我们绘制各种地图样式。打开R或RStudio,并运行以下代码来安装这些包:
install.packages("ggplot2") # 用于绘图
install.packages("maps") # 提供地图数据
install.packages("dplyr") # 数据处理
install.packages("sf") # 空间数据框架
2. 地理区域着色图(Choropleth)
地理区域着色图是一种展示区域数据的地图,其中每个区域的颜色深浅表示数据的大小。以下是如何使用R语言绘制一个简单的地理区域着色图:
library(ggplot2)
library(maps)# 获取世界地图数据
world_map <- map_data("world")# 创建一个示例数据框,包含国家的GDP
data <- data.frame(long = c(-54.8039, -77.0294, 114.1589),lat = c(-35.4437, -12.0931, 22.3193),country = c("Argentina", "Brazil", "China"),gdp = c(473000, 1834000, 14342900) # GDP单位:百万美元
)# 将国家名称与地图数据匹配
world_map$country <- world_map$region
world_map <- merge(world_map, data, by.x = "country", by.y = "country")# 绘制地理区域着色图
ggplot() +geom_polygon(data = world_map, aes(x = long, y = lat, group = group, fill = gdp),color = "white") +scale_fill_continuous(low = "lightblue", high = "darkblue") +labs(title = "世界GDP分布图", fill = "GDP (百万美元)")
3. 气泡图(Bubble Map)
气泡图通过在地图上绘制不同大小的气泡来展示数据的大小。以下是如何使用R语言绘制一个简单的气泡图:
library(ggplot2)
library(maps)# 获取美国地图数据
us_map <- map_data("state")# 创建一个示例数据框,包含各州的人口数量
data <- data.frame(state = c("Alabama", "Alaska", "Arizona"),population = c(4903185, 731545, 7278717) # 人口单位:人
)# 将州名与地图数据匹配
us_map$state <- us_map$region
us_map <- merge(us_map, data, by.x = "state", by.y = "state")# 绘制气泡图
ggplot() +geom_polygon(data = us_map, aes(x = long, y = lat, group = group, fill = population),color = "white") +scale_fill_gradient(low = "lightgreen", high = "darkgreen") +labs(title = "美国各州人口分布图", fill = "人口数量")
4. 连接图(Connection Map)
连接图通过在地图上绘制线条来展示不同地点之间的连接关系。以下是如何使用R语言绘制一个简单的连接图:
library(ggplot2)
library(maps)# 获取世界地图数据
world_map <- map_data("world")# 创建一个示例数据框,包含两个国家之间的距离
data <- data.frame(origin = c("China", "Germany"),destination = c("USA", "France"),distance = c(12000, 1500) # 距离单位:公里
)# 将国家名称与地图数据匹配
world_map$country <- world_map$region
world_map <- merge(world_map, data, by.x = "country", by.y = "origin")# 绘制连接图
ggplot() +geom_segment(data = data, aes(x = long.x, y = lat.x, xend = long.y, yend = lat.y,color = distance), size = 1) +scale_color_gradient(low = "grey", high = "red") +labs(title = "国家间距离连接图", color = "距离 (公里)")
5. 变形图(Cartogram)
变形图通过调整地图上区域的大小来展示数据的大小。以下是如何使用R语言绘制一个简单的变形图:
library(ggplot2)
library(maps)# 获取美国地图数据
us_map <- map_data("state")# 创建一个示例数据框,包含各州的面积
data <- data.frame(state = c("Alabama", "Alaska", "Arizona"),area = c(131728, 1717856, 295234) # 面积单位:平方公里
)# 将州名与地图数据匹配
us_map$state <- us_map$region
us_map <- merge(us_map, data, by.x = "state", by.y = "state")# 绘制变形图
ggplot() +geom_polygon(data = us_map, aes(x = long, y = lat, group = group, area = area),color = "white") +scale_area_continuous(range = c(1, 10)) +labs(title = "美国各州面积变形图", area = "面积 (平方公里)")
结语
通过上述步骤,我们学习了如何在R语言中使用不同的地图样式来创建静态和交互式地图。这些地图样式在生物信息学中尤其有用,可以帮助我们理解基因表达、疾病分布、物种多样性等数据的空间模式。希望这篇文章能够帮助你快速上手R语言的地图绘制功能,将复杂的空间数据转化为直观的地图可视化,从而更深入地分析和解释生物信息数据。
🌟 非常感谢您抽出宝贵的时间阅读我的文章。如果您觉得这篇文章对您有所帮助,或者激发了您对生物信息学的兴趣,我诚挚地邀请您:
👍 点赞这篇文章,让更多人看到我们共同的热爱和追求。
🔔 关注我的账号,不错过每一次知识的分享和探索的旅程。
📢 您的每一个点赞和关注都是对我最大的支持和鼓励,也是推动我继续创作优质内容的动力。
📚 我承诺,将持续为您带来深度与广度兼具的生物信息学内容,让我们一起在知识的海洋中遨游,发现更多未知的奇迹。
💌 如果您有任何问题或想要进一步交流,欢迎在评论区留言,我会尽快回复您。
相关文章:
2025.04.18|【Map】地图绘图技巧全解
Add circles Add circles on a Leaflet map Change tile Several background tiles are offered by leaflet. Learn how to load them, and check the possibilities. 文章目录 Add circlesChange tile 2025.04.18【Map】| 地图绘图技巧全解1. 准备工作2. 地理区域着色图&…...
PR第一课
目录 1.新建 2.PR内部设置 3.导入素材 4.关于素材窗口 5.关于编辑窗口 6.序列的创建 7.视频、图片、音乐 7.1 带有透明通道的素材 8.导出作品 8.1 打开方法 8.2 导出时,需要修改的参数 1.新建 2.PR内部设置 随意点开 编辑->首选项 中的任意内容&a…...
C# 预定义类型全解析
在 C# 编程中,预定义类型是基础且重要的概念。下面我们来详细了解 C# 的预定义类型。 预定义类型概述 C# 提供了 16 种预定义类型,包含 13 种简单类型和 3 种非简单类型。所有预定义类型的名称都由全小写字母组成。 预定义简单类型 预定义简单类型表…...
@EnableAsync+@Async源码学习笔记之六
接上文,我们本文分析 AsyncExecutionAspectSupport 的源码: package org.springframework.aop.interceptor;import java.lang.reflect.Method; import java.util.Map; import java.util.concurrent.Callable; import java.util.concurrent.CompletableFu…...
Java CMS和G1垃圾回收器
举个真带劲的例子:把JVM内存比作你家的祖传旱厕 想象你有个祖传旱厕,分三个坑: 新坑区(年轻代):刚拉的屎热乎着(新对象)陈年坑(老年代):风干的屎…...
Vue+Notification 自定义消息通知组件 支持数据分页 实时更新
效果图: message.vue 消息组件 子组件 <template><div class"custom-notification"><div class"content"><span click"gotoMessageList(currentMessage.split()[1])">{{ currentMessage.split()[0] }}</…...
不规则曲面上两点距离求取
背景 在CT中求皮肤上两点间的弧长。由于人体表面并不是规则的曲面,不可能用圆的弧长求取方法来计算出两点间的弧长。 而在不规则的曲面上求两点的距离,都可以用类似测地线距离求取的方式来求取(积分),而转化为搜索路…...
Redis面试问题缓存相关详解
Redis面试问题缓存相关详解 一、缓存三兄弟(穿透、击穿、雪崩) 1. 穿透 问题描述: 缓存穿透是指查询一个数据库中不存在的数据,由于缓存不会保存这样的数据,每次都会穿透到数据库,导致数据库压力增大。例…...
性能比拼: Elixir vs Go
本内容是对知名性能评测博主 Anton Putra Elixir vs Go (Golang) Performance (Latency - Throughput - Saturation - Availability) 内容的翻译与整理, 有适当删减, 相关指标和结论以原作为准 对比 Elixir 和 Go 简介 许多人长期以来一直要求我对比 Elixir 和 Go。在本视频…...
精益数据分析(6/126):深入理解精益分析的核心要点
精益数据分析(6/126):深入理解精益分析的核心要点 在创业和数据驱动的时代浪潮中,我们都在不断探索如何更好地利用数据推动业务发展。我希望通过和大家分享对《精益数据分析》的学习心得,一起在这个充满挑战和机遇的领…...
【Linux网络与网络编程】11.数据链路层mac帧协议ARP协议
前面在介绍网络层时我们提出来过一个问题:主机是怎么把数据交给路由器的?那里我们说这是由数据链路层来做的。 网络上的报文在物理结构上是以mac帧的形式流动的,但在逻辑上是以IP流动的,IP的流动是需要mac帧支持的。 数据链路层解…...
JAVA设计模式:注解+模板+接口
1.基础组件 1.1注解类控制代码执行启动、停止、顺序 /*** author : test* description : 数据同步注解* date : 2025/4/18*/ Target({ElementType.TYPE}) Retention(RetentionPolicy.RUNTIME) Documented public interface SyncMeta {/*** 执行服务名称* return*/String name…...
Linux系统编程 day6 进程间通信mmap
父子共享的信息:文件描述符,mmap建立的共享映射区(MAP_SHARED) mmap父子间进程通信 var的时候 :读时共享,写时复制 父进程先创建映射区,指定共享MAP_SHARED权限 , fork创建子进程…...
【MySQL】MySQL建立索引不知道注意什么?
基本原则: 1.选择性原则: 选择高选择性的列建立索引(该列有大量不同的值) 2.适度原则:不是越多越好,每个索引都会增加写入开销 列选择注意事项: 1.常用查询条件列:WHERE字句中频繁使用的列 2.连接操作列…...
定制一款国密浏览器(9):SM4 对称加密算法
上一章介绍了 SM3 算法的移植要点,本章介绍对称加密算法 SM4 的移植要点。 SM4 算法相对 SM3 算法来说复杂一些,但还是比较简单的算法,详细算法说明参考《GMT 0002-2012 SM4分组密码算法》这份文档。铜锁开源项目的实现代码在 sm4.c 文件中,直接拿过来编译就可以。 但需要…...
Redis 的持久化机制(RDB, AOF)对微服务的数据一致性和恢复性有何影响?如何选择?
Redis 的持久化机制(RDB 和 AOF)对于保证 Redis 服务重启或崩溃后数据的恢复至关重要,这直接影响到依赖 Redis 的微服务的数据一致性和恢复能力。 1. RDB (Redis Database Backup) 机制: 在指定的时间间隔内,将 Redis 在内存中的…...
lottie深入玩法
A、json文件和图片资源分开 delete 是json资源名字 /res/lottie/delete_anim_images是图片资源文件夹路径 JSON 中引用的图片名,必须与实际图片文件名一致 B、json文件和图片资源分开,并且图片加载不固定 比如我有7张图片,分别命名1~7&…...
Android学习总结之算法篇七(图和矩阵)
有向图的深度优先搜索(DFS)和广度优先搜索(BFS)的示例,以此来模拟遍历 GC Root 引用链这种有向图结构: 一、深度优先搜索(DFS) import java.util.*;public class GraphDFS {privat…...
docker 大模型
使用 Docker 实现大模型的步骤指南 在今天的文章中,我们将指导刚入行的小白如何使用 Docker 来运行大模型。Docker 是一个开放源代码的平台,允许开发者自动化应用程序的部署、扩展和管理。通过将大模型放入 Docker 容器中,我们可以确保其在各…...
热门与冷门并存,25西电—电子工程学院(考研录取情况)
1、电子工程学院各个方向 2、电子工程学院近三年复试分数线对比 学长、学姐分析 由表可看出: 1、电子科学与技术25年相较于24年上升20分 2、信息与通信工程、控制科学与工程、新一代电子信息技术(专硕)25年相较于24年下降25分 3、25vs24推…...
Warcraft Logs [Classic] [WCL] BOSS ID query
Warcraft Logs [Classic] [WCL] BOSS ID query 所有副本BOSSID查询 https://wowpedia.fandom.com/wiki/DungeonEncounterID#Retail IDNameMapInstanceIDPatch227High Interrogator GerstahnBlackrock Depths230228Lord RoccorBlackrock Depths230229Houndmaster GrebmarBlackro…...
python录屏工具实现
python录屏工具实现 实现一 按Ctrl+Shift+8开始录制,按Ctrl+Shift+9结束录制,视频保存到“ d:\录屏视频”目录中。 先看用了哪些库 import cv2: 引入 OpenCV 库,这是一个开源计算机视觉库,用于图像和视频处理。在这个程序中,它用于创建视频文件、处理图像等。需要安装ope…...
架构师面试(三十一):IM 消息收发逻辑
问题 今天聊一下 IM 系统最核心的业务逻辑。 在上一篇短文《架构师面试(三十):IM 分层架构》中详细分析过,IM 水平分层架构包括:【入口网关层】、【业务逻辑层】、【路由层】和【数据访问层】;除此之外&a…...
基于若依框架前后端分离的项目部署
文章目录 单项目的部署项目目录后端打包上传前端打包上传配置nginx服务器打开防火墙完成 两个项目的部署两个项目介绍后端打包并上传前端打包并上传nginx配置服务器端口开放完成 腾讯云服务器 之 环境搭建 单项目的部署 项目目录 后端打包上传 查看端口号 在ruoyi-admin的appl…...
黑马Java基础笔记-1
JVM,JDK和JRE JDK是java的开发环境 JVM虚拟机:Java程序运行的地方 核心类库:Java已经写好的东西,我们可以直接用。 System.out.print中的这些方法就是核心库中的所包含的 开发工具: javac(编译工具)、java&…...
面向新一代扩展现实(XR)应用的物联网框架
中文标题: 面向新一代扩展现实(XR)应用的物联网框架 英文标题: Towards an IoT Framework for the New Generation of XR Applications 作者信息 Joo A. Dias,UNIDCOM - IADE,欧洲大学,里斯本&…...
pcl各模块
参考资料: https://github.com/Ewenwan/MVision/blob/master/PCL_APP/1_%E7%82%B9%E4%BA%91%E6%BB%A4%E6%B3%A2filter.md 点云库PCL各模块学习 语雀 各模块依赖关系: 模块: common pcl_common中主要是包含了PCL库常用的公共数据结构和方…...
Oracle Recovery Tools修复ORA-600 6101/kdxlin:psno out of range故障
数据库异常断电,然后启动异常,我接手该库,尝试recover恢复 SQL> recover database; ORA-10562: Error occurred while applying redo to data block (file# 2, block# 63710) ORA-10564: tablespace SYSAUX ORA-01110: ???????? 2: H:\TEMP\GDLISNET\SYSAUX01.DBF O…...
Python网络编程从入门到精通:Socket核心技术+TCP/UDP实战详解
引言 网络编程是构建现代分布式系统的核心能力,而Socket作为通信的基石,其重要性不言而喻。本文将从零开始,通过清晰的代码示例、原理剖析和对比分析,带你彻底掌握Python中的Socket编程技术,涵盖TCP可靠连接、UDP高效…...
2025MathorcupC题 音频文件的高质量读写与去噪优化 保姆级教程讲解|模型讲解
2025Mathorcup数学建模挑战赛(妈妈杯)C题保姆级分析完整思路代码数据教学 C题:音频文件的高质量读写与去噪优化 随着数字媒体技术的迅速发展,音频处理成为信息时代的关键技术之一。在日常生活中,从录音设备捕捉的原始…...
