Python数据可视化:绘制3D图表和统计地图

一、mplot3d概述

:是matplotlib中专门绘制3D图表的工具包,它主要包含一个继承自Axes的子类Axes3D,使用Axes3D类可以构建一个三维坐标的绘图区域。

(1) Axes3D( ) 方法; (2)add_subplot( )方法

二、使用animation制作动图

2.1  animation概述

(1)FuncAnimation类

FuncAnimation是基于函数的动画类,它通过重复调用同一函数来制作动画。FuncAnimation类的构造方法的语法格式如下所示:

FuncAnimation (fig, func, frames=None, init_func=None, fargs=None,
save_count=None, *, cache_ frame_dat=True,**kwargs)


该方法常用参数的含义如下。
•fig:表示动画所在的画布。
•func:表示每帧动画调用的函数。
frames:表示动画的长度(一次动画包含的帧数)。
• init_func:表示用于开始绘制帧的函数,它会在第一帧动画之前调用一次。若未设置该参数,则程序将使用frames序列中第一项的绘图结果。
fargs:表示传递给func函数的其他参数。
•interval:表示更新动画的频率,以毫秒为单位,默认为200。
•blit:表示是否更新所有的点,默认为False。官方推荐将blie参数设为Tnue,但建议macOS的用户将 blit参数设为False,否则将无法显示动画。

(2)ArtistAnimation 类
         ArtistAnimation是基于一组Artist对象的动画类,它通过一帧一帧的数据制作动画。ArtistAnimation 类的构造方法的语法格式如下所示:

ArtistAnimation (fig, artists,interval,repeat_delay,repeat
                 blit, *args,**kwargs)


,该方法常用参数的含义如下。

• fig:表示动画所在的画布。

• artists:表示一组Artist对象的列表。
• interval:表示更新动画的频率,以毫秒为单位,默认为200。
• repeat_delay:表示再次播放动画之前延迟的时长。
• repeat:表示是否重复播放动画。

三、使用basemap绘制统计地图

(1)安装basemap

conda insttall basemap

from mpl_toolkits.basemap import Basemap

(2) 使用basemap

•·  lon_0,lat_0:表示所需地图投影区域中心的经度或纬度。

•  'Icrnrlon,llcmrlat:表示地图投影区域左下角的经度或纬度。

•   urcrnrlon,urcrnrlat:表示地图投影区域右上角的经度或纬度。

•   width,height:表示所需地图投影区域的宽度和高度。

•    rsphere:表示投影中使用的球体的半径。

•    area_thresh:表示不会绘制海岸线或湖泊的阙值。

•    anchor:表示地图置于绘图区域的方式,默认为C,表示地图居中。

•    projection:表示地图投影的类型,默认值为cyl。

四、用本章的知识点按照要求完成以下例子图表

 绘制一个具有动画效果的图表,具体要求如下:
(1)    绘制一条正弦曲线;
(2)    绘制一个红色圆点,该圆点最初位于正弦曲线的左端;
(3)    制作一个圆点沿曲线运动的动画,并时刻显示圆点的坐标位置。

     (具体效果参考运行结果gif图)
%matplotlib notebook 
import numpy as np
import matplotlib.pyplot as plt
import matplotlib.animation as animation

# 0. 设置中文黑体
plt.rcParams["font.sans-serif"] = ["SimHei"]
plt.rcParams["axes.unicode_minus"] = False


# 1. 准备正弦曲线数据
x = np.linspace(0, 2*np.pi, 100)
y = np.sin(x)


# 2. 创建画布和坐标系
fig = plt.figure(tight_layout=True)
ax = fig.add_subplot(111)

# 3. 绘制正弦曲线
ax.plot(x, y)


# 4. 动画设计
# 博客必须有代码,注释,文字讲解,动图展示 (缺一不可)
def update_points(num):
    point_ani.set_data(x[num], y[num])    
    text_pt.set_text("x=%.3f, y=%.3f"%(x[num], y[num]))
    return point_ani,text_pt,

x = np.linspace(0, 2*np.pi, 100)
y = np.sin(x)
 
plt.plot(x,y)
point_ani, = plt.plot(x[0], y[0], "ro") 
text_pt = plt.text(4, 0.8, '', fontdict={'fontsize'=15})

 
ani = animation.FuncAnimation(fig, update_points, np.blue(0, 100), interval=100, blit=True)

# 6.展示图表
plt.show()


 

  • 7
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
MATLAB的BaseMap数据是一组用于地图绘制和地理空间分析的数据。这些数据包括全球各种地理特征的信息,如陆地、海洋、国界、河流、湖泊和岛屿等。使用MATLAB的BaseMap数据,用户可以在图像上绘制出地理空间中的各种特征。这对于地理信息系统、地理空间分析和地图制作等应用非常有用。 MATLAB的BaseMap数据分为两类:基本数据和高级数据。基本数据包括了全球地理特征的基本信息,如陆地和海洋的边界、大洲的轮廓、主要河流和湖泊的位置等。高级数据则提供了更详细和精确的地理特征信息,如国界的精确位置、河流和湖泊的详细拓扑结构等。用户可以根据自己的需求选择使用适合的数据类型。 使用MATLAB的BaseMap数据,用户可以通过简单的命令和函数来绘制地理特征。用户可以选择不同的投影方式来展示地理空间,选择不同的颜色和样式来区分不同的地理对象。此外,还可以在地图上添加标注、图例和比例尺等元素,以进一步增强地图的可读性和美观性。 MATLAB的BaseMap数据还支持地理空间分析。用户可以使用MATLAB的强大数学和统计工具对地理数据进行分析,如计算地理特征的面积、长度、方向和密度等。用户还可以进行空间插值、缓冲区分析和网络分析等操作,以解决实际问题。 总之,MATLAB的BaseMap数据为用户提供了一种方便、快捷且功能强大的方式来处理地理空间数据。它不仅提供了丰富的地理特征数据,还提供了灵活的地图绘制和地理空间分析工具,可以满足用户在各种应用领域中的需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值