49 Commits
v1.3 ... v1.7

Author SHA1 Message Date
b1c37e73f4 v1.6 release 2019-01-24 20:39:07 +01:00
b7650efdf6 tweaks 2019-01-24 20:37:42 +01:00
231ba2fbff tweaks 2019-01-24 18:17:44 +01:00
a1fb70a3ee Revert "high-angle shot"
This reverts commit 8435997cc4.
2019-01-24 18:04:37 +01:00
8435997cc4 high-angle shot 2019-01-24 18:01:27 +01:00
8eb3aba5d5 tweaking 2019-01-24 17:35:56 +01:00
f3e61d319f forgot to hide grid 2019-01-24 17:30:08 +01:00
c4aee1c2bc low angle shot 2019-01-24 17:29:28 +01:00
f220739ffc compatibility with Godot 3.1 2019-01-21 16:59:47 +01:00
1b5cccd8c9 Exploding minoes instead of lines 2019-01-19 16:23:41 +01:00
685acd4589 externalize environment 2019-01-19 15:21:34 +01:00
831d07d436 boost html5 loading 2019-01-18 17:42:48 +01:00
1829102bb1 the signals 2019-01-18 16:39:57 +01:00
4cde8ff47f Update TETRIS3000.pck 2019-01-18 10:42:04 +01:00
e9152d7d81 Update Main.tscn 2019-01-18 10:41:56 +01:00
ba8184af9d Update TETRIS3000.pck 2019-01-18 01:26:26 +01:00
9f31c97391 loop 2019-01-18 01:22:07 +01:00
e5778812bc remove mesure at reprise 2019-01-18 01:08:58 +01:00
d89c65333e reduce size by removing unnecessary instruments 2019-01-18 01:07:20 +01:00
52743e8ad2 Revert "reduce size by removing unnecessary instruments"
This reverts commit 52c1300d09.
2019-01-18 01:03:16 +01:00
52c1300d09 reduce size by removing unnecessary instruments 2019-01-18 00:59:27 +01:00
50b3e35859 remove piano to line clear sfx 2019-01-18 00:58:58 +01:00
e9f3d7dc14 remix 2019-01-18 00:58:33 +01:00
c64c4afd89 web works! 2019-01-17 18:32:25 +01:00
e714b7cbaf disable Etc2 compression 2019-01-17 16:00:32 +01:00
63728c90c6 disable S 3tc compression 2019-01-17 15:52:52 +01:00
9e9779b8a9 disable S3TC texture compression 2019-01-17 15:49:30 +01:00
25d865bcbb new build 2019-01-17 15:36:51 +01:00
73d3e59d93 rename midi 2019-01-17 15:32:12 +01:00
8c7a4bef17 add midi resource 2019-01-17 15:25:09 +01:00
0b909091b7 Update TETRIS3000.pck 2019-01-17 09:57:52 +01:00
8cc69e99da Update controlsUI 2019-01-17 01:28:26 +01:00
1cec50f4f6 Update Tetromino.gd 2019-01-16 23:16:25 +01:00
6e9f5659ae t-spin only if last movement is a rotation 2019-01-16 22:53:19 +01:00
69a21fe12f randomize in main 2019-01-16 21:47:16 +01:00
11e6e07098 Revert "prepare rotate to be moved in main class"
This reverts commit a8dced21f1.
2019-01-16 19:20:00 +01:00
a8dced21f1 prepare rotate to be moved in main class 2019-01-16 18:29:51 +01:00
c338885d67 Update Main.tscn 2019-01-16 18:17:22 +01:00
dc7a6bd488 above cell 2019-01-16 18:17:17 +01:00
88f5dfb00f reduce icons 2019-01-16 18:16:13 +01:00
2417bd5b56 test t-spin only on lock 2019-01-16 18:15:56 +01:00
d7768f08ea T-Spin & stats 2019-01-16 16:31:24 +01:00
05f61c76db update hint text 2019-01-16 16:05:55 +01:00
5419864859 Hint text 2019-01-16 15:35:46 +01:00
a915251506 Update TETRIS3000.pck 2019-01-16 14:34:36 +01:00
1916c80784 action icons on control ui 2019-01-16 13:40:53 +01:00
762dd1bdf1 delays 2019-01-16 01:50:44 +01:00
6868c73e49 v1.3 2019-01-16 01:49:14 +01:00
4e33f3f78d delays 2019-01-16 01:49:00 +01:00
40 changed files with 13492 additions and 652 deletions

1
.gitignore vendored
View File

@ -10,3 +10,4 @@ export_presets.cfg
midi/FluidR3 GM.sf2 midi/FluidR3 GM.sf2
release/ release/
*.import *.import
*.tmp

View File

@ -2,5 +2,5 @@
[Downloads](https://github.com/adrienmalin/TETRIS3000/releases) [Downloads](https://github.com/adrienmalin/TETRIS3000/releases)
[Play in browser (experimental)](https://adrienmalin.github.io/TETRIS3000/web/TETRIS3000.html) [Play in browser](https://adrienmalin.github.io/TETRIS3000/web/TETRIS3000.html)

87
source/Environment.tres Normal file
View File

@ -0,0 +1,87 @@
[gd_resource type="Environment" load_steps=2 format=2]
[sub_resource type="PanoramaSky" id=1]
radiance_size = 0
[resource]
resource_local_to_scene = true
background_mode = 0
background_sky = SubResource( 1 )
background_sky_custom_fov = 0.0
background_color = Color( 0, 0, 0, 1 )
background_energy = 0.0
background_canvas_max_layer = 0
ambient_light_color = Color( 0.86908, 0.949502, 0.958984, 1 )
ambient_light_energy = 2.0
ambient_light_sky_contribution = 0.92
fog_enabled = false
fog_color = Color( 0.5, 0.6, 0.7, 1 )
fog_sun_color = Color( 1, 0.9, 0.7, 1 )
fog_sun_amount = 0.0
fog_depth_enabled = true
fog_depth_begin = 10.0
fog_depth_curve = 1.0
fog_transmit_enabled = false
fog_transmit_curve = 1.0
fog_height_enabled = false
fog_height_min = 0.0
fog_height_max = 100.0
fog_height_curve = 1.0
tonemap_mode = 3
tonemap_exposure = 1.0
tonemap_white = 1.0
auto_exposure_enabled = false
auto_exposure_scale = 0.4
auto_exposure_min_luma = 0.05
auto_exposure_max_luma = 0.26
auto_exposure_speed = 0.5
ss_reflections_enabled = false
ss_reflections_max_steps = 64
ss_reflections_fade_in = 0.15
ss_reflections_fade_out = 2.0
ss_reflections_depth_tolerance = 0.2
ss_reflections_roughness = true
ssao_enabled = false
ssao_radius = 1.0
ssao_intensity = 1.0
ssao_radius2 = 0.0
ssao_intensity2 = 1.0
ssao_bias = 0.01
ssao_light_affect = 0.0
ssao_color = Color( 0, 0, 0, 1 )
ssao_quality = 0
ssao_blur = 3
ssao_edge_sharpness = 4.0
dof_blur_far_enabled = false
dof_blur_far_distance = 10.0
dof_blur_far_transition = 5.0
dof_blur_far_amount = 0.1
dof_blur_far_quality = 1
dof_blur_near_enabled = false
dof_blur_near_distance = 2.0
dof_blur_near_transition = 1.0
dof_blur_near_amount = 0.1
dof_blur_near_quality = 1
glow_enabled = false
glow_levels/1 = false
glow_levels/2 = false
glow_levels/3 = true
glow_levels/4 = false
glow_levels/5 = true
glow_levels/6 = false
glow_levels/7 = false
glow_intensity = 6.17
glow_strength = 1.0
glow_bloom = 0.0
glow_blend_mode = 2
glow_hdr_threshold = 1.0
glow_hdr_scale = 2.0
glow_bicubic_upscale = false
adjustment_enabled = false
adjustment_brightness = 0.27
adjustment_contrast = 1.0
adjustment_saturation = 0.34
_sections_unfolded = [ "Adjustments", "Ambient Light", "Background", "Resource" ]

View File

@ -1,12 +1,12 @@
extends GridMap extends GridMap
const Tetromino = preload("res://Tetrominos/Tetromino.gd") const Tetromino = preload("res://Tetrominos/Tetromino.gd")
const ExplodingLine = preload("res://ExplodingLine.tscn") const ExplodingMino = preload("res://Tetrominos/Mino/ExplodingMino.tscn")
const EMPTY_CELL = -1 const EMPTY_CELL = -1
const MINO = 0 const MINO = 0
var exploding_lines = [] var exploding_minoes = []
var nb_collumns var nb_collumns
var nb_lines var nb_lines
@ -14,9 +14,11 @@ func _ready():
nb_collumns = int(get_parent().scale.x) nb_collumns = int(get_parent().scale.x)
nb_lines = int(get_parent().scale.y) nb_lines = int(get_parent().scale.y)
for y in range(nb_lines): for y in range(nb_lines):
exploding_lines.append(ExplodingLine.instance()) exploding_minoes.append([])
add_child(exploding_lines[y]) for x in range(nb_collumns):
exploding_lines[y].translation = Vector3(nb_collumns/2, y, 1) exploding_minoes[y].append(ExplodingMino.instance())
add_child(exploding_minoes[y][x])
exploding_minoes[y][x].translation = Vector3(x, y, 0)
func clear(): func clear():
for used_cell in get_used_cells(): for used_cell in get_used_cells():
@ -52,10 +54,9 @@ func lock(piece):
return minoes_over_grid < Tetromino.NB_MINOES return minoes_over_grid < Tetromino.NB_MINOES
func clear_lines(): func clear_lines():
var line_cleared
var lines_cleared = 0 var lines_cleared = 0
for y in range(nb_lines-1, -1, -1): for y in range(nb_lines-1, -1, -1):
line_cleared = true var line_cleared = true
for x in range(nb_collumns): for x in range(nb_collumns):
if not get_cell_item(x, y, 0) == MINO: if not get_cell_item(x, y, 0) == MINO:
line_cleared = false line_cleared = false
@ -63,8 +64,10 @@ func clear_lines():
if line_cleared: if line_cleared:
for y2 in range(y, nb_lines+2): for y2 in range(y, nb_lines+2):
for x in range(nb_collumns): for x in range(nb_collumns):
set_cell_item(x, y2, 0, get_cell_item(x, y2+1, 0)) var above_cell = get_cell_item(x, y2+1, 0)
set_cell_item(x, y2, 0, above_cell)
lines_cleared += 1 lines_cleared += 1
exploding_lines[y].emitting = true for x in range(nb_collumns):
exploding_lines[y].restart() exploding_minoes[y][x].emitting = true
exploding_minoes[y][x].restart()
return lines_cleared return lines_cleared

View File

@ -27,11 +27,14 @@ var autoshift_action
var playing = false var playing = false
func _ready():
randomize()
func new_game(level): func new_game(level):
$Start.visible = false $Start.visible = false
$Matrix/GridMap.clear()
next_piece = random_piece() next_piece = random_piece()
autoshift_action = "" autoshift_action = ""
$LockDelay.wait_time = 0.5
$MidiPlayer.position = 0 $MidiPlayer.position = 0
$Stats.new_game(level) $Stats.new_game(level)
new_piece() new_piece()
@ -65,14 +68,13 @@ func new_level(level):
if level <= 15: if level <= 15:
$DropTimer.wait_time = pow(0.8 - ((level - 1) * 0.007), level - 1) $DropTimer.wait_time = pow(0.8 - ((level - 1) * 0.007), level - 1)
else: else:
$DropTimer.wait_time = 0.01
$LockDelay.wait_time = 0.5 * pow(0.9, level-15) $LockDelay.wait_time = 0.5 * pow(0.9, level-15)
func _unhandled_input(event): func _unhandled_input(event):
if event.is_action_pressed("pause"): if event.is_action_pressed("pause"):
if playing: if playing:
pause($controls_ui) pause($controls_ui)
elif $controls_ui.enable_resume: else:
resume() resume()
if event.is_action_pressed("toggle_fullscreen"): if event.is_action_pressed("toggle_fullscreen"):
OS.window_fullscreen = not OS.window_fullscreen OS.window_fullscreen = not OS.window_fullscreen
@ -98,9 +100,9 @@ func _unhandled_input(event):
if event.is_action_pressed("hard_drop"): if event.is_action_pressed("hard_drop"):
hard_drop() hard_drop()
if event.is_action_pressed("rotate_clockwise"): if event.is_action_pressed("rotate_clockwise"):
current_piece.rotate(Tetromino.CLOCKWISE) current_piece.turn(Tetromino.CLOCKWISE)
if event.is_action_pressed("rotate_counterclockwise"): if event.is_action_pressed("rotate_counterclockwise"):
current_piece.rotate(Tetromino.COUNTERCLOCKWISE) current_piece.turn(Tetromino.COUNTERCLOCKWISE)
if event.is_action_pressed("hold"): if event.is_action_pressed("hold"):
hold() hold()
@ -133,9 +135,10 @@ func _on_DropTimer_timeout():
func lock(): func lock():
if $Matrix/GridMap.lock(current_piece): if $Matrix/GridMap.lock(current_piece):
var t_spin = current_piece.t_spin()
var lines_cleared = $Matrix/GridMap.clear_lines() var lines_cleared = $Matrix/GridMap.clear_lines()
$Stats.piece_locked(lines_cleared, current_piece.t_spin) $Stats.piece_locked(lines_cleared, t_spin)
if lines_cleared or current_piece.t_spin: if lines_cleared or t_spin:
$MidiPlayer.piece_locked(lines_cleared) $MidiPlayer.piece_locked(lines_cleared)
remove_child(current_piece) remove_child(current_piece)
new_piece() new_piece()
@ -203,12 +206,13 @@ func game_over():
func _on_ReplayButton_pressed(): func _on_ReplayButton_pressed():
$ReplayButton.visible = false $ReplayButton.visible = false
pause($Start)
remove_child(next_piece) remove_child(next_piece)
remove_child(current_piece) remove_child(current_piece)
if held_piece: if held_piece:
remove_child(held_piece) remove_child(held_piece)
held_piece = null held_piece = null
$Matrix/GridMap.clear()
pause($Start)
func _notification(what): func _notification(what):
match what: match what:

View File

@ -1,104 +1,20 @@
[gd_scene load_steps=21 format=2] [gd_scene load_steps=20 format=2]
[ext_resource path="res://Main.gd" type="Script" id=1] [ext_resource path="res://Environment.tres" type="Environment" id=1]
[ext_resource path="res://aperture-vintage-472251-unsplash.jpg" type="Texture" id=2] [ext_resource path="res://Main.gd" type="Script" id=2]
[ext_resource path="res://Tetrominos/Mino/MinoLibrary.tres" type="MeshLibrary" id=3] [ext_resource path="res://aperture-vintage-472251-unsplash.jpg" type="Texture" id=3]
[ext_resource path="res://GridMap.gd" type="Script" id=4] [ext_resource path="res://Tetrominos/Mino/MinoLibrary.tres" type="MeshLibrary" id=4]
[ext_resource path="res://midi/MidiPlayer.tscn" type="PackedScene" id=5] [ext_resource path="res://GridMap.gd" type="Script" id=5]
[ext_resource path="res://MidiPlayer.gd" type="Script" id=6] [ext_resource path="res://midi/MidiPlayer.tscn" type="PackedScene" id=6]
[ext_resource path="res://FlashText.gd" type="Script" id=7] [ext_resource path="res://MidiPlayer.gd" type="Script" id=7]
[ext_resource path="res://fonts/525-ROUN.TTF" type="DynamicFontData" id=8] [ext_resource path="res://FlashText.gd" type="Script" id=8]
[ext_resource path="res://Stats.tscn" type="PackedScene" id=9] [ext_resource path="res://fonts/525-ROUN.TTF" type="DynamicFontData" id=9]
[ext_resource path="res://controls.tscn" type="PackedScene" id=10] [ext_resource path="res://Stats.tscn" type="PackedScene" id=10]
[ext_resource path="res://Start.tscn" type="PackedScene" id=11] [ext_resource path="res://controls.tscn" type="PackedScene" id=11]
[ext_resource path="res://fonts/Gamer.ttf" type="DynamicFontData" id=12] [ext_resource path="res://Start.tscn" type="PackedScene" id=12]
[ext_resource path="res://fonts/Gamer.ttf" type="DynamicFontData" id=13]
[sub_resource type="PanoramaSky" id=1] [sub_resource type="SpatialMaterial" id=1]
radiance_size = 0
[sub_resource type="Environment" id=2]
resource_local_to_scene = true
background_mode = 0
background_sky = SubResource( 1 )
background_sky_custom_fov = 0.0
background_color = Color( 0, 0, 0, 1 )
background_energy = 0.0
background_canvas_max_layer = 0
ambient_light_color = Color( 0.86908, 0.949502, 0.958984, 1 )
ambient_light_energy = 2.0
ambient_light_sky_contribution = 0.92
fog_enabled = false
fog_color = Color( 0.5, 0.6, 0.7, 1 )
fog_sun_color = Color( 1, 0.9, 0.7, 1 )
fog_sun_amount = 0.0
fog_depth_enabled = true
fog_depth_begin = 10.0
fog_depth_curve = 1.0
fog_transmit_enabled = false
fog_transmit_curve = 1.0
fog_height_enabled = false
fog_height_min = 0.0
fog_height_max = 100.0
fog_height_curve = 1.0
tonemap_mode = 3
tonemap_exposure = 1.0
tonemap_white = 1.0
auto_exposure_enabled = false
auto_exposure_scale = 0.4
auto_exposure_min_luma = 0.05
auto_exposure_max_luma = 0.26
auto_exposure_speed = 0.5
ss_reflections_enabled = false
ss_reflections_max_steps = 64
ss_reflections_fade_in = 0.15
ss_reflections_fade_out = 2.0
ss_reflections_depth_tolerance = 0.2
ss_reflections_roughness = true
ssao_enabled = false
ssao_radius = 1.0
ssao_intensity = 1.0
ssao_radius2 = 0.0
ssao_intensity2 = 1.0
ssao_bias = 0.01
ssao_light_affect = 0.0
ssao_color = Color( 0, 0, 0, 1 )
ssao_quality = 0
ssao_blur = 3
ssao_edge_sharpness = 4.0
dof_blur_far_enabled = false
dof_blur_far_distance = 10.0
dof_blur_far_transition = 5.0
dof_blur_far_amount = 0.1
dof_blur_far_quality = 1
dof_blur_near_enabled = false
dof_blur_near_distance = 2.0
dof_blur_near_transition = 1.0
dof_blur_near_amount = 0.1
dof_blur_near_quality = 1
glow_enabled = false
glow_levels/1 = false
glow_levels/2 = false
glow_levels/3 = true
glow_levels/4 = false
glow_levels/5 = true
glow_levels/6 = false
glow_levels/7 = false
glow_intensity = 6.17
glow_strength = 1.0
glow_bloom = 0.0
glow_blend_mode = 2
glow_hdr_threshold = 1.0
glow_hdr_scale = 2.0
glow_bicubic_upscale = false
adjustment_enabled = false
adjustment_brightness = 0.27
adjustment_contrast = 1.0
adjustment_saturation = 0.34
_sections_unfolded = [ "Adjustments", "Ambient Light", "Background", "Resource" ]
[sub_resource type="SpatialMaterial" id=3]
render_priority = 0 render_priority = 0
flags_transparent = true flags_transparent = true
@ -149,35 +65,35 @@ uv2_triplanar_sharpness = 1.0
proximity_fade_enable = true proximity_fade_enable = true
proximity_fade_distance = 1.0 proximity_fade_distance = 1.0
distance_fade_enable = false distance_fade_enable = false
_sections_unfolded = [ "Albedo", "Emission", "Metallic", "NormalMap", "Proximity Fade" ] _sections_unfolded = [ "Albedo", "Emission", "Flags", "Metallic", "NormalMap", "Proximity Fade" ]
[sub_resource type="CubeMesh" id=4] [sub_resource type="CubeMesh" id=2]
material = SubResource( 3 ) material = SubResource( 1 )
custom_aabb = AABB( 0, 0, 0, 0, 0, 0 ) custom_aabb = AABB( 0, 0, 0, 0, 0, 0 )
size = Vector3( 1, 1, 1 ) size = Vector3( 1, 1, 1 )
subdivide_width = 0 subdivide_width = 0
subdivide_height = 0 subdivide_height = 0
subdivide_depth = 0 subdivide_depth = 0
[sub_resource type="CubeMesh" id=5] [sub_resource type="CubeMesh" id=3]
material = SubResource( 3 ) material = SubResource( 1 )
custom_aabb = AABB( 0, 0, 0, 0, 0, 0 ) custom_aabb = AABB( 0, 0, 0, 0, 0, 0 )
size = Vector3( 1, 1, 1 ) size = Vector3( 1, 1, 1 )
subdivide_width = 0 subdivide_width = 0
subdivide_height = 0 subdivide_height = 0
subdivide_depth = 0 subdivide_depth = 0
[sub_resource type="DynamicFont" id=6] [sub_resource type="DynamicFont" id=4]
size = 30 size = 30
use_mipmaps = true use_mipmaps = true
use_filter = false use_filter = false
font_data = ExtResource( 8 ) font_data = ExtResource( 9 )
_sections_unfolded = [ "Font", "Settings" ] _sections_unfolded = [ "Font", "Settings" ]
[sub_resource type="Animation" id=7] [sub_resource type="Animation" id=5]
resource_name = "Flash" resource_name = "Flash"
length = 1.0 length = 1.0
@ -220,23 +136,23 @@ tracks/2/keys = {
"values": [ Vector2( 0, 110 ), Vector2( 0, -50 ), Vector2( 0, -60 ), Vector2( 0, -100 ) ] "values": [ Vector2( 0, 110 ), Vector2( 0, -50 ), Vector2( 0, -60 ), Vector2( 0, -100 ) ]
} }
[sub_resource type="DynamicFont" id=8] [sub_resource type="DynamicFont" id=6]
size = 20 size = 20
use_mipmaps = false use_mipmaps = false
use_filter = false use_filter = false
extra_spacing_bottom = 5 extra_spacing_bottom = 5
font_data = ExtResource( 12 ) font_data = ExtResource( 13 )
_sections_unfolded = [ "Extra Spacing", "Font", "Settings" ] _sections_unfolded = [ "Extra Spacing", "Font", "Settings" ]
[node name="Main" type="WorldEnvironment" index="0"] [node name="Main" type="WorldEnvironment" index="0"]
environment = SubResource( 2 ) environment = ExtResource( 1 )
script = ExtResource( 1 ) script = ExtResource( 2 )
[node name="Background" type="Sprite3D" parent="." index="0"] [node name="Background" type="Sprite3D" parent="." index="0"]
transform = Transform( 12.8, 0, 0, 0, 8.53, 0, 0, 0, 1, 5, 10, -32 ) transform = Transform( 12.8, 0, 0, 0, 8.53, 0, 0, 0, 1, 4.5, 25, -32 )
layers = 1 layers = 1
material_override = null material_override = null
cast_shadow = 1 cast_shadow = 1
@ -255,10 +171,10 @@ opacity = 1.0
pixel_size = 0.01 pixel_size = 0.01
axis = 2 axis = 2
transparent = false transparent = false
shaded = true shaded = false
double_sided = false double_sided = false
alpha_cut = 0 alpha_cut = 0
texture = ExtResource( 2 ) texture = ExtResource( 3 )
vframes = 1 vframes = 1
hframes = 1 hframes = 1
frame = 0 frame = 0
@ -268,7 +184,7 @@ _sections_unfolded = [ "Animation", "Flags", "Geometry", "Transform" ]
[node name="Camera" type="Camera" parent="." index="1"] [node name="Camera" type="Camera" parent="." index="1"]
transform = Transform( 1, 0, 0, 0, 1, 0, 0, 0, 1, 4.5, 10, 20 ) transform = Transform( 1, 0, 0, 0, 0.939693, -0.34202, 0, 0.34202, 0.939693, 4.5, 2, 17 )
keep_aspect = 1 keep_aspect = 1
cull_mask = 1048575 cull_mask = 1048575
environment = null environment = null
@ -277,7 +193,7 @@ v_offset = 0.0
doppler_tracking = 0 doppler_tracking = 0
projection = 0 projection = 0
current = true current = true
fov = 70.0 fov = 60.3
size = 1.0 size = 1.0
near = 0.05 near = 0.05
far = 500.0 far = 500.0
@ -285,7 +201,7 @@ _sections_unfolded = [ "Transform" ]
[node name="DirectionalLight" type="DirectionalLight" parent="." index="2"] [node name="DirectionalLight" type="DirectionalLight" parent="." index="2"]
transform = Transform( -0.241094, 0.489231, -0.838169, 0.896995, 0.442041, 0, 0.370504, -0.751834, -0.545411, 5, 30, 0 ) transform = Transform( 0.332668, 0.771982, -0.541642, 0.579657, 0.285656, 0.763151, 0.743861, -0.567843, -0.352456, 5, 30, 0 )
layers = 1 layers = 1
light_color = Color( 1, 1, 1, 1 ) light_color = Color( 1, 1, 1, 1 )
light_energy = 3.0 light_energy = 3.0
@ -324,15 +240,15 @@ lod_min_distance = 0.0
lod_min_hysteresis = 0.0 lod_min_hysteresis = 0.0
lod_max_distance = 0.0 lod_max_distance = 0.0
lod_max_hysteresis = 0.0 lod_max_hysteresis = 0.0
mesh = SubResource( 4 ) mesh = SubResource( 2 )
skeleton = NodePath("..") skeleton = NodePath("..")
material/0 = null material/0 = null
_sections_unfolded = [ "Transform" ] _sections_unfolded = [ "Transform", "material" ]
[node name="GridMap" type="GridMap" parent="Matrix" index="0"] [node name="GridMap" type="GridMap" parent="Matrix" index="0"]
transform = Transform( 0.1, 0, 0, 0, 0.05, 0, 0, 0, 1, -0.45, -0.475, 0 ) transform = Transform( 0.1, 0, 0, 0, 0.05, 0, 0, 0, 1, -0.45, -0.475, 0 )
theme = ExtResource( 3 ) theme = ExtResource( 4 )
cell_size = Vector3( 1, 1, 1 ) cell_size = Vector3( 1, 1, 1 )
cell_octant_size = 8 cell_octant_size = 8
cell_center_x = false cell_center_x = false
@ -344,11 +260,11 @@ collision_mask = 1
data = { data = {
"cells": PoolIntArray( ) "cells": PoolIntArray( )
} }
script = ExtResource( 4 ) script = ExtResource( 5 )
_sections_unfolded = [ "Cell", "Transform" ] _sections_unfolded = [ "Cell", "Transform" ]
__meta__ = { __meta__ = {
"_editor_clip_": 1, "_editor_clip_": 1,
"_editor_floor_": Vector3( 0, -1, 0 ) "_editor_floor_": Vector3( 0, -2, 0 )
} }
[node name="Position3D" type="Position3D" parent="Matrix" index="1"] [node name="Position3D" type="Position3D" parent="Matrix" index="1"]
@ -369,7 +285,7 @@ lod_min_distance = 0.0
lod_min_hysteresis = 0.0 lod_min_hysteresis = 0.0
lod_max_distance = 0.0 lod_max_distance = 0.0
lod_max_hysteresis = 0.0 lod_max_hysteresis = 0.0
mesh = SubResource( 5 ) mesh = SubResource( 3 )
skeleton = NodePath("..") skeleton = NodePath("..")
material/0 = null material/0 = null
_sections_unfolded = [ "Transform" ] _sections_unfolded = [ "Transform" ]
@ -392,7 +308,7 @@ lod_min_distance = 0.0
lod_min_hysteresis = 0.0 lod_min_hysteresis = 0.0
lod_max_distance = 0.0 lod_max_distance = 0.0
lod_max_hysteresis = 0.0 lod_max_hysteresis = 0.0
mesh = SubResource( 5 ) mesh = SubResource( 3 )
skeleton = NodePath("..") skeleton = NodePath("..")
material/0 = null material/0 = null
_sections_unfolded = [ "Transform" ] _sections_unfolded = [ "Transform" ]
@ -426,15 +342,16 @@ autostart = false
[node name="AutoShiftTimer" type="Timer" parent="." index="9"] [node name="AutoShiftTimer" type="Timer" parent="." index="9"]
process_mode = 1 process_mode = 1
wait_time = 0.02 wait_time = 0.03
one_shot = false one_shot = false
autostart = false autostart = false
[node name="MidiPlayer" parent="." index="10" instance=ExtResource( 5 )] [node name="MidiPlayer" parent="." index="10" instance=ExtResource( 6 )]
editor/display_folded = true editor/display_folded = true
script = ExtResource( 6 ) script = ExtResource( 7 )
file = "res://midi/Tetris - Song A.mid" _sections_unfolded = [ "Pause" ]
file = "res://midi/Korobeiniki.mid"
volume_db = -24 volume_db = -24
loop = true loop = true
loop_start = 1.81 loop_start = 1.81
@ -463,7 +380,7 @@ mouse_filter = 0
mouse_default_cursor_shape = 0 mouse_default_cursor_shape = 0
size_flags_horizontal = 1 size_flags_horizontal = 1
size_flags_vertical = 1 size_flags_vertical = 1
script = ExtResource( 7 ) script = ExtResource( 8 )
_sections_unfolded = [ "Material", "Size Flags", "Theme" ] _sections_unfolded = [ "Material", "Size Flags", "Theme" ]
[node name="Label" type="Label" parent="FlashText" index="0"] [node name="Label" type="Label" parent="FlashText" index="0"]
@ -481,7 +398,7 @@ mouse_filter = 2
mouse_default_cursor_shape = 0 mouse_default_cursor_shape = 0
size_flags_horizontal = 1 size_flags_horizontal = 1
size_flags_vertical = 4 size_flags_vertical = 4
custom_fonts/font = SubResource( 6 ) custom_fonts/font = SubResource( 4 )
custom_colors/font_color = Color( 0.445404, 0.710476, 0.820313, 0 ) custom_colors/font_color = Color( 0.445404, 0.710476, 0.820313, 0 )
align = 1 align = 1
valign = 1 valign = 1
@ -497,27 +414,27 @@ autoplay = ""
playback_process_mode = 1 playback_process_mode = 1
playback_default_blend_time = 0.0 playback_default_blend_time = 0.0
playback_speed = 1.0 playback_speed = 1.0
anims/Flash = SubResource( 7 ) anims/Flash = SubResource( 5 )
blend_times = [ ] blend_times = [ ]
_sections_unfolded = [ "Playback Options" ] _sections_unfolded = [ "Playback Options" ]
[node name="Stats" parent="." index="12" instance=ExtResource( 9 )] [node name="Stats" parent="." index="12" instance=ExtResource( 10 )]
visible = false visible = false
anchor_left = 0.0 anchor_left = 0.0
anchor_top = 1.0 anchor_top = 1.0
anchor_right = 0.0 anchor_right = 0.0
anchor_bottom = 1.0 anchor_bottom = 1.0
margin_left = 20.0 margin_left = 30.0
margin_top = -260.0 margin_top = -220.0
margin_right = 130.0 margin_right = 140.0
margin_bottom = -50.0 margin_bottom = -25.0
[node name="controls_ui" parent="." index="13" instance=ExtResource( 10 )] [node name="controls_ui" parent="." index="13" instance=ExtResource( 11 )]
visible = false visible = false
[node name="Start" parent="." index="14" instance=ExtResource( 11 )] [node name="Start" parent="." index="14" instance=ExtResource( 12 )]
[node name="ReplayButton" type="Button" parent="." index="15"] [node name="ReplayButton" type="Button" parent="." index="15"]
@ -526,10 +443,10 @@ anchor_left = 1.0
anchor_top = 1.0 anchor_top = 1.0
anchor_right = 1.0 anchor_right = 1.0
anchor_bottom = 1.0 anchor_bottom = 1.0
margin_left = -335.0 margin_left = -215.0
margin_top = -55.0 margin_top = -100.0
margin_right = -165.0 margin_right = -90.0
margin_bottom = -15.0 margin_bottom = -60.0
rect_pivot_offset = Vector2( 0, 0 ) rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false rect_clip_content = false
focus_mode = 2 focus_mode = 2
@ -537,13 +454,13 @@ mouse_filter = 0
mouse_default_cursor_shape = 0 mouse_default_cursor_shape = 0
size_flags_horizontal = 1 size_flags_horizontal = 1
size_flags_vertical = 1 size_flags_vertical = 1
custom_fonts/font = SubResource( 8 ) custom_fonts/font = SubResource( 6 )
custom_colors/font_color = Color( 1, 1, 1, 1 ) custom_colors/font_color = Color( 1, 1, 1, 1 )
toggle_mode = false toggle_mode = false
enabled_focus_mode = 2 enabled_focus_mode = 2
shortcut = null shortcut = null
group = null group = null
text = "REPLAY" text = "play again"
flat = false flat = false
align = 1 align = 1
_sections_unfolded = [ "Margin", "custom_colors", "custom_fonts" ] _sections_unfolded = [ "Margin", "custom_colors", "custom_fonts" ]

View File

@ -2,7 +2,7 @@ extends "midi/MidiPlayer.gd"
const Tetromino = preload("res://Tetrominos/Tetromino.gd") const Tetromino = preload("res://Tetrominos/Tetromino.gd")
const LINE_CLEAR_CHANNELS = [2, 6] const LINE_CLEAR_CHANNELS = [2]
var muted_events = [] var muted_events = []

View File

@ -1,21 +1,30 @@
[gd_scene load_steps=7 format=2] [gd_scene load_steps=9 format=2]
[ext_resource path="res://Start.gd" type="Script" id=1] [ext_resource path="res://Start.gd" type="Script" id=1]
[ext_resource path="res://fonts/TitleFont.tres" type="DynamicFont" id=2] [ext_resource path="res://fonts/TitleFont.tres" type="DynamicFont" id=2]
[ext_resource path="res://fonts/Gamer.ttf" type="DynamicFontData" id=3] [ext_resource path="res://fonts/525-ROUN.TTF" type="DynamicFontData" id=3]
[ext_resource path="res://fonts/ButtonFont.tres" type="DynamicFont" id=4] [ext_resource path="res://fonts/Gamer.ttf" type="DynamicFontData" id=4]
[ext_resource path="res://fonts/ButtonFont.tres" type="DynamicFont" id=5]
[sub_resource type="DynamicFont" id=1] [sub_resource type="DynamicFont" id=4]
size = 50
use_mipmaps = false
use_filter = false
font_data = ExtResource( 3 )
_sections_unfolded = [ "Font", "Settings" ]
[sub_resource type="DynamicFont" id=2]
size = 20 size = 20
use_mipmaps = false use_mipmaps = false
use_filter = false use_filter = false
font_data = ExtResource( 3 ) font_data = ExtResource( 4 )
_sections_unfolded = [ "Extra Spacing", "Font", "Font/fallback", "Settings" ] _sections_unfolded = [ "Extra Spacing", "Font", "Font/fallback", "Settings" ]
[sub_resource type="Theme" id=2] [sub_resource type="Theme" id=3]
default_font = SubResource( 1 ) default_font = SubResource( 2 )
[node name="Start" type="Control" index="0"] [node name="Start" type="Control" index="0"]
@ -42,9 +51,9 @@ anchor_top = 0.0
anchor_right = 0.5 anchor_right = 0.5
anchor_bottom = 0.0 anchor_bottom = 0.0
margin_left = -250.0 margin_left = -250.0
margin_top = -100.0 margin_top = -109.0
margin_right = 250.0 margin_right = 250.0
margin_bottom = -26.0 margin_bottom = -69.0
rect_pivot_offset = Vector2( 0, 0 ) rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false rect_clip_content = false
mouse_filter = 2 mouse_filter = 2
@ -54,15 +63,40 @@ size_flags_vertical = 4
custom_fonts/font = ExtResource( 2 ) custom_fonts/font = ExtResource( 2 )
custom_colors/font_color = Color( 0.443137, 0.709804, 0.819608, 0.533333 ) custom_colors/font_color = Color( 0.443137, 0.709804, 0.819608, 0.533333 )
custom_colors/font_color_shadow = Color( 1, 1, 1, 0.101333 ) custom_colors/font_color_shadow = Color( 1, 1, 1, 0.101333 )
text = "TETRIS text = "TETRIS"
3000" align = 1
percent_visible = 1.0
lines_skipped = 0
max_lines_visible = -1
_sections_unfolded = [ "Theme", "custom_colors", "custom_fonts" ]
[node name="Label2" type="Label" parent="." index="1"]
anchor_left = 0.5
anchor_top = 0.0
anchor_right = 0.5
anchor_bottom = 0.0
margin_left = -250.0
margin_top = -75.0
margin_right = 250.0
margin_bottom = -19.0
rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false
mouse_filter = 2
mouse_default_cursor_shape = 0
size_flags_horizontal = 1
size_flags_vertical = 4
custom_fonts/font = SubResource( 4 )
custom_colors/font_color = Color( 0.443137, 0.709804, 0.819608, 0.533333 )
custom_colors/font_color_shadow = Color( 1, 1, 1, 0.101333 )
text = "3000"
align = 1 align = 1
percent_visible = 1.0 percent_visible = 1.0
lines_skipped = 0 lines_skipped = 0
max_lines_visible = -1 max_lines_visible = -1
_sections_unfolded = [ "custom_colors", "custom_fonts" ] _sections_unfolded = [ "custom_colors", "custom_fonts" ]
[node name="SpinBox" type="SpinBox" parent="." index="1"] [node name="SpinBox" type="SpinBox" parent="." index="2"]
anchor_left = 0.5 anchor_left = 0.5
anchor_top = 0.5 anchor_top = 0.5
@ -78,7 +112,7 @@ mouse_filter = 0
mouse_default_cursor_shape = 0 mouse_default_cursor_shape = 0
size_flags_horizontal = 1 size_flags_horizontal = 1
size_flags_vertical = 1 size_flags_vertical = 1
theme = SubResource( 2 ) theme = SubResource( 3 )
min_value = 1.0 min_value = 1.0
max_value = 15.0 max_value = 15.0
step = 1.0 step = 1.0
@ -91,7 +125,7 @@ prefix = "Level "
suffix = "" suffix = ""
_sections_unfolded = [ "Margin", "Theme" ] _sections_unfolded = [ "Margin", "Theme" ]
[node name="PlayButton" type="Button" parent="." index="2"] [node name="PlayButton" type="Button" parent="." index="3"]
anchor_left = 0.5 anchor_left = 0.5
anchor_top = 0.5 anchor_top = 0.5
@ -108,7 +142,7 @@ mouse_filter = 0
mouse_default_cursor_shape = 0 mouse_default_cursor_shape = 0
size_flags_horizontal = 1 size_flags_horizontal = 1
size_flags_vertical = 1 size_flags_vertical = 1
custom_fonts/font = ExtResource( 4 ) custom_fonts/font = ExtResource( 5 )
toggle_mode = false toggle_mode = false
enabled_focus_mode = 2 enabled_focus_mode = 2
shortcut = null shortcut = null

View File

@ -1,14 +1,13 @@
extends MarginContainer extends MarginContainer
const SCORES = [ const SCORES = [
[0, 4, 1], {"": 0, "MINI T-SPIN": 1, "T-SPIN": 4},
[1, 8, 2], {"": 1, "MINI T-SPIN": 2, "T-SPIN": 8},
[3, 12], {"": 3, "T-SPIN": 12},
[5, 16], {"": 5, "T-SPIN": 16},
[8] {"": 8}
] ]
const LINES_CLEARED_NAMES = ["", "SINGLE", "DOUBLE", "TRIPLE", "TETRIS"] const LINES_CLEARED_NAMES = ["", "SINGLE", "DOUBLE", "TRIPLE", "TETRIS"]
const T_SPIN_NAMES = ["", "T-SPIN", "MINI T-SPIN"]
const password = "TETRIS 3000" const password = "TETRIS 3000"
var level var level
@ -18,8 +17,8 @@ var high_score
var time var time
var combos var combos
signal flash_text(text)
signal level_up(level) signal level_up(level)
signal flash_text(text)
func _ready(): func _ready():
load_user_data() load_user_data()
@ -69,15 +68,15 @@ func piece_dropped(ds):
func piece_locked(lines, t_spin): func piece_locked(lines, t_spin):
var ds var ds
if lines or t_spin: if lines or t_spin:
var text = T_SPIN_NAMES[t_spin]
if lines and t_spin: if lines and t_spin:
text += " " emit_signal("flash_text", t_spin + " " + LINES_CLEARED_NAMES[lines])
text += LINES_CLEARED_NAMES[lines] elif lines:
emit_signal("flash_text", text) emit_signal("flash_text", LINES_CLEARED_NAMES[lines])
ds = SCORES[lines][t_spin] elif t_spin:
goal -= ds emit_signal("flash_text", t_spin)
goal -= SCORES[lines][""]
$VBC/Goal.text = str(goal) $VBC/Goal.text = str(goal)
ds *= 100 * level ds = 100 * level * SCORES[lines][t_spin]
emit_signal("flash_text", str(ds)) emit_signal("flash_text", str(ds))
score += ds score += ds
$VBC/Score.text = str(score) $VBC/Score.text = str(score)

View File

@ -267,9 +267,10 @@ anchor_left = 0.0
anchor_top = 0.0 anchor_top = 0.0
anchor_right = 0.0 anchor_right = 0.0
anchor_bottom = 0.0 anchor_bottom = 0.0
margin_top = 153.0 margin_left = -116.0
margin_right = 78.0 margin_top = 205.0
margin_bottom = 170.0 margin_right = -38.0
margin_bottom = 222.0
rect_pivot_offset = Vector2( 0, 0 ) rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false rect_clip_content = false
mouse_filter = 2 mouse_filter = 2

View File

@ -30,16 +30,16 @@ render_priority = 0
trail_divisor = 2 trail_divisor = 2
trail_color_modifier = SubResource( 4 ) trail_color_modifier = SubResource( 4 )
emission_shape = 2 emission_shape = 2
emission_box_extents = Vector3( 10, 1, 1 ) emission_box_extents = Vector3( 1, 1, 1 )
flag_align_y = false flag_align_y = false
flag_rotate_y = true flag_rotate_y = true
flag_disable_z = false flag_disable_z = false
spread = 0.0 spread = 0.0
flatness = 0.0 flatness = 0.0
gravity = Vector3( 0, -10, 30 ) gravity = Vector3( 0, -30, 5 )
initial_velocity = 20.0 initial_velocity = 100.0
initial_velocity_random = 1.0 initial_velocity_random = 1.0
angular_velocity = 97.14 angular_velocity = 210.0
angular_velocity_random = 1.0 angular_velocity_random = 1.0
linear_accel = 100.0 linear_accel = 100.0
linear_accel_random = 1.0 linear_accel_random = 1.0
@ -61,9 +61,9 @@ anim_speed_random = 0.0
anim_offset = 0.0 anim_offset = 0.0
anim_offset_random = 0.0 anim_offset_random = 0.0
anim_loop = false anim_loop = false
_sections_unfolded = [ "Angular Velocity", "Color", "Gravity", "Initial Velocity", "Linear Accel", "Scale", "Spread" ] _sections_unfolded = [ "Angular Velocity", "Color", "Emission Shape", "Gravity", "Initial Velocity", "Linear Accel", "Scale", "Spread" ]
[node name="ExplodingLine" type="Particles" index="0"] [node name="ExplodingMino" type="Particles"]
layers = 1 layers = 1
material_override = null material_override = null
@ -75,7 +75,7 @@ lod_min_hysteresis = 0.0
lod_max_distance = 0.0 lod_max_distance = 0.0
lod_max_hysteresis = 0.0 lod_max_hysteresis = 0.0
emitting = false emitting = false
amount = 40 amount = 1
lifetime = 2.0 lifetime = 2.0
one_shot = true one_shot = true
preprocess = 0.0 preprocess = 0.0
@ -84,7 +84,7 @@ explosiveness = 1.0
randomness = 0.0 randomness = 0.0
fixed_fps = 0 fixed_fps = 0
fract_delta = true fract_delta = true
visibility_aabb = AABB( -5, -0.5, -1, 10, 1, 2 ) visibility_aabb = AABB( -0.5, -0.5, -0.5, 1, 1, 1 )
local_coords = false local_coords = false
draw_order = 0 draw_order = 0
process_material = SubResource( 5 ) process_material = SubResource( 5 )

View File

@ -162,7 +162,7 @@ subdivide_width = 0
subdivide_height = 0 subdivide_height = 0
subdivide_depth = 0 subdivide_depth = 0
[node name="Mino" type="Spatial"] [node name="Mino" type="Spatial" index="0"]
transform = Transform( 0.997027, 0, 0, 0, 0.997027, 0, 0, 0, 0.997027, 0, 0, 0 ) transform = Transform( 0.997027, 0, 0, 0, 0.997027, 0, 0, 0, 0.997027, 0, 0, 0 )
_sections_unfolded = [ "Pause", "Transform", "Visibility" ] _sections_unfolded = [ "Pause", "Transform", "Visibility" ]
@ -204,13 +204,13 @@ _sections_unfolded = [ "Draw Passes", "Drawing", "Geometry", "LOD", "Process Mat
[node name="SpotLight" type="SpotLight" parent="." index="2"] [node name="SpotLight" type="SpotLight" parent="." index="2"]
transform = Transform( 1, 0, 0, 0, -4.37114e-008, 1, 0, -1, -4.37114e-008, 0, 0, 0.5 ) transform = Transform( 1, 0, 0, 0, 0.0174524, 0.999848, 0, -0.999848, 0.0174524, 0, 4, 1 )
layers = 1 layers = 1
light_color = Color( 1, 1, 1, 1 ) light_color = Color( 1, 1, 1, 1 )
light_energy = 16.0 light_energy = 16.0
light_indirect_energy = 1.0 light_indirect_energy = 1.0
light_negative = false light_negative = false
light_specular = 0.5 light_specular = 0.86
light_bake_mode = 1 light_bake_mode = 1
light_cull_mask = -1 light_cull_mask = -1
shadow_enabled = false shadow_enabled = false
@ -219,10 +219,10 @@ shadow_bias = 0.15
shadow_contact = 0.0 shadow_contact = 0.0
shadow_reverse_cull_face = false shadow_reverse_cull_face = false
editor_only = false editor_only = false
spot_range = 20.0 spot_range = 30.0
spot_attenuation = 0.5 spot_attenuation = 0.5
spot_angle = 5.0 spot_angle = 5.0
spot_angle_attenuation = 2.0 spot_angle_attenuation = 2.0
_sections_unfolded = [ "Light", "Spot", "Transform" ] _sections_unfolded = [ "Editor", "Light", "Spot", "Transform" ]

View File

@ -23,7 +23,7 @@ params_point_size = 1.0
params_billboard_mode = 0 params_billboard_mode = 0
params_grow = false params_grow = false
params_use_alpha_scissor = false params_use_alpha_scissor = false
albedo_color = Color( 0.601563, 0.775878, 1, 0.486471 ) albedo_color = Color( 0.601563, 0.775878, 1, 0.259529 )
metallic = 1.0 metallic = 1.0
metallic_specular = 0.63 metallic_specular = 0.63
metallic_texture_channel = 4 metallic_texture_channel = 4
@ -31,7 +31,7 @@ roughness = 0.46
roughness_texture_channel = 0 roughness_texture_channel = 0
emission_enabled = true emission_enabled = true
emission = Color( 0.755859, 1, 0.914169, 1 ) emission = Color( 0.755859, 1, 0.914169, 1 )
emission_energy = 0.2 emission_energy = 0.1
emission_operator = 0 emission_operator = 0
emission_on_uv2 = false emission_on_uv2 = false
normal_enabled = false normal_enabled = false

View File

@ -2,8 +2,6 @@
[ext_resource path="res://Tetrominos/Mino/MinoMaterial.tres" type="Material" id=1] [ext_resource path="res://Tetrominos/Mino/MinoMaterial.tres" type="Material" id=1]
[sub_resource type="CubeMesh" id=1] [sub_resource type="CubeMesh" id=1]
custom_aabb = AABB( 0, 0, 0, 0, 0, 0 ) custom_aabb = AABB( 0, 0, 0, 0, 0, 0 )
@ -12,7 +10,7 @@ subdivide_width = 0
subdivide_height = 0 subdivide_height = 0
subdivide_depth = 0 subdivide_depth = 0
[node name="Mino" type="MeshInstance" index="0"] [node name="Mino" type="MeshInstance"]
layers = 1 layers = 1
material_override = null material_override = null

View File

@ -1,8 +1,7 @@
extends "Tetromino.gd" extends "Tetromino.gd"
const CLOCKWISE = -1 func _init():
const COUNTERCLOCKWISE = 1 super_rotation_system = [
const SUPER_ROTATION_SYSTEM = [
{ {
COUNTERCLOCKWISE: [ COUNTERCLOCKWISE: [
Vector3(0, -1, 0), Vector3(0, -1, 0),
@ -67,4 +66,4 @@ const SUPER_ROTATION_SYSTEM = [
Vector3(-2, 2, 0) Vector3(-2, 2, 0)
], ],
}, },
] ]

View File

@ -3,7 +3,7 @@
[ext_resource path="res://Tetrominos/Tetromino.gd" type="Script" id=1] [ext_resource path="res://Tetrominos/Tetromino.gd" type="Script" id=1]
[ext_resource path="res://Tetrominos/Mino/Mino.tscn" type="PackedScene" id=2] [ext_resource path="res://Tetrominos/Mino/Mino.tscn" type="PackedScene" id=2]
[node name="TetroJ" type="Spatial" index="0"] [node name="TetroJ" type="Spatial"]
script = ExtResource( 1 ) script = ExtResource( 1 )

View File

@ -1,4 +1,5 @@
extends "Tetromino.gd" extends "Tetromino.gd"
func rotate(direction): func turn(direction):
return 0 return false

View File

@ -3,8 +3,7 @@
[ext_resource path="res://Tetrominos/TetroO.gd" type="Script" id=1] [ext_resource path="res://Tetrominos/TetroO.gd" type="Script" id=1]
[ext_resource path="res://Tetrominos/Mino/Mino.tscn" type="PackedScene" id=2] [ext_resource path="res://Tetrominos/Mino/Mino.tscn" type="PackedScene" id=2]
[node name="TetroO" type="Spatial"]
[node name="TetroO" type="Spatial" index="0"]
script = ExtResource( 1 ) script = ExtResource( 1 )

View File

@ -7,19 +7,15 @@ const T_SLOT = [
Vector3(-1, -1, 0) Vector3(-1, -1, 0)
] ]
func rotate(direction): func t_spin():
var rotation_point = .rotate(direction) if rotated_last:
if rotation_point and t_spin != T_SPIN:
var center = to_global(minoes[0].translation) var center = to_global(minoes[0].translation)
var a = not grid_map.is_free_cell(center + T_SLOT[orientation]) var a = not grid_map.is_free_cell(center + T_SLOT[orientation])
var b = not grid_map.is_free_cell(center + T_SLOT[(1+orientation)%4]) var b = not grid_map.is_free_cell(center + T_SLOT[(1+orientation)%4])
var c = not grid_map.is_free_cell(center + T_SLOT[(2+orientation)%4]) var c = not grid_map.is_free_cell(center + T_SLOT[(3+orientation)%4])
var d = not grid_map.is_free_cell(center + T_SLOT[(3+orientation)%4]) var d = not grid_map.is_free_cell(center + T_SLOT[(2+orientation)%4])
if a and b and (c or d): if rotation_point_5_used or (a and b and (c or d)):
t_spin = T_SPIN return "T-SPIN"
elif c and d and (a or b): elif c and d and (a or b):
if rotation_point == 5: return "MINI T-SPIN"
t_spin = T_SPIN return ""
else:
t_spin = MINI_T_SPIN
return rotation_point

View File

@ -6,6 +6,7 @@
[node name="TetroT" type="Spatial"] [node name="TetroT" type="Spatial"]
script = ExtResource( 1 ) script = ExtResource( 1 )
_sections_unfolded = [ "Transform" ]
[node name="Mino0" parent="." index="0" instance=ExtResource( 2 )] [node name="Mino0" parent="." index="0" instance=ExtResource( 2 )]

View File

@ -3,10 +3,8 @@ extends Spatial
const NB_MINOES = 4 const NB_MINOES = 4
const CLOCKWISE = -1 const CLOCKWISE = -1
const COUNTERCLOCKWISE = 1 const COUNTERCLOCKWISE = 1
const NO_T_SPIN = 0
const T_SPIN = 1 var super_rotation_system = [
const MINI_T_SPIN = 2
const SUPER_ROTATION_SYSTEM = [
{ {
COUNTERCLOCKWISE: [ COUNTERCLOCKWISE: [
Vector3(0, 0, 0), Vector3(0, 0, 0),
@ -77,10 +75,10 @@ var minoes = []
var grid_map var grid_map
var lock_delay var lock_delay
var orientation = 0 var orientation = 0
var t_spin = NO_T_SPIN var rotation_point_5_used = false
var rotated_last = false
func _ready(): func _ready():
randomize()
for i in range(NB_MINOES): for i in range(NB_MINOES):
minoes.append(get_node("Mino"+str(i))) minoes.append(get_node("Mino"+str(i)))
grid_map = get_node("../Matrix/GridMap") grid_map = get_node("../Matrix/GridMap")
@ -100,28 +98,34 @@ func move(movement):
if grid_map.possible_positions(get_translations(), movement): if grid_map.possible_positions(get_translations(), movement):
translate(movement) translate(movement)
lock_delay.start() lock_delay.start()
rotated_last = false
return true return true
return false return false
func rotate(direction): func turn(direction):
var t = get_translations() var translations = get_translations()
var rotated_translations = [t[0]] var rotated_translations = [translations[0]]
var center = translations[0]
for i in range(1, NB_MINOES): for i in range(1, NB_MINOES):
var v = t[i] var rt = translations[i] - center
v -= t[0] rt = Vector3(-1*direction*rt.y, direction*rt.x, 0)
v = Vector3(-1*direction*v.y, direction*v.x, 0) rt += center
v += t[0] rotated_translations.append(rt)
rotated_translations.append(v) var movements = super_rotation_system[orientation][direction]
var movements = SUPER_ROTATION_SYSTEM[orientation][direction]
for i in range(movements.size()): for i in range(movements.size()):
if grid_map.possible_positions(rotated_translations, movements[i]): if grid_map.possible_positions(rotated_translations, movements[i]):
orientation -= direction orientation = (orientation - direction) % NB_MINOES
orientation %= NB_MINOES
set_translations(rotated_translations) set_translations(rotated_translations)
translate(movements[i]) translate(movements[i])
lock_delay.start() lock_delay.start()
return i+1 rotated_last = true
return 0 if i == 4:
rotation_point_5_used = true
return true
return false
func t_spin():
return ""
func emit_trail(visible): func emit_trail(visible):
var trail var trail

View File

@ -1,17 +1,5 @@
extends Control extends Control
# Note for the reader:
#
# This demo conveniently uses the same names for actions and for the container nodes
# that hold each remapping button. This allow to get back to the button based simply
# on the name of the corresponding action, but it might not be so simple in your project.
#
# A better approach for large-scale input remapping might be to do the connections between
# buttons and wait_for_input through the code, passing as arguments both the name of the
# action and the node, e.g.:
# button.connect("pressed", self, "wait_for_input", [ button, action ])
# Constants
const INPUT_ACTIONS = [ const INPUT_ACTIONS = [
"move_left", "move_left",
"move_right", "move_right",
@ -24,11 +12,8 @@ const INPUT_ACTIONS = [
] ]
const CONFIG_FILE = "user://input.cfg" const CONFIG_FILE = "user://input.cfg"
# Member variables
var action # To register the action the UI is currently handling var action # To register the action the UI is currently handling
var button # Button node corresponding to the above action var button # Button node corresponding to the above action
var enable_resume = true
# Load/save input mapping to a config file # Load/save input mapping to a config file
# Changes done while testing the demo will be persistent, saved to CONFIG_FILE # Changes done while testing the demo will be persistent, saved to CONFIG_FILE
@ -74,8 +59,7 @@ func wait_for_input(action_bind):
action = action_bind action = action_bind
# See note at the beginning of the script # See note at the beginning of the script
button = get_node("bindings").get_node(action).get_node("Button") button = get_node("bindings").get_node(action).get_node("Button")
#get_node("contextual_help").text = "Press a key to assign to the '" + action + "' action." button.text = "Press key"
enable_resume = false
set_process_input(true) set_process_input(true)
@ -85,8 +69,6 @@ func _input(event):
# Register the event as handled and stop polling # Register the event as handled and stop polling
get_tree().set_input_as_handled() get_tree().set_input_as_handled()
set_process_input(false) set_process_input(false)
# Reinitialise the contextual help label
#get_node("contextual_help").text = "Click a key binding to reassign it, or press the Cancel action."
# Display the string corresponding to the pressed key # Display the string corresponding to the pressed key
var scancode = OS.get_scancode_string(event.scancode) var scancode = OS.get_scancode_string(event.scancode)
@ -97,8 +79,7 @@ func _input(event):
# Add the new key binding # Add the new key binding
InputMap.action_add_event(action, event) InputMap.action_add_event(action, event)
save_to_config("input", action, scancode) save_to_config("input", action, scancode)
enable_resume = true hint_text()
func _ready(): func _ready():
# Load config if existing, if not it will be generated with default values # Load config if existing, if not it will be generated with default values
@ -112,5 +93,12 @@ func _ready():
button.text = OS.get_scancode_string(input_event.scancode) button.text = OS.get_scancode_string(input_event.scancode)
button.connect("pressed", self, "wait_for_input", [action]) button.connect("pressed", self, "wait_for_input", [action])
hint_text()
func hint_text():
var input_event = InputMap.get_action_list("pause")[0]
var scancode = OS.get_scancode_string(input_event.scancode)
$hint.text = "Press ["+ scancode + "] to resume\nor click on a button to change key assignment"
# Do not start processing input until a button is pressed # Do not start processing input until a button is pressed
set_process_input(false) set_process_input(false)

View File

@ -1,30 +1,27 @@
[gd_scene load_steps=6 format=2] [gd_scene load_steps=12 format=2]
[ext_resource path="res://controls.gd" type="Script" id=1] [ext_resource path="res://controls.gd" type="Script" id=1]
[ext_resource path="res://fonts/TitleFont.tres" type="DynamicFont" id=2] [ext_resource path="res://fonts/TitleFont.tres" type="DynamicFont" id=2]
[ext_resource path="res://fonts/Gamer.ttf" type="DynamicFontData" id=3] [ext_resource path="res://fonts/ButtonFont.tres" type="DynamicFont" id=3]
[ext_resource path="res://fonts/ButtonFont.tres" type="DynamicFont" id=4] [ext_resource path="res://icons/arrowLeft.png" type="Texture" id=4]
[ext_resource path="res://icons/arrowRight.png" type="Texture" id=5]
[ext_resource path="res://icons/clockwise.png" type="Texture" id=6]
[ext_resource path="res://icons/counterclockwise.png" type="Texture" id=7]
[ext_resource path="res://icons/arrowDown.png" type="Texture" id=8]
[ext_resource path="res://icons/harddrop.png" type="Texture" id=9]
[ext_resource path="res://icons/hold.png" type="Texture" id=10]
[ext_resource path="res://icons/pause.png" type="Texture" id=11]
[sub_resource type="DynamicFont" id=2] [node name="controls_ui" type="Control" index="0"]
size = 20
use_mipmaps = true
use_filter = false
extra_spacing_top = -4
extra_spacing_bottom = -4
font_data = ExtResource( 3 )
_sections_unfolded = [ "Extra Spacing", "Font", "Settings" ]
[node name="controls_ui" type="Control"]
anchor_left = 0.5 anchor_left = 0.5
anchor_top = 0.5 anchor_top = 0.5
anchor_right = 0.5 anchor_right = 0.5
anchor_bottom = 0.5 anchor_bottom = 0.5
margin_left = -30.0 margin_left = -30.0
margin_top = 10.0 margin_top = 20.0
margin_right = 10.0 margin_right = 10.0
margin_bottom = 50.0 margin_bottom = 60.0
rect_pivot_offset = Vector2( 0, 0 ) rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false rect_clip_content = false
mouse_filter = 0 mouse_filter = 0
@ -42,10 +39,10 @@ anchor_left = 0.0
anchor_top = 0.0 anchor_top = 0.0
anchor_right = 0.0 anchor_right = 0.0
anchor_bottom = 0.0 anchor_bottom = 0.0
margin_left = -40.0 margin_left = -220.0
margin_top = -150.0 margin_top = -190.0
margin_right = 110.0 margin_right = 280.0
margin_bottom = -111.0 margin_bottom = -151.0
rect_pivot_offset = Vector2( 0, 0 ) rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false rect_clip_content = false
mouse_filter = 2 mouse_filter = 2
@ -56,6 +53,8 @@ custom_fonts/font = ExtResource( 2 )
custom_colors/font_color = Color( 0.443137, 0.709804, 0.819608, 0.533333 ) custom_colors/font_color = Color( 0.443137, 0.709804, 0.819608, 0.533333 )
custom_colors/font_color_shadow = Color( 1, 1, 1, 0.0968627 ) custom_colors/font_color_shadow = Color( 1, 1, 1, 0.0968627 )
text = "PAUSE" text = "PAUSE"
align = 1
valign = 1
percent_visible = 1.0 percent_visible = 1.0
lines_skipped = 0 lines_skipped = 0
max_lines_visible = -1 max_lines_visible = -1
@ -84,10 +83,10 @@ anchor_left = 0.0
anchor_top = 0.0 anchor_top = 0.0
anchor_right = 0.0 anchor_right = 0.0
anchor_bottom = 0.0 anchor_bottom = 0.0
margin_left = 50.0 margin_left = 20.0
margin_top = 50.0 margin_top = 65.0
margin_right = 90.0 margin_right = 60.0
margin_bottom = 90.0 margin_bottom = 105.0
rect_pivot_offset = Vector2( 0, 0 ) rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false rect_clip_content = false
mouse_filter = 0 mouse_filter = 0
@ -95,38 +94,14 @@ mouse_default_cursor_shape = 0
size_flags_horizontal = 2 size_flags_horizontal = 2
size_flags_vertical = 2 size_flags_vertical = 2
[node name="Label" type="Label" parent="bindings/move_left" index="0"] [node name="Button" type="Button" parent="bindings/move_left" index="0"]
anchor_left = 0.0
anchor_top = 0.0
anchor_right = 0.0
anchor_bottom = 0.0
margin_right = 69.0
margin_bottom = 29.0
rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false
mouse_filter = 2
mouse_default_cursor_shape = 0
size_flags_horizontal = 2
size_flags_vertical = 0
custom_fonts/font = SubResource( 2 )
custom_colors/font_color = Color( 0.752941, 0.921569, 0.988235, 1 )
text = "move
left"
valign = 1
percent_visible = 1.0
lines_skipped = 0
max_lines_visible = -1
_sections_unfolded = [ "Rect", "custom_fonts" ]
[node name="Button" type="Button" parent="bindings/move_left" index="1"]
anchor_left = 0.0 anchor_left = 0.0
anchor_top = 0.0 anchor_top = 0.0
anchor_right = 0.0 anchor_right = 0.0
anchor_bottom = 0.0 anchor_bottom = 0.0
margin_left = 80.0 margin_left = 80.0
margin_right = 155.0 margin_right = 174.0
margin_bottom = 37.0 margin_bottom = 37.0
rect_pivot_offset = Vector2( 0, 0 ) rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false rect_clip_content = false
@ -135,25 +110,32 @@ mouse_filter = 0
mouse_default_cursor_shape = 0 mouse_default_cursor_shape = 0
size_flags_horizontal = 2 size_flags_horizontal = 2
size_flags_vertical = 2 size_flags_vertical = 2
custom_fonts/font = ExtResource( 4 ) custom_fonts/font = ExtResource( 3 )
toggle_mode = false toggle_mode = false
enabled_focus_mode = 2 enabled_focus_mode = 2
shortcut = null shortcut = null
group = null group = null
text = "Press key"
flat = false flat = false
align = 1 align = 1
_sections_unfolded = [ "Rect" ] _sections_unfolded = [ "Rect" ]
[node name="arrowLeft" type="Sprite" parent="bindings/move_left" index="1"]
position = Vector2( 30, 20 )
scale = Vector2( 0.75, 0.75 )
texture = ExtResource( 4 )
[node name="move_right" type="Control" parent="bindings" index="1"] [node name="move_right" type="Control" parent="bindings" index="1"]
anchor_left = 0.0 anchor_left = 0.0
anchor_top = 0.0 anchor_top = 0.0
anchor_right = 0.0 anchor_right = 0.0
anchor_bottom = 0.0 anchor_bottom = 0.0
margin_left = 226.0 margin_left = 220.0
margin_top = 51.0 margin_top = 65.0
margin_right = 266.0 margin_right = 260.0
margin_bottom = 91.0 margin_bottom = 105.0
rect_pivot_offset = Vector2( 0, 0 ) rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false rect_clip_content = false
mouse_filter = 0 mouse_filter = 0
@ -161,32 +143,7 @@ mouse_default_cursor_shape = 0
size_flags_horizontal = 2 size_flags_horizontal = 2
size_flags_vertical = 2 size_flags_vertical = 2
[node name="Label" type="Label" parent="bindings/move_right" index="0"] [node name="Button" type="Button" parent="bindings/move_right" index="0"]
anchor_left = 0.0
anchor_top = 0.0
anchor_right = 0.0
anchor_bottom = 0.0
margin_left = 5.0
margin_top = -1.0
margin_right = 80.0
margin_bottom = 31.0
rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false
mouse_filter = 2
mouse_default_cursor_shape = 0
size_flags_horizontal = 2
size_flags_vertical = 0
custom_fonts/font = SubResource( 2 )
custom_colors/font_color = Color( 0.752941, 0.921569, 0.988235, 1 )
text = "move
right"
valign = 1
percent_visible = 1.0
lines_skipped = 0
max_lines_visible = -1
[node name="Button" type="Button" parent="bindings/move_right" index="1"]
anchor_left = 0.0 anchor_left = 0.0
anchor_top = 0.0 anchor_top = 0.0
@ -194,7 +151,7 @@ anchor_right = 0.0
anchor_bottom = 0.0 anchor_bottom = 0.0
margin_left = 84.0 margin_left = 84.0
margin_top = -1.0 margin_top = -1.0
margin_right = 159.0 margin_right = 178.0
margin_bottom = 36.0 margin_bottom = 36.0
rect_pivot_offset = Vector2( 0, 0 ) rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false rect_clip_content = false
@ -203,13 +160,22 @@ mouse_filter = 0
mouse_default_cursor_shape = 0 mouse_default_cursor_shape = 0
size_flags_horizontal = 2 size_flags_horizontal = 2
size_flags_vertical = 2 size_flags_vertical = 2
custom_fonts/font = ExtResource( 4 ) custom_fonts/font = ExtResource( 3 )
toggle_mode = false toggle_mode = false
enabled_focus_mode = 2 enabled_focus_mode = 2
shortcut = null shortcut = null
group = null group = null
text = "Press key"
flat = false flat = false
align = 1 align = 1
_sections_unfolded = [ "custom_fonts" ]
[node name="arrowRight" type="Sprite" parent="bindings/move_right" index="1"]
position = Vector2( 34, 19 )
scale = Vector2( 0.8, 0.8 )
texture = ExtResource( 5 )
_sections_unfolded = [ "Transform" ]
[node name="rotate_clockwise" type="Control" parent="bindings" index="2"] [node name="rotate_clockwise" type="Control" parent="bindings" index="2"]
@ -217,10 +183,10 @@ anchor_left = 0.0
anchor_top = 0.0 anchor_top = 0.0
anchor_right = 0.0 anchor_right = 0.0
anchor_bottom = 0.0 anchor_bottom = 0.0
margin_left = 50.0 margin_left = 224.0
margin_top = 100.0 margin_top = 114.0
margin_right = 90.0 margin_right = 264.0
margin_bottom = 140.0 margin_bottom = 154.0
rect_pivot_offset = Vector2( 0, 0 ) rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false rect_clip_content = false
mouse_filter = 0 mouse_filter = 0
@ -228,37 +194,14 @@ mouse_default_cursor_shape = 0
size_flags_horizontal = 2 size_flags_horizontal = 2
size_flags_vertical = 2 size_flags_vertical = 2
[node name="Label" type="Label" parent="bindings/rotate_clockwise" index="0"] [node name="Button" type="Button" parent="bindings/rotate_clockwise" index="0"]
anchor_left = 0.0
anchor_top = 0.0
anchor_right = 0.0
anchor_bottom = 0.0
margin_right = 118.0
margin_bottom = 32.0
rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false
mouse_filter = 2
mouse_default_cursor_shape = 0
size_flags_horizontal = 2
size_flags_vertical = 0
custom_fonts/font = SubResource( 2 )
custom_colors/font_color = Color( 0.752941, 0.921569, 0.988235, 1 )
text = "rotate
clockwise"
valign = 1
percent_visible = 1.0
lines_skipped = 0
max_lines_visible = -1
[node name="Button" type="Button" parent="bindings/rotate_clockwise" index="1"]
anchor_left = 0.0 anchor_left = 0.0
anchor_top = 0.0 anchor_top = 0.0
anchor_right = 0.0 anchor_right = 0.0
anchor_bottom = 0.0 anchor_bottom = 0.0
margin_left = 80.0 margin_left = 80.0
margin_right = 155.0 margin_right = 174.0
margin_bottom = 37.0 margin_bottom = 37.0
rect_pivot_offset = Vector2( 0, 0 ) rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false rect_clip_content = false
@ -267,14 +210,21 @@ mouse_filter = 0
mouse_default_cursor_shape = 0 mouse_default_cursor_shape = 0
size_flags_horizontal = 2 size_flags_horizontal = 2
size_flags_vertical = 2 size_flags_vertical = 2
custom_fonts/font = ExtResource( 4 ) custom_fonts/font = ExtResource( 3 )
toggle_mode = false toggle_mode = false
enabled_focus_mode = 2 enabled_focus_mode = 2
shortcut = null shortcut = null
group = null group = null
text = "Press key"
flat = false flat = false
align = 1 align = 1
_sections_unfolded = [ "custom_fonts" ] _sections_unfolded = [ "Rect", "custom_fonts" ]
[node name="clockwise" type="Sprite" parent="bindings/rotate_clockwise" index="1"]
position = Vector2( 30, 15 )
scale = Vector2( 0.8, 0.8 )
texture = ExtResource( 6 )
[node name="rotate_counterclockwise" type="Control" parent="bindings" index="3"] [node name="rotate_counterclockwise" type="Control" parent="bindings" index="3"]
@ -282,10 +232,10 @@ anchor_left = 0.0
anchor_top = 0.0 anchor_top = 0.0
anchor_right = 0.0 anchor_right = 0.0
anchor_bottom = 0.0 anchor_bottom = 0.0
margin_left = 226.0 margin_left = 15.0
margin_top = 101.0 margin_top = 115.0
margin_right = 266.0 margin_right = 55.0
margin_bottom = 141.0 margin_bottom = 155.0
rect_pivot_offset = Vector2( 0, 0 ) rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false rect_clip_content = false
mouse_filter = 0 mouse_filter = 0
@ -293,33 +243,7 @@ mouse_default_cursor_shape = 0
size_flags_horizontal = 2 size_flags_horizontal = 2
size_flags_vertical = 2 size_flags_vertical = 2
[node name="Label" type="Label" parent="bindings/rotate_counterclockwise" index="0"] [node name="Button" type="Button" parent="bindings/rotate_counterclockwise" index="0"]
anchor_left = 0.0
anchor_top = 0.0
anchor_right = 0.0
anchor_bottom = 0.0
margin_left = 5.0
margin_top = -2.0
margin_right = 177.0
margin_bottom = 37.0
rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false
mouse_filter = 2
mouse_default_cursor_shape = 0
size_flags_horizontal = 2
size_flags_vertical = 0
custom_fonts/font = SubResource( 2 )
custom_colors/font_color = Color( 0.752941, 0.921569, 0.988235, 1 )
text = "rotate
counter
clockwise"
valign = 1
percent_visible = 1.0
lines_skipped = 0
max_lines_visible = -1
[node name="Button" type="Button" parent="bindings/rotate_counterclockwise" index="1"]
anchor_left = 0.0 anchor_left = 0.0
anchor_top = 0.0 anchor_top = 0.0
@ -327,7 +251,7 @@ anchor_right = 0.0
anchor_bottom = 0.0 anchor_bottom = 0.0
margin_left = 84.0 margin_left = 84.0
margin_top = -1.0 margin_top = -1.0
margin_right = 159.0 margin_right = 178.0
margin_bottom = 36.0 margin_bottom = 36.0
rect_pivot_offset = Vector2( 0, 0 ) rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false rect_clip_content = false
@ -336,25 +260,32 @@ mouse_filter = 0
mouse_default_cursor_shape = 0 mouse_default_cursor_shape = 0
size_flags_horizontal = 2 size_flags_horizontal = 2
size_flags_vertical = 2 size_flags_vertical = 2
custom_fonts/font = ExtResource( 4 ) custom_fonts/font = ExtResource( 3 )
toggle_mode = false toggle_mode = false
enabled_focus_mode = 2 enabled_focus_mode = 2
shortcut = null shortcut = null
group = null group = null
text = "Press key"
flat = false flat = false
align = 1 align = 1
_sections_unfolded = [ "Rect" ] _sections_unfolded = [ "Rect" ]
[node name="counterclockwise" type="Sprite" parent="bindings/rotate_counterclockwise" index="1"]
position = Vector2( 35, 15 )
scale = Vector2( 0.82, 0.82 )
texture = ExtResource( 7 )
[node name="soft_drop" type="Control" parent="bindings" index="4"] [node name="soft_drop" type="Control" parent="bindings" index="4"]
anchor_left = 0.0 anchor_left = 0.0
anchor_top = 0.0 anchor_top = 0.0
anchor_right = 0.0 anchor_right = 0.0
anchor_bottom = 0.0 anchor_bottom = 0.0
margin_left = 50.0 margin_left = 20.0
margin_top = 150.0 margin_top = 165.0
margin_right = 90.0 margin_right = 60.0
margin_bottom = 190.0 margin_bottom = 205.0
rect_pivot_offset = Vector2( 0, 0 ) rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false rect_clip_content = false
mouse_filter = 0 mouse_filter = 0
@ -362,37 +293,14 @@ mouse_default_cursor_shape = 0
size_flags_horizontal = 2 size_flags_horizontal = 2
size_flags_vertical = 2 size_flags_vertical = 2
[node name="Label" type="Label" parent="bindings/soft_drop" index="0"] [node name="Button" type="Button" parent="bindings/soft_drop" index="0"]
anchor_left = 0.0
anchor_top = 0.0
anchor_right = 0.0
anchor_bottom = 0.0
margin_right = 66.0
margin_bottom = 32.0
rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false
mouse_filter = 2
mouse_default_cursor_shape = 0
size_flags_horizontal = 2
size_flags_vertical = 0
custom_fonts/font = SubResource( 2 )
custom_colors/font_color = Color( 0.752941, 0.921569, 0.988235, 1 )
text = "soft
drop"
valign = 1
percent_visible = 1.0
lines_skipped = 0
max_lines_visible = -1
[node name="Button" type="Button" parent="bindings/soft_drop" index="1"]
anchor_left = 0.0 anchor_left = 0.0
anchor_top = 0.0 anchor_top = 0.0
anchor_right = 0.0 anchor_right = 0.0
anchor_bottom = 0.0 anchor_bottom = 0.0
margin_left = 80.0 margin_left = 80.0
margin_right = 155.0 margin_right = 174.0
margin_bottom = 37.0 margin_bottom = 37.0
rect_pivot_offset = Vector2( 0, 0 ) rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false rect_clip_content = false
@ -401,24 +309,32 @@ mouse_filter = 0
mouse_default_cursor_shape = 0 mouse_default_cursor_shape = 0
size_flags_horizontal = 2 size_flags_horizontal = 2
size_flags_vertical = 2 size_flags_vertical = 2
custom_fonts/font = ExtResource( 4 ) custom_fonts/font = ExtResource( 3 )
toggle_mode = false toggle_mode = false
enabled_focus_mode = 2 enabled_focus_mode = 2
shortcut = null shortcut = null
group = null group = null
text = "Press key"
flat = false flat = false
align = 1 align = 1
[node name="arrowDown" type="Sprite" parent="bindings/soft_drop" index="1"]
position = Vector2( 30, 20 )
scale = Vector2( 0.8, 0.8 )
texture = ExtResource( 8 )
_sections_unfolded = [ "Transform" ]
[node name="hard_drop" type="Control" parent="bindings" index="5"] [node name="hard_drop" type="Control" parent="bindings" index="5"]
anchor_left = 0.0 anchor_left = 0.0
anchor_top = 0.0 anchor_top = 0.0
anchor_right = 0.0 anchor_right = 0.0
anchor_bottom = 0.0 anchor_bottom = 0.0
margin_left = 226.0 margin_left = 220.0
margin_top = 151.0 margin_top = 165.0
margin_right = 266.0 margin_right = 260.0
margin_bottom = 191.0 margin_bottom = 205.0
rect_pivot_offset = Vector2( 0, 0 ) rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false rect_clip_content = false
mouse_filter = 0 mouse_filter = 0
@ -426,32 +342,7 @@ mouse_default_cursor_shape = 0
size_flags_horizontal = 2 size_flags_horizontal = 2
size_flags_vertical = 2 size_flags_vertical = 2
[node name="Label" type="Label" parent="bindings/hard_drop" index="0"] [node name="Button" type="Button" parent="bindings/hard_drop" index="0"]
anchor_left = 0.0
anchor_top = 0.0
anchor_right = 0.0
anchor_bottom = 0.0
margin_left = 5.0
margin_top = -1.0
margin_right = 75.0
margin_bottom = 31.0
rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false
mouse_filter = 2
mouse_default_cursor_shape = 0
size_flags_horizontal = 2
size_flags_vertical = 0
custom_fonts/font = SubResource( 2 )
custom_colors/font_color = Color( 0.752941, 0.921569, 0.988235, 1 )
text = "hard
drop"
valign = 1
percent_visible = 1.0
lines_skipped = 0
max_lines_visible = -1
[node name="Button" type="Button" parent="bindings/hard_drop" index="1"]
anchor_left = 0.0 anchor_left = 0.0
anchor_top = 0.0 anchor_top = 0.0
@ -459,7 +350,7 @@ anchor_right = 0.0
anchor_bottom = 0.0 anchor_bottom = 0.0
margin_left = 84.0 margin_left = 84.0
margin_top = -1.0 margin_top = -1.0
margin_right = 159.0 margin_right = 178.0
margin_bottom = 36.0 margin_bottom = 36.0
rect_pivot_offset = Vector2( 0, 0 ) rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false rect_clip_content = false
@ -468,24 +359,32 @@ mouse_filter = 0
mouse_default_cursor_shape = 0 mouse_default_cursor_shape = 0
size_flags_horizontal = 2 size_flags_horizontal = 2
size_flags_vertical = 2 size_flags_vertical = 2
custom_fonts/font = ExtResource( 4 ) custom_fonts/font = ExtResource( 3 )
toggle_mode = false toggle_mode = false
enabled_focus_mode = 2 enabled_focus_mode = 2
shortcut = null shortcut = null
group = null group = null
text = "Press key"
flat = false flat = false
align = 1 align = 1
[node name="harddrop" type="Sprite" parent="bindings/hard_drop" index="1"]
position = Vector2( 34, 19 )
scale = Vector2( 0.75, 0.75 )
texture = ExtResource( 9 )
_sections_unfolded = [ "Transform", "Z Index" ]
[node name="hold" type="Control" parent="bindings" index="6"] [node name="hold" type="Control" parent="bindings" index="6"]
anchor_left = 0.0 anchor_left = 0.0
anchor_top = 0.0 anchor_top = 0.0
anchor_right = 0.0 anchor_right = 0.0
anchor_bottom = 0.0 anchor_bottom = 0.0
margin_left = 50.0 margin_left = 20.0
margin_top = 200.0 margin_top = 215.0
margin_right = 90.0 margin_right = 60.0
margin_bottom = 240.0 margin_bottom = 255.0
rect_pivot_offset = Vector2( 0, 0 ) rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false rect_clip_content = false
mouse_filter = 0 mouse_filter = 0
@ -493,36 +392,14 @@ mouse_default_cursor_shape = 0
size_flags_horizontal = 2 size_flags_horizontal = 2
size_flags_vertical = 2 size_flags_vertical = 2
[node name="Label" type="Label" parent="bindings/hold" index="0"] [node name="Button" type="Button" parent="bindings/hold" index="0"]
anchor_left = 0.0
anchor_top = 0.0
anchor_right = 0.0
anchor_bottom = 0.0
margin_right = 55.0
margin_bottom = 40.0
rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false
mouse_filter = 2
mouse_default_cursor_shape = 0
size_flags_horizontal = 2
size_flags_vertical = 0
custom_fonts/font = SubResource( 2 )
custom_colors/font_color = Color( 0.752941, 0.921569, 0.988235, 1 )
text = "hold"
valign = 1
percent_visible = 1.0
lines_skipped = 0
max_lines_visible = -1
[node name="Button" type="Button" parent="bindings/hold" index="1"]
anchor_left = 0.0 anchor_left = 0.0
anchor_top = 0.0 anchor_top = 0.0
anchor_right = 0.0 anchor_right = 0.0
anchor_bottom = 0.0 anchor_bottom = 0.0
margin_left = 80.0 margin_left = 80.0
margin_right = 155.0 margin_right = 174.0
margin_bottom = 37.0 margin_bottom = 37.0
rect_pivot_offset = Vector2( 0, 0 ) rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false rect_clip_content = false
@ -531,24 +408,31 @@ mouse_filter = 0
mouse_default_cursor_shape = 0 mouse_default_cursor_shape = 0
size_flags_horizontal = 2 size_flags_horizontal = 2
size_flags_vertical = 2 size_flags_vertical = 2
custom_fonts/font = ExtResource( 4 ) custom_fonts/font = ExtResource( 3 )
toggle_mode = false toggle_mode = false
enabled_focus_mode = 2 enabled_focus_mode = 2
shortcut = null shortcut = null
group = null group = null
text = "Press key"
flat = false flat = false
align = 1 align = 1
[node name="hold" type="Sprite" parent="bindings/hold" index="1"]
position = Vector2( 30, 20 )
scale = Vector2( 0.8, 0.8 )
texture = ExtResource( 10 )
[node name="pause" type="Control" parent="bindings" index="7"] [node name="pause" type="Control" parent="bindings" index="7"]
anchor_left = 0.0 anchor_left = 0.0
anchor_top = 0.0 anchor_top = 0.0
anchor_right = 0.0 anchor_right = 0.0
anchor_bottom = 0.0 anchor_bottom = 0.0
margin_left = 226.0 margin_left = 220.0
margin_top = 201.0 margin_top = 215.0
margin_right = 266.0 margin_right = 260.0
margin_bottom = 241.0 margin_bottom = 255.0
rect_pivot_offset = Vector2( 0, 0 ) rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false rect_clip_content = false
mouse_filter = 0 mouse_filter = 0
@ -556,33 +440,7 @@ mouse_default_cursor_shape = 0
size_flags_horizontal = 2 size_flags_horizontal = 2
size_flags_vertical = 2 size_flags_vertical = 2
[node name="Label" type="Label" parent="bindings/pause" index="0"] [node name="Button" type="Button" parent="bindings/pause" index="0"]
anchor_left = 0.0
anchor_top = 0.0
anchor_right = 0.0
anchor_bottom = 0.0
margin_left = 5.0
margin_top = 3.0
margin_right = 106.0
margin_bottom = 35.0
rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false
mouse_filter = 2
mouse_default_cursor_shape = 0
size_flags_horizontal = 2
size_flags_vertical = 0
custom_fonts/font = SubResource( 2 )
custom_colors/font_color = Color( 0.752941, 0.921569, 0.988235, 1 )
text = "pause
resume"
valign = 1
percent_visible = 1.0
lines_skipped = 0
max_lines_visible = -1
_sections_unfolded = [ "custom_fonts" ]
[node name="Button" type="Button" parent="bindings/pause" index="1"]
anchor_left = 0.0 anchor_left = 0.0
anchor_top = 0.0 anchor_top = 0.0
@ -590,7 +448,7 @@ anchor_right = 0.0
anchor_bottom = 0.0 anchor_bottom = 0.0
margin_left = 84.0 margin_left = 84.0
margin_top = -1.0 margin_top = -1.0
margin_right = 159.0 margin_right = 178.0
margin_bottom = 36.0 margin_bottom = 36.0
rect_pivot_offset = Vector2( 0, 0 ) rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false rect_clip_content = false
@ -599,12 +457,46 @@ mouse_filter = 0
mouse_default_cursor_shape = 0 mouse_default_cursor_shape = 0
size_flags_horizontal = 2 size_flags_horizontal = 2
size_flags_vertical = 2 size_flags_vertical = 2
custom_fonts/font = ExtResource( 4 ) custom_fonts/font = ExtResource( 3 )
toggle_mode = false toggle_mode = false
enabled_focus_mode = 2 enabled_focus_mode = 2
shortcut = null shortcut = null
group = null group = null
text = "Press key"
flat = false flat = false
align = 1 align = 1
[node name="pause" type="Sprite" parent="bindings/pause" index="1"]
position = Vector2( 34, 19 )
scale = Vector2( 0.8, 0.8 )
texture = ExtResource( 11 )
_sections_unfolded = [ "Transform" ]
[node name="hint" type="Label" parent="." index="2"]
anchor_left = 0.0
anchor_top = 0.0
anchor_right = 0.0
anchor_bottom = 0.0
margin_left = -220.0
margin_top = -135.0
margin_right = 280.0
margin_bottom = -84.0
rect_pivot_offset = Vector2( 0, 0 )
rect_clip_content = false
mouse_filter = 2
mouse_default_cursor_shape = 0
size_flags_horizontal = 1
size_flags_vertical = 4
custom_fonts/font = ExtResource( 3 )
text = "Press [pause key] to resume
or click on a button to change key assignment"
align = 1
valign = 1
percent_visible = 1.0
lines_skipped = 0
max_lines_visible = -1
_sections_unfolded = [ "custom_fonts" ]

BIN
source/icons/arrowDown.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 15 KiB

BIN
source/icons/arrowLeft.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 15 KiB

BIN
source/icons/arrowRight.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 15 KiB

BIN
source/icons/clockwise.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 665 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 15 KiB

BIN
source/icons/harddrop.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 503 B

BIN
source/icons/hold.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 602 B

BIN
source/icons/pause.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 15 KiB

View File

@ -36,13 +36,13 @@ func set_instrument( instrument ):
self.ads_state = instrument.ads_state self.ads_state = instrument.ads_state
self.release_state = instrument.release_state self.release_state = instrument.release_state
func play( ): func play( from_position=0.0 ):
self.releasing = false self.releasing = false
self.timer = 0.0 self.timer = 0.0
self.using_timer = 0.0 self.using_timer = 0.0
self.current_volume = self.ads_state[0].volume self.current_volume = self.ads_state[0].volume
self.stream.mix_rate = round( self.mix_rate * ( 1.0 + self.pitch_bend * 0.5 ) ) self.stream.mix_rate = round( self.mix_rate * ( 1.0 + self.pitch_bend * 0.5 ) )
.play( 0.0 ) .play( from_position )
self._update_volume( ) self._update_volume( )
func start_release( ): func start_release( ):

BIN
source/midi/Korobeiniki.mid Normal file

Binary file not shown.

Binary file not shown.

Binary file not shown.

View File

@ -17,8 +17,8 @@ config/icon="res://icons/48.png"
[display] [display]
window/size/width=500 window/size/width=640
window/size/height=500 window/size/height=480
window/vsync/use_vsync=false window/vsync/use_vsync=false
window/stretch/aspect="expand" window/stretch/aspect="expand"
@ -50,4 +50,5 @@ toggle_fullscreen=[ Object(InputEventKey,"resource_local_to_scene":false,"resour
[rendering] [rendering]
environment/default_clear_color=Color( 0, 0, 0, 1 ) environment/default_clear_color=Color( 0, 0, 0, 1 )
environment/default_environment="res://Environment.tres"
quality/main_loop_type="" quality/main_loop_type=""

Binary file not shown.

Before

Width:  |  Height:  |  Size: 4.6 KiB

After

Width:  |  Height:  |  Size: 7.5 KiB

File diff suppressed because one or more lines are too long

Binary file not shown.

Binary file not shown.

Before

Width:  |  Height:  |  Size: 398 KiB

After

Width:  |  Height:  |  Size: 421 KiB