Update terminis.py
This commit is contained in:
parent
c5cd910260
commit
549a4d363b
@ -22,7 +22,7 @@ import subprocess
|
|||||||
|
|
||||||
try:
|
try:
|
||||||
import configparser
|
import configparser
|
||||||
except ImportError:
|
except ImportError: # Python2
|
||||||
import ConfigParser as configparser
|
import ConfigParser as configparser
|
||||||
|
|
||||||
|
|
||||||
@ -36,11 +36,6 @@ Tetris clone for terminal
|
|||||||
--reset\treset to default controls settings
|
--reset\treset to default controls settings
|
||||||
--level=n\tstart at level n (integer between 1 and 15)"""
|
--level=n\tstart at level n (integer between 1 and 15)"""
|
||||||
|
|
||||||
|
|
||||||
locale.setlocale(locale.LC_ALL, '')
|
|
||||||
if locale.getpreferredencoding() == 'UTF-8':
|
|
||||||
os.environ["NCURSES_NO_UTF8_ACS"] = "1"
|
|
||||||
|
|
||||||
scheduler = sched.scheduler(time.time, lambda delay: curses.napms(int(delay*1000)))
|
scheduler = sched.scheduler(time.time, lambda delay: curses.napms(int(delay*1000)))
|
||||||
|
|
||||||
|
|
||||||
@ -98,19 +93,42 @@ class Tetromino:
|
|||||||
self.fall_timer = None
|
self.fall_timer = None
|
||||||
self.hold_enabled = True
|
self.hold_enabled = True
|
||||||
|
|
||||||
|
def moved(self, potential_position, potential_minoes_positions):
|
||||||
|
if self.matrix.shape_fits(potential_position, potential_minoes_positions):
|
||||||
|
self.position = potential_position
|
||||||
|
self.minoes_positions = potential_minoes_positions
|
||||||
|
self.postpone_lock()
|
||||||
|
self.matrix.refresh()
|
||||||
|
return True
|
||||||
|
else:
|
||||||
|
return False
|
||||||
|
|
||||||
def move(self, movement, lock=True):
|
def move(self, movement, lock=True):
|
||||||
potential_position = self.position + movement
|
potential_position = self.position + movement
|
||||||
if self.matrix.shape_fits(potential_position, self.minoes_positions):
|
if self.moved(potential_position, self.minoes_positions):
|
||||||
self.position = potential_position
|
|
||||||
self.postpone_lock()
|
|
||||||
self.rotated_last = False
|
self.rotated_last = False
|
||||||
self.matrix.refresh()
|
|
||||||
return True
|
return True
|
||||||
else:
|
else:
|
||||||
if lock and movement == Movement.DOWN:
|
if lock and movement == Movement.DOWN:
|
||||||
self.locking()
|
self.locking()
|
||||||
return False
|
return False
|
||||||
|
|
||||||
|
def rotate(self, direction):
|
||||||
|
potential_minoes_positions = tuple(
|
||||||
|
Point(-direction*mino_position.y, direction*mino_position.x)
|
||||||
|
for mino_position in self.minoes_positions
|
||||||
|
)
|
||||||
|
for rotation_point, liberty_degree in enumerate(self.SUPER_ROTATION_SYSTEM[self.orientation][direction], start=1):
|
||||||
|
potential_position = self.position + liberty_degree
|
||||||
|
if self.moved(potential_position, potential_minoes_positions):
|
||||||
|
self.orientation = (self.orientation+direction) % 4
|
||||||
|
self.rotated_last = True
|
||||||
|
if rotation_point == 5:
|
||||||
|
self.rotation_point_5_used = True
|
||||||
|
return True
|
||||||
|
else:
|
||||||
|
return False
|
||||||
|
|
||||||
def soft_drop(self):
|
def soft_drop(self):
|
||||||
if self.move(Movement.DOWN):
|
if self.move(Movement.DOWN):
|
||||||
self.matrix.game.stats.piece_dropped(1)
|
self.matrix.game.stats.piece_dropped(1)
|
||||||
@ -124,26 +142,6 @@ class Tetromino:
|
|||||||
self.matrix.game.stats.piece_dropped(lines)
|
self.matrix.game.stats.piece_dropped(lines)
|
||||||
self.lock()
|
self.lock()
|
||||||
|
|
||||||
def rotate(self, direction):
|
|
||||||
potential_minoes_positions = tuple(
|
|
||||||
Point(-direction*mino_position.y, direction*mino_position.x)
|
|
||||||
for mino_position in self.minoes_positions
|
|
||||||
)
|
|
||||||
for rotation_point, liberty_degree in enumerate(self.SUPER_ROTATION_SYSTEM[self.orientation][direction], start=1):
|
|
||||||
potential_position = self.position + liberty_degree
|
|
||||||
if self.matrix.shape_fits(potential_position, potential_minoes_positions):
|
|
||||||
self.orientation = (self.orientation+direction) % 4
|
|
||||||
self.position = potential_position
|
|
||||||
self.minoes_positions = potential_minoes_positions
|
|
||||||
self.postpone_lock()
|
|
||||||
self.rotated_last = True
|
|
||||||
if rotation_point == 5:
|
|
||||||
self.rotation_point_5_used = True
|
|
||||||
self.matrix.refresh()
|
|
||||||
return True
|
|
||||||
else:
|
|
||||||
return False
|
|
||||||
|
|
||||||
def fall(self):
|
def fall(self):
|
||||||
self.fall_timer = scheduler.enter(self.fall_delay, 2, self.fall, tuple())
|
self.fall_timer = scheduler.enter(self.fall_delay, 2, self.fall, tuple())
|
||||||
self.move(Movement.DOWN)
|
self.move(Movement.DOWN)
|
||||||
@ -743,6 +741,10 @@ def main():
|
|||||||
controls.edit()
|
controls.edit()
|
||||||
elif "--edit" in sys.argv[1:]:
|
elif "--edit" in sys.argv[1:]:
|
||||||
ControlsParser().edit()
|
ControlsParser().edit()
|
||||||
|
|
||||||
|
locale.setlocale(locale.LC_ALL, '')
|
||||||
|
if locale.getpreferredencoding() == 'UTF-8':
|
||||||
|
os.environ["NCURSES_NO_UTF8_ACS"] = "1"
|
||||||
curses.wrapper(Game)
|
curses.wrapper(Game)
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user