通过上文[[Python 快速实现栅格地图(2)]]]可进行快速的地图搭建。如果需要添加一些始末点方便可视化,方法也比较简单。只需更改你的map_test地图中的值即可。

代码实现:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
import matplotlib.pyplot as plt

import numpy as np

from matplotlib import colors


# 地图长,宽

map_w = 10
map_h =10

# 起、末点

S_point = [0, 0]
E_point = [9, 9]

G = np.zeros(map_w*map_h)

obs_num = int(G.size * 0.2)  # 障碍数量

obs_a = np.random.randint(low=0, high=G.size, size=obs_num)  # 随机产生障碍的索引

G[obs_a] = 1  # 障碍

map_test = G.reshape([map_w, map_h])  # 创建矩阵地图


cmap = colors.ListedColormap(['none', 'black', 'white', 'magenta', 'yellow', 'cyan', 'green', 'red', 'blue'])


#=============增加部分==============

map_test[S_point[0], S_point[1]] = 3
map_test[E_point[0], E_point[1]] = 5

plt.imshow(map_test, cmap=cmap, interpolation='nearest', vmin=0, vmax=7)

plt.show()

运行结果如下:
![[Pasted image 20220822211528.png]]

本质上就是对应上cmap上的值进行修改即可。
如果不想随机的产生障碍,可以自己搭建一个二维数组,实现也相对简单,代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
import matplotlib.pyplot as plt

import numpy as np

from matplotlib import colors

map_test =[ [4, 0, 0, 0, 1, 1, 0, 0, 0, 0] ,
            [0, 0, 0, 0, 1, 1, 0, 0, 0, 0] ,
            [0, 0, 0, 0, 1, 1, 0, 0, 0, 0] ,
            [0, 0, 0, 0, 1, 1, 0, 0, 0, 0] ,
            [0, 0, 0, 0, 1, 1, 0, 0, 0, 0] ,
            [0, 0, 0, 0, 1, 1, 0, 0, 0, 0] ,
            [0, 0, 0, 0, 0, 0, 0, 0, 0, 0] ,
            [0, 1, 1, 0, 0, 0, 0, 0, 0, 0] ,
            [0, 1, 1, 0, 0, 0, 0, 0, 0, 5] ,
            ]
           
cmap = colors.ListedColormap(['none', 'black', 'white', 'magenta', 'yellow', 'cyan', 'green', 'red', 'blue'])

plt.imshow(map_test, cmap=cmap, interpolation='nearest', vmin=0, vmax=7)
plt.show()

运行结果如下:

总结:玩法多样,也可以导入二值化图片,生成栅格地图。