Add zone switching (#5)
Pixel calculation error Add zone switching Co-authored-by: siinus <pearu@siinus.com> Reviewed-on: #5feature/absolute-paths
parent
4be70b9c31
commit
810fefe323
4 changed files with 69 additions and 2 deletions
@ -0,0 +1,35 @@ |
||||
class Regions(object): |
||||
_pixelsEnabled: [] = [] |
||||
_regions: [] = [] |
||||
|
||||
def __init__(self, strip_length: int, splitters: []): |
||||
self._length: int = strip_length |
||||
start_pixel = 0 |
||||
for i in splitters: |
||||
if i > self._length: |
||||
raise ValueError('splitter out of bounds, you idiot') |
||||
self._regions.append([start_pixel, i + 1, True]) |
||||
start_pixel = i + 1 |
||||
|
||||
self._regions.append([start_pixel, self._length, True]) |
||||
for i in range(self._length): |
||||
self._pixelsEnabled.append(True) |
||||
|
||||
def region_switch(self, region_id: int, enabled: bool): |
||||
pixel_region = self._regions[region_id] |
||||
for i in range(pixel_region[0], pixel_region[1]): |
||||
self._pixelsEnabled[i] = enabled |
||||
self._regions[region_id][2] = enabled |
||||
|
||||
def is_pixel_enabled(self, pixel_id: int): |
||||
return self._pixelsEnabled[pixel_id] |
||||
|
||||
def switch_region(self, region_id: int): |
||||
status: bool = self._regions[region_id][2] |
||||
self.region_switch(region_id, not status) |
||||
|
||||
def list_region_ids(self): |
||||
result = [] |
||||
for i in range(len(self._regions)): |
||||
result.append(i) |
||||
return result |
Loading…
Reference in new issue