-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpower_source.py
32 lines (23 loc) · 884 Bytes
/
power_source.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
from sc2.position import Point2
class PowerSource:
@classmethod
def from_proto(cls, proto):
return cls(Point2.from_proto(proto.pos), proto.radius, proto.tag)
def __init__(self, position, radius, unit_tag):
assert isinstance(position, Point2)
assert radius > 0
self.position = position
self.radius = radius
self.unit_tag = unit_tag
def covers(self, position):
return self.position.distance_to(position) <= self.radius
def __repr__(self):
return f"PowerSource({self.position}, {self.radius})"
class PsionicMatrix:
@classmethod
def from_proto(cls, proto):
return cls([PowerSource.from_proto(p) for p in proto])
def __init__(self, sources):
self.sources = sources
def covers(self, position):
return any(source.covers(position) for source in self.sources)