-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathenv.py
47 lines (34 loc) · 1.28 KB
/
env.py
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
40
41
42
43
44
45
46
47
import math
import pygame
class buildEnvironment:
def __init__ (self, MapDimensions):
pygame.init()
self.pointCloud = []
self.externalMap = pygame.image.load('plans/floorplan-1.png')
self.mapHeight, self.mapWidth = MapDimensions
# Set window name
self.MapWindowName = 'RRT path planning'
pygame.display.set_caption(self.MapWindowName)
self.map = pygame.display.set_mode((self.mapWidth, self.mapHeight))
self.map.blit(self.externalMap, (0,0)) # overlays the floorplan image
# Colors in RGB format
self.black = (0, 0, 0)
self.white = (255, 255, 255)
self.grey = (70, 70, 70)
self.blue = (0, 0, 255)
self.green = (0, 255, 0)
self.red = (255, 0, 0)
def AD2pos(self, distance, angle, robotPosition):
x = distance * math.cos(angle) + robotPosition[0]
y = -distance * math.sin(angle) + robotPosition[1]
return (int(x), int(y))
def dataStorage(self, data):
print(len(self.pointCloud))
for element in data:
point = self.AD2pos(element[0], element[1], element[2])
if point not in self.pointCloud:
self.pointCloud.append(point)
def show_sensorData(self):
self.infomap = self.map.copy()
for point in self.pointCloud:
self.infomap.set_at((int(point[0]), int(point[1])), self.red)