gma 地理空间绘图:(1) 绘制简单的世界地图-3.设置地图框

内容回顾

gma 地理空间绘图:(1) 绘制简单的世界地图-1.地图绘制与细节调整
gma 地理空间绘图:(1) 绘制简单的世界地图-2.设置经纬网

方法

SetFrame(FrameColor = ‘black’, FrameWidth = 0.6, ShowFrame = True, ShowLeft = True, ShowBottom = True, ShowRight = True, ShowTop = True, TickColor = ‘black’, TickLength = 0.01, TickWidth = 0.4, LabelTickPad = 0.005, Precision = 0, Uint = ‘D’, UseWESN = True, LabelFont = None, LabelFontSize = 5, LabelFontPROP = {}, LabelColor = ‘black’)


功能: 【设置地图框】。配置地图框的边框、标签和刻度。

可选参数:

  FrameColor = str||tuple||None。边框颜色。如果为 None,则生成随机颜色。详见:matplotlib。

  FrameWidth = float。边框线宽。默认 0.6。

以下参数在添加了经纬网(AddGridLines)之后才会生效。

  ShowLeft = bool。是否显示左侧经纬网标签和刻度线。 默认显示(True)。

  ShowBottom = bool。是否显示底部经纬网标签和刻度线。 默认显示(True)。

  ShowRight = bool。是否显示右侧经纬网标签和刻度线。 默认显示(True)。

  ShowTop = bool。是否显示顶部经纬网标签和刻度线。 默认显示(True)。

  TickColor = str||tuplt||None。刻度线颜色。如果为 None,则生成随机颜色。详见:matplotlib。

  TickLength = float。刻度线的相对长度。为相对于地图框 X 方向长度的倍数。默认 0.01 倍。

  TickWidth = float。刻度线线宽(字体单位)。默认 0.4 。

  LabelTickPad = float。刻度线与标签值之间的相对间距。为相对于地图框 X 方向长度的倍数。默认 0.005 倍。

  Precision = int。经纬网标度值保留的小数位数。默认不保留小数位(0)。

  Uint = str。经纬网标度值保留的单位。可以为 ‘D’(度)、 ‘DM’(度分)或 ‘DMS’(度分秒)。

  UseWESN = bool。经纬网标度值是否使用 ‘W’(西经)、‘E’(东经)、‘S’(南纬)、‘N’(北纬)。

  LabelFont = str||None。 标签字体。 默认(None)取决于 matplotlib 设置。

  LabelFontSize = float。 标签字体大小。默认为 7。

  LabelFontPROP = dict。 标签字体的其他属性。详见:matplotlib.font_manager.FontProperties。

  LabelColor = str||tuplt||None。标签字体的颜色。如果为 None,则生成随机颜色。详见:matplotlib。

返回:DataFrame。地图框绘制过程的详细数据。

添加和优化地图框

0.绘制默认的地图框

0.1 仅地图框

from gma.map import plot

# 0. 打开 gma 内置的世界矢量
WorldDS = plot.GetWorldDataSource()
WorldLayer = WorldDS.GetLayer(0)

# 1.初始化一个地图框,用于绘图
MapF = plot.MapFrame(Axes = None, BaseMapProj = 'WGS84', Extent = None)

# 2.将内置的世界矢量图层添加到地图框(为底图配置随机颜色,并修改边线线宽)
MapL1 = MapF.AddLayer(WorldLayer, LineWidth = 0.2)

# 4.设置地图框
Frame = MapF.SetFrame()

0.2 添加经纬网后

from gma.map import plot

# 0. 打开 gma 内置的世界矢量
WorldDS = plot.GetWorldDataSource()
WorldLayer = WorldDS.GetLayer(0)

# 1.初始化一个地图框,用于绘图
MapF = plot.MapFrame(Axes = None, BaseMapProj = 'WGS84', Extent = None)

# 2.将内置的世界矢量图层添加到地图框(为底图配置随机颜色,并修改边线线宽)
MapL1 = MapF.AddLayer(WorldLayer, LineWidth = 0.2)

# 3.添加经纬网(默认参数)
GridLines = MapF.AddGridLines(LONRange = (-180, 180, 30), LATRange = (-90, 90, 30))

# 4.设置地图框
Frame = MapF.SetFrame()

1.边框颜色和宽度

from gma.map import plot
import matplotlib.pyplot as plt

plt.figure(figsize = (7, 7), dpi = 300)

# 0. 打开 gma 内置的世界矢量
WorldDS = plot.GetWorldDataSource()
WorldLayer = WorldDS.GetLayer(0)

######################## 这里绘制两个图进行对比
## 定义两组参数
FramePar = [('black', 0.3),
            ('blue', 1)]

for i in range(2):
    Axes = plt.subplot(2, 1, i + 1)

    MapF = plot.MapFrame(Axes = Axes, BaseMapProj = 'WGS84', Extent = None)
    MapL1 = MapF.AddLayer(WorldLayer, LineWidth = 0.2)
    GridLines = MapF.AddGridLines(LONRange = (-180, 180, 30), LATRange = (-90, 90, 30))

    Frame = MapF.SetFrame(FrameColor = FramePar[i][0],
                          FrameWidth = FramePar[i][1])
    
    Axes.set_title(f'FrameColor = "{FramePar[i][0]}", FrameWidth = {FramePar[i][1]}', y = 0.98, fontsize = 9)

plt.tight_layout() 

2.左下右上刻度和标签显示

from gma.map import plot
import matplotlib.pyplot as plt

plt.figure(figsize = (7, 7), dpi = 300)

# 0. 打开 gma 内置的世界矢量
WorldDS = plot.GetWorldDataSource()
WorldLayer = WorldDS.GetLayer(0)

######################## 这里绘制两个图进行对比
## 定义两组参数
Show = [(True, False, False, False),
        (True, True, True, False)]

for i in range(2):
    Axes = plt.subplot(2, 1, i + 1)

    MapF = plot.MapFrame(Axes = Axes, BaseMapProj = 'WGS84', Extent = None)
    MapL1 = MapF.AddLayer(WorldLayer, LineWidth = 0.2)
    GridLines = MapF.AddGridLines(LONRange = (-180, 180, 30), LATRange = (-90, 90, 30))

    Frame = MapF.SetFrame(ShowLeft = Show[i][0],
                          ShowBottom = Show[i][1],
                          ShowRight = Show[i][2],
                          ShowTop = Show[i][3])
    
    Axes.set_title(f'ShowLeft = {Show[i][0]}, ShowBottom = {Show[i][1]}, ShowRight = {Show[i][2]}, ShowTop = {Show[i][3]}', 
                   y = 0.98, fontsize = 9)

plt.tight_layout() 

3.刻度和标签调整

from gma.map import plot
import matplotlib.pyplot as plt

plt.figure(figsize = (7, 7), dpi = 300)

# 0. 打开 gma 内置的世界矢量
WorldDS = plot.GetWorldDataSource()
WorldLayer = WorldDS.GetLayer(0)

######################## 这里绘制两个图进行对比
## 定义两组参数
Tick = [('black', 0.0, 0, 0.01),
        ('Red', 0.04, 1, 0.005)]

for i in range(2):
    Axes = plt.subplot(2, 1, i + 1)

    MapF = plot.MapFrame(Axes = Axes, BaseMapProj = 'WGS84', Extent = None)
    MapL1 = MapF.AddLayer(WorldLayer, LineWidth = 0.2)
    GridLines = MapF.AddGridLines(LONRange = (-180, 180, 30), LATRange = (-90, 90, 30))

    Frame = MapF.SetFrame(TickColor = Tick[i][0],
                          TickLength = Tick[i][1],
                          TickWidth = Tick[i][2],
                          LabelTickPad = Tick[i][3])
    
    Axes.set_title(f'TickColor = {Tick[i][0]}, TickLength = {Tick[i][0]}, TickWidth = {Tick[i][2]}, LabelTickPad = {Tick[i][3]}', 
                   y = 0.98, fontsize = 9)

plt.tight_layout() 

4.刻度值样式、精度设置

from gma.map import plot
import matplotlib.pyplot as plt

plt.figure(figsize = (7, 7), dpi = 300)

# 0. 打开 gma 内置的世界矢量
WorldDS = plot.GetWorldDataSource()
WorldLayer = WorldDS.GetLayer(0)

######################## 这里绘制两个图进行对比
## 定义两组参数
MarkerValue = [(0, 'D', False),
               (1, 'DMS', True)]

for i in range(2):
    Axes = plt.subplot(2, 1, i + 1)

    MapF = plot.MapFrame(Axes = Axes, BaseMapProj = 'WGS84', Extent = None)
    MapL1 = MapF.AddLayer(WorldLayer, LineWidth = 0.2)
    GridLines = MapF.AddGridLines(LONRange = (-180, 180, 35.5423), LATRange = (-90, 90, 30))

    Frame = MapF.SetFrame(Precision = MarkerValue[i][0],
                          Uint = MarkerValue[i][1],
                          UseWESN = MarkerValue[i][2])
    
    Axes.set_title(f'Precision = {MarkerValue[i][0]}, Uint = "{MarkerValue[i][1]}", UseWESN = {MarkerValue[i][2]}', 
                   y = 0.98, fontsize = 9)

plt.tight_layout() 

5.刻度值字体设置

from gma.map import plot
import matplotlib.pyplot as plt

plt.figure(figsize = (7, 7), dpi = 300)

# 0. 打开 gma 内置的世界矢量
WorldDS = plot.GetWorldDataSource()
WorldLayer = WorldDS.GetLayer(0)

######################## 这里绘制两个图进行对比
## 定义两组参数
Font = [('Times New Roman', 5, 'blue'),
        ('SimSun', 10, 'green')]

for i in range(2):
    Axes = plt.subplot(2, 1, i + 1)

    MapF = plot.MapFrame(Axes = Axes, BaseMapProj = 'WGS84', Extent = None)
    MapL1 = MapF.AddLayer(WorldLayer, LineWidth = 0.2)
    GridLines = MapF.AddGridLines(LONRange = (-180, 180, 30), LATRange = (-90, 90, 30))

    Frame = MapF.SetFrame(LabelFont = Font[i][0],
                          LabelFontSize = Font[i][1],
                          LabelColor = Font[i][2])
    
    Axes.set_title(f'LabelFont = {Font[i][0]}, LabelFontSize = "{Font[i][1]}", LabelColor = {Font[i][2]}', 
                   y = 0.98, fontsize = 9)

plt.tight_layout() 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

洛的地理研学

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值