adding music manager
This commit is contained in:
parent
01811fd19f
commit
0811638fd1
26 changed files with 975 additions and 190 deletions
|
@ -215,9 +215,18 @@ msgstr "Del"
|
||||||
msgid "BUTTON_RIGHT"
|
msgid "BUTTON_RIGHT"
|
||||||
msgstr "Button Right"
|
msgstr "Button Right"
|
||||||
|
|
||||||
|
msgid "BUTTON_MIDDLE"
|
||||||
|
msgstr "Button Middle"
|
||||||
|
|
||||||
msgid "BUTTON_LEFT"
|
msgid "BUTTON_LEFT"
|
||||||
msgstr "Button Left"
|
msgstr "Button Left"
|
||||||
|
|
||||||
|
msgid "BUTTON_XBUTTON1"
|
||||||
|
msgstr "Button X1"
|
||||||
|
|
||||||
|
msgid "BUTTON_XBUTTON2"
|
||||||
|
msgstr "Button X2"
|
||||||
|
|
||||||
msgid "BUTTON_WHEEL_UP"
|
msgid "BUTTON_WHEEL_UP"
|
||||||
msgstr "Button wheel up"
|
msgstr "Button wheel up"
|
||||||
|
|
||||||
|
@ -225,13 +234,59 @@ msgid "BUTTON_WHEEL_DOWN"
|
||||||
msgstr "Button wheel down"
|
msgstr "Button wheel down"
|
||||||
|
|
||||||
msgid "INPUT_VIEW_CAMERA_MOVE_PLAYER_FOLLOW"
|
msgid "INPUT_VIEW_CAMERA_MOVE_PLAYER_FOLLOW"
|
||||||
msgstr "Camera move and player follow"
|
msgstr "Rotate camera and player follow"
|
||||||
|
|
||||||
msgid "INPUT_VIEW_CAMERA_MOVE_ONLY"
|
msgid "INPUT_VIEW_CAMERA_MOVE_ONLY"
|
||||||
msgstr "Camera move only"
|
msgstr "Rotate camera only"
|
||||||
|
|
||||||
|
msgid "INPUT_VIEW_CAMERA_PLAYER_WALK"
|
||||||
|
msgstr "Rotate camera and player move"
|
||||||
|
|
||||||
msgid "INPUT_ACTION_JUMP"
|
msgid "INPUT_ACTION_JUMP"
|
||||||
msgstr "Jump"
|
msgstr "Jump"
|
||||||
|
|
||||||
msgid "POPUP_ABOUT_MESSAGE/TITLE"
|
msgid "POPUP_ABOUT_MESSAGE/TITLE"
|
||||||
msgstr "About"
|
msgstr "About"
|
||||||
|
|
||||||
|
msgid "HUD/MUSIC"
|
||||||
|
msgstr "Sound"
|
||||||
|
|
||||||
|
msgid "MUSIC_MANAGER/TITLE"
|
||||||
|
msgstr "Sound Manager"
|
||||||
|
|
||||||
|
msgid "Music"
|
||||||
|
msgstr "Music"
|
||||||
|
|
||||||
|
msgid "Mixer"
|
||||||
|
msgstr "Mixer"
|
||||||
|
|
||||||
|
msgid "MUSIC_MANAGER/PLAY"
|
||||||
|
msgstr "Play"
|
||||||
|
|
||||||
|
msgid "MUSIC_MANAGER/RANDOM"
|
||||||
|
msgstr "Random"
|
||||||
|
|
||||||
|
msgid "MUSIC_MANAGER/REINIT"
|
||||||
|
msgstr "Reinit"
|
||||||
|
|
||||||
|
msgid "MUSIC_MANAGER/MUTE"
|
||||||
|
msgstr "Mute"
|
||||||
|
|
||||||
|
msgid "MUSIC_MANAGER/GLOBAL_VOLUME"
|
||||||
|
msgstr "Global volume"
|
||||||
|
|
||||||
|
msgid "MUSIC_MANAGER/MUSIC_VOLUME"
|
||||||
|
msgstr "Music volume"
|
||||||
|
|
||||||
|
msgid "MUSIC_MANAGER/EFFECT_VOLUME"
|
||||||
|
msgstr "Effect volume"
|
||||||
|
|
||||||
|
msgid "EDIT_CONTROL/MOVE_CAMERA_REVERSE_HORIZONTAL"
|
||||||
|
msgstr "Reverse horizontal"
|
||||||
|
|
||||||
|
msgid "EDIT_CONTROL/MOVE_CAMERA_REVERSE_VERTICAL"
|
||||||
|
msgstr "Reverse vertical"
|
||||||
|
|
||||||
|
msgid "NO_MOUSE_BUTTON"
|
||||||
|
msgstr "Nothing"
|
||||||
|
|
||||||
|
|
|
@ -215,9 +215,18 @@ msgstr "Supprimer"
|
||||||
msgid "BUTTON_RIGHT"
|
msgid "BUTTON_RIGHT"
|
||||||
msgstr "Bouton droit de la souris"
|
msgstr "Bouton droit de la souris"
|
||||||
|
|
||||||
|
msgid "BUTTON_MIDDLE"
|
||||||
|
msgstr "Bouton mileu de la souris"
|
||||||
|
|
||||||
msgid "BUTTON_LEFT"
|
msgid "BUTTON_LEFT"
|
||||||
msgstr "Bouton gauche de la souris"
|
msgstr "Bouton gauche de la souris"
|
||||||
|
|
||||||
|
msgid "BUTTON_XBUTTON1"
|
||||||
|
msgstr "Bouton X1 de la souris"
|
||||||
|
|
||||||
|
msgid "BUTTON_XBUTTON2"
|
||||||
|
msgstr "Bouton X2 de la souris"
|
||||||
|
|
||||||
msgid "BUTTON_WHEEL_UP"
|
msgid "BUTTON_WHEEL_UP"
|
||||||
msgstr "Molette souris vers avant"
|
msgstr "Molette souris vers avant"
|
||||||
|
|
||||||
|
@ -225,13 +234,59 @@ msgid "BUTTON_WHEEL_DOWN"
|
||||||
msgstr "Molette souris vers arrière"
|
msgstr "Molette souris vers arrière"
|
||||||
|
|
||||||
msgid "INPUT_VIEW_CAMERA_MOVE_PLAYER_FOLLOW"
|
msgid "INPUT_VIEW_CAMERA_MOVE_PLAYER_FOLLOW"
|
||||||
msgstr "Déplacer la caméra et le joueur suit"
|
msgstr "Rotation de la caméra et le joueur suit"
|
||||||
|
|
||||||
msgid "INPUT_VIEW_CAMERA_MOVE_ONLY"
|
msgid "INPUT_VIEW_CAMERA_MOVE_ONLY"
|
||||||
msgstr "Déplacer la caméra seulement"
|
msgstr "Rotation de la caméra seulement"
|
||||||
|
|
||||||
|
msgid "INPUT_VIEW_CAMERA_PLAYER_WALK"
|
||||||
|
msgstr "Rotation de la caméra et déplacer le joueur dans la direction"
|
||||||
|
|
||||||
msgid "INPUT_ACTION_JUMP"
|
msgid "INPUT_ACTION_JUMP"
|
||||||
msgstr "Sauter"
|
msgstr "Sauter"
|
||||||
|
|
||||||
msgid "POPUP_ABOUT_MESSAGE/TITLE"
|
msgid "POPUP_ABOUT_MESSAGE/TITLE"
|
||||||
msgstr "A propos"
|
msgstr "A propos"
|
||||||
|
|
||||||
|
msgid "HUD/MUSIC"
|
||||||
|
msgstr "Son"
|
||||||
|
|
||||||
|
msgid "MUSIC_MANAGER/TITLE"
|
||||||
|
msgstr "Configuration Musique/Son"
|
||||||
|
|
||||||
|
msgid "Music"
|
||||||
|
msgstr "Musique"
|
||||||
|
|
||||||
|
msgid "Mixer"
|
||||||
|
msgstr "Volume"
|
||||||
|
|
||||||
|
msgid "MUSIC_MANAGER/PLAY"
|
||||||
|
msgstr "Jouer"
|
||||||
|
|
||||||
|
msgid "MUSIC_MANAGER/RANDOM"
|
||||||
|
msgstr "Mélanger"
|
||||||
|
|
||||||
|
msgid "MUSIC_MANAGER/REINIT"
|
||||||
|
msgstr "Réinitialiser"
|
||||||
|
|
||||||
|
msgid "MUSIC_MANAGER/MUTE"
|
||||||
|
msgstr "Silence"
|
||||||
|
|
||||||
|
msgid "MUSIC_MANAGER/GLOBAL_VOLUME"
|
||||||
|
msgstr "Niveau sonore global"
|
||||||
|
|
||||||
|
msgid "MUSIC_MANAGER/MUSIC_VOLUME"
|
||||||
|
msgstr "Niveau sonore de la musique"
|
||||||
|
|
||||||
|
msgid "MUSIC_MANAGER/EFFECT_VOLUME"
|
||||||
|
msgstr "Niveau sonore des effets"
|
||||||
|
|
||||||
|
msgid "EDIT_CONTROL/MOVE_CAMERA_REVERSE_HORIZONTAL"
|
||||||
|
msgstr "Inversé horizontale"
|
||||||
|
|
||||||
|
msgid "EDIT_CONTROL/MOVE_CAMERA_REVERSE_VERTICAL"
|
||||||
|
msgstr "Inversé verticale"
|
||||||
|
|
||||||
|
msgid "NO_MOUSE_BUTTON"
|
||||||
|
msgstr "Rien n'est sélectionné"
|
||||||
|
|
||||||
|
|
Binary file not shown.
|
@ -206,9 +206,18 @@ msgstr ""
|
||||||
msgid "BUTTON_RIGHT"
|
msgid "BUTTON_RIGHT"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
|
msgid "BUTTON_MIDDLE"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
msgid "BUTTON_LEFT"
|
msgid "BUTTON_LEFT"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
|
msgid "BUTTON_XBUTTON1"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
msgid "BUTTON_XBUTTON2"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
msgid "BUTTON_WHEEL_UP"
|
msgid "BUTTON_WHEEL_UP"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
|
@ -221,8 +230,57 @@ msgstr ""
|
||||||
msgid "INPUT_VIEW_CAMERA_MOVE_ONLY"
|
msgid "INPUT_VIEW_CAMERA_MOVE_ONLY"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
|
msgid "INPUT_VIEW_CAMERA_PLAYER_WALK"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
msgid "INPUT_ACTION_JUMP"
|
msgid "INPUT_ACTION_JUMP"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
msgid "POPUP_ABOUT_MESSAGE/TITLE"
|
msgid "POPUP_ABOUT_MESSAGE/TITLE"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
|
msgid "HUD/MUSIC"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
msgid "MUSIC_MANAGER/TITLE"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
msgid "Music"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
msgid "Mixer"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
msgid "MUSIC_MANAGER/PLAY"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
msgid "MUSIC_MANAGER/RANDOM"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
msgid "MUSIC_MANAGER/REINIT"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
msgid "MUSIC_MANAGER/MUTE"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
msgid "MUSIC_MANAGER/GLOBAL_VOLUME"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
msgid "MUSIC_MANAGER/MUSIC_VOLUME"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
msgid "MUSIC_MANAGER/EFFECT_VOLUME"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
|
||||||
|
msgid "EDIT_CONTROL/MOVE_CAMERA_REVERSE_HORIZONTAL"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
msgid "EDIT_CONTROL/MOVE_CAMERA_REVERSE_VERTICAL"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
msgid "NO_MOUSE_BUTTON"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
|
@ -25,9 +25,6 @@ anchor_right = 1.0
|
||||||
anchor_bottom = 1.0
|
anchor_bottom = 1.0
|
||||||
grow_horizontal = 2
|
grow_horizontal = 2
|
||||||
grow_vertical = 2
|
grow_vertical = 2
|
||||||
__meta__ = {
|
|
||||||
"_edit_use_custom_anchors": false
|
|
||||||
}
|
|
||||||
|
|
||||||
[node name="Label" type="Label" parent="panel2/Node3D/SubViewport/VBoxContainer" index="0"]
|
[node name="Label" type="Label" parent="panel2/Node3D/SubViewport/VBoxContainer" index="0"]
|
||||||
offset_right = 1024.0
|
offset_right = 1024.0
|
||||||
|
@ -39,9 +36,6 @@ theme_override_colors/font_shadow_color = Color(0.933333, 0, 0, 1)
|
||||||
text = "Ceci est un texte"
|
text = "Ceci est un texte"
|
||||||
horizontal_alignment = 1
|
horizontal_alignment = 1
|
||||||
vertical_alignment = 1
|
vertical_alignment = 1
|
||||||
__meta__ = {
|
|
||||||
"_edit_use_custom_anchors": false
|
|
||||||
}
|
|
||||||
|
|
||||||
[node name="Button" type="Button" parent="panel2/Node3D/SubViewport/VBoxContainer" index="1"]
|
[node name="Button" type="Button" parent="panel2/Node3D/SubViewport/VBoxContainer" index="1"]
|
||||||
offset_top = 30.0
|
offset_top = 30.0
|
||||||
|
|
|
@ -240,11 +240,29 @@ INPUT_VIEW_CAMERA_MOVE_PLAYER_FOLLOW={
|
||||||
"events": [Object(InputEventMouseButton,"resource_local_to_scene":false,"resource_name":"","device":0,"window_id":0,"store_command":true,"alt_pressed":false,"shift_pressed":false,"meta_pressed":false,"command_pressed":false,"button_mask":2,"position":Vector2(217, 135),"global_position":Vector2(217, 135),"factor":1.0,"button_index":2,"pressed":true,"double_click":false,"script":null)
|
"events": [Object(InputEventMouseButton,"resource_local_to_scene":false,"resource_name":"","device":0,"window_id":0,"store_command":true,"alt_pressed":false,"shift_pressed":false,"meta_pressed":false,"command_pressed":false,"button_mask":2,"position":Vector2(217, 135),"global_position":Vector2(217, 135),"factor":1.0,"button_index":2,"pressed":true,"double_click":false,"script":null)
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
INPUT_VIEW_CAMERA_MOVE_PLAYER_FOLLOW_PLUS={
|
||||||
|
"deadzone": 0.5,
|
||||||
|
"events": []
|
||||||
|
}
|
||||||
INPUT_VIEW_CAMERA_MOVE_ONLY={
|
INPUT_VIEW_CAMERA_MOVE_ONLY={
|
||||||
"deadzone": 0.5,
|
"deadzone": 0.5,
|
||||||
"events": [Object(InputEventMouseButton,"resource_local_to_scene":false,"resource_name":"","device":0,"window_id":0,"store_command":true,"alt_pressed":false,"shift_pressed":false,"meta_pressed":false,"command_pressed":false,"button_mask":0,"position":Vector2(0, 0),"global_position":Vector2(0, 0),"factor":1.0,"button_index":1,"pressed":false,"double_click":false,"script":null)
|
"events": [Object(InputEventMouseButton,"resource_local_to_scene":false,"resource_name":"","device":0,"window_id":0,"store_command":true,"alt_pressed":false,"shift_pressed":false,"meta_pressed":false,"command_pressed":false,"button_mask":0,"position":Vector2(0, 0),"global_position":Vector2(0, 0),"factor":1.0,"button_index":1,"pressed":false,"double_click":false,"script":null)
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
INPUT_VIEW_CAMERA_MOVE_ONLY_PLUS={
|
||||||
|
"deadzone": 0.5,
|
||||||
|
"events": []
|
||||||
|
}
|
||||||
|
INPUT_VIEW_CAMERA_PLAYER_WALK={
|
||||||
|
"deadzone": 0.5,
|
||||||
|
"events": [Object(InputEventMouseButton,"resource_local_to_scene":false,"resource_name":"","device":0,"window_id":0,"store_command":true,"alt_pressed":false,"shift_pressed":false,"meta_pressed":false,"command_pressed":false,"button_mask":0,"position":Vector2(0, 0),"global_position":Vector2(0, 0),"factor":1.0,"button_index":1,"pressed":false,"double_click":false,"script":null)
|
||||||
|
]
|
||||||
|
}
|
||||||
|
INPUT_VIEW_CAMERA_PLAYER_WALK_PLUS={
|
||||||
|
"deadzone": 0.5,
|
||||||
|
"events": [Object(InputEventMouseButton,"resource_local_to_scene":false,"resource_name":"","device":0,"window_id":0,"store_command":true,"alt_pressed":false,"shift_pressed":false,"meta_pressed":false,"command_pressed":false,"button_mask":2,"position":Vector2(217, 135),"global_position":Vector2(217, 135),"factor":1.0,"button_index":2,"pressed":true,"double_click":false,"script":null)
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
[internationalization]
|
[internationalization]
|
||||||
|
|
||||||
|
|
|
@ -11,7 +11,9 @@ func _init():
|
||||||
|
|
||||||
func _ready():
|
func _ready():
|
||||||
$SelectType.connect("refresh_select_type_control", refresh.bind() )
|
$SelectType.connect("refresh_select_type_control", refresh.bind() )
|
||||||
|
$SelectType.connect("cancel_define_input", show_windows.bind() )
|
||||||
|
$DefineInput.connect("refresh_control_define_input", define_mouse_camera_move.bind() )
|
||||||
|
$DefineInput.connect("cancel_define_input", show_windows.bind())
|
||||||
|
|
||||||
func refresh():
|
func refresh():
|
||||||
configure_control()
|
configure_control()
|
||||||
|
@ -131,35 +133,71 @@ func load_current_control():
|
||||||
return conf
|
return conf
|
||||||
|
|
||||||
|
|
||||||
|
func update_mouse_button_move_camera():
|
||||||
|
# Update SelectButton - INPUT_VIEW_CAMERA_MOVE_PLAYER_FOLLOW
|
||||||
|
var MouseCameraMove:String = ""
|
||||||
|
var comment:String = "None"
|
||||||
|
#var text1:String = ""
|
||||||
|
$Window/Tab/MOUSE/CameraPlayer/SelectButton.set_text(Common.get_input_plus("INPUT_VIEW_CAMERA_MOVE_PLAYER_FOLLOW"))
|
||||||
|
$Window/Tab/MOUSE/CameraOnly/SelectButton.set_text(Common.get_input_plus("INPUT_VIEW_CAMERA_MOVE_ONLY"))
|
||||||
|
$Window/Tab/MOUSE/CameraPlayerWalk/SelectButton.set_text(Common.get_input_plus("INPUT_VIEW_CAMERA_PLAYER_WALK"))
|
||||||
|
# if InputMap.has_action("INPUT_VIEW_CAMERA_MOVE_PLAYER_FOLLOW"):
|
||||||
|
# for z in InputMap.action_get_events("INPUT_VIEW_CAMERA_MOVE_PLAYER_FOLLOW"):
|
||||||
|
# if z is InputEventMouseButton:
|
||||||
|
# comment = tr(Common.get_string_input(z))
|
||||||
|
# Common.msg_debug(comment)
|
||||||
|
# #$Window/Tab/MOUSE/HBox/SelectButton.set_text(text1)
|
||||||
|
# break
|
||||||
|
# if InputMap.has_action("INPUT_VIEW_CAMERA_MOVE_PLAYER_FOLLOW_PLUS"):
|
||||||
|
# for z in InputMap.action_get_events("INPUT_VIEW_CAMERA_MOVE_PLAYER_FOLLOW_PLUS"):
|
||||||
|
# if z is InputEventMouseButton:
|
||||||
|
# comment = comment + " & " + tr(Common.get_string_input(z))
|
||||||
|
# Common.msg_debug(comment)
|
||||||
|
# break
|
||||||
|
# $Window/Tab/MOUSE/HBox/SelectButton.set_text(comment)
|
||||||
|
# for action in InputMap.get_actions():
|
||||||
|
# var text:String = action
|
||||||
|
# if text.find("INPUT_VIEW_CAMERA_MOVE_PLAYER_FOLLOW") == 0:
|
||||||
|
# for z in InputMap.action_get_events(action):
|
||||||
|
# if z is InputEventMouseButton:
|
||||||
|
# var text2:String = Common.get_string_input(z)
|
||||||
|
# Common.msg_debug(text2)
|
||||||
|
# $Window/Tab/MOUSE/HBox/SelectButton.set_text(text2)
|
||||||
|
# return
|
||||||
|
|
||||||
|
|
||||||
func configure_control():
|
func configure_control():
|
||||||
if $Window/VBox/Menu/ShowMethod.get_selected() == 0:
|
if $Window/Tab/CONTROL/Menu/ShowMethod.get_selected() == 0:
|
||||||
$Window/VBox/Input.visible = false
|
$Window/Tab/CONTROL/Input.visible = false
|
||||||
$Window/VBox/Tree.visible = true
|
$Window/Tab/CONTROL/Tree.visible = true
|
||||||
configure_control_by_group()
|
configure_control_by_group()
|
||||||
elif $Window/VBox/Menu/ShowMethod.get_selected() == 1:
|
elif $Window/Tab/CONTROL/Menu/ShowMethod.get_selected() == 1:
|
||||||
$Window/VBox/Tree.visible = false
|
$Window/Tab/CONTROL/Tree.visible = false
|
||||||
$Window/VBox/Input.visible = true
|
$Window/Tab/CONTROL/Input.visible = true
|
||||||
configure_control_sort_by_categories()
|
configure_control_sort_by_categories()
|
||||||
else:
|
else:
|
||||||
$Window/VBox/Tree.visible = false
|
$Window/Tab/CONTROL/Tree.visible = false
|
||||||
$Window/VBox/Input.visible = true
|
$Window/Tab/CONTROL/Input.visible = true
|
||||||
configure_control_sort_by_input()
|
configure_control_sort_by_input()
|
||||||
|
update_mouse_button_move_camera()
|
||||||
|
|
||||||
|
|
||||||
func configure_control_by_group():
|
func configure_control_by_group():
|
||||||
$Window/VBox/Tree.clear()
|
$Window/Tab/CONTROL/Tree.clear()
|
||||||
var root = $Window/VBox/Tree.create_item()
|
var root = $Window/Tab/CONTROL/Tree.create_item()
|
||||||
$Window/VBox/Tree.hide_root = true
|
$Window/Tab/CONTROL/Tree.hide_root = true
|
||||||
var child_action = $Window/VBox/Tree.create_item(root)
|
var child_action = $Window/Tab/CONTROL/Tree.create_item(root)
|
||||||
child_action.set_text(0, tr("CONTROL_INPUT_ACTION"))
|
child_action.set_text(0, tr("CONTROL_INPUT_ACTION"))
|
||||||
var child_view = $Window/VBox/Tree.create_item(root)
|
var child_view = $Window/Tab/CONTROL/Tree.create_item(root)
|
||||||
child_view.set_text(0, tr("CONTROL_INPUT_VIEW"))
|
child_view.set_text(0, tr("CONTROL_INPUT_VIEW"))
|
||||||
var child_other = $Window/VBox/Tree.create_item(root)
|
var child_other = $Window/Tab/CONTROL/Tree.create_item(root)
|
||||||
child_other.set_text(0, tr("CONTROL_INPUT_OTHER"))
|
child_other.set_text(0, tr("CONTROL_INPUT_OTHER"))
|
||||||
for action in InputMap.get_actions():
|
for action in InputMap.get_actions():
|
||||||
var text:String = action
|
var text:String = action
|
||||||
if text.find("INPUT_ACTION") == 0:
|
if text.ends_with("_PLUS"):
|
||||||
var subchild:TreeItem = $Window/VBox/Tree.create_item(child_action)
|
pass
|
||||||
|
elif text.find("INPUT_ACTION") == 0:
|
||||||
|
var subchild:TreeItem = $Window/Tab/CONTROL/Tree.create_item(child_action)
|
||||||
subchild.set_text(0, tr(text))
|
subchild.set_text(0, tr(text))
|
||||||
var buttontxt : Texture2D = preload("res://scenes/controls/add.png")
|
var buttontxt : Texture2D = preload("res://scenes/controls/add.png")
|
||||||
subchild.add_button(0, buttontxt, 0, false, "CONTROL_ADD_INPUT")
|
subchild.add_button(0, buttontxt, 0, false, "CONTROL_ADD_INPUT")
|
||||||
|
@ -167,8 +205,8 @@ func configure_control_by_group():
|
||||||
subchild.set_meta("group", action)
|
subchild.set_meta("group", action)
|
||||||
var a = InputMap.action_get_events(action)
|
var a = InputMap.action_get_events(action)
|
||||||
for z in a:
|
for z in a:
|
||||||
var text2:String = Common.get_string_input(z)
|
var text2:String = tr(Common.get_string_input(z)) + Common.get_input_plus_event(action ,z)
|
||||||
var subchild2:TreeItem = $Window/VBox/Tree.create_item(subchild)
|
var subchild2:TreeItem = $Window/Tab/CONTROL/Tree.create_item(subchild)
|
||||||
subchild2.set_text(0, tr(text2))
|
subchild2.set_text(0, tr(text2))
|
||||||
var button2txt : Texture2D = preload("res://scenes/controls/trash.png")
|
var button2txt : Texture2D = preload("res://scenes/controls/trash.png")
|
||||||
subchild2.add_button(0, button2txt, 0, false, "CONTROL_DEL_INPUT")
|
subchild2.add_button(0, button2txt, 0, false, "CONTROL_DEL_INPUT")
|
||||||
|
@ -176,7 +214,7 @@ func configure_control_by_group():
|
||||||
subchild2.set_meta("group", action)
|
subchild2.set_meta("group", action)
|
||||||
subchild2.set_meta("control", z)
|
subchild2.set_meta("control", z)
|
||||||
elif text.find("INPUT_VIEW") == 0:
|
elif text.find("INPUT_VIEW") == 0:
|
||||||
var subchild:TreeItem = $Window/VBox/Tree.create_item(child_view)
|
var subchild:TreeItem = $Window/Tab/CONTROL/Tree.create_item(child_view)
|
||||||
subchild.set_text(0, tr(text))
|
subchild.set_text(0, tr(text))
|
||||||
var buttontxt : Texture2D = preload("res://scenes/controls/add.png")
|
var buttontxt : Texture2D = preload("res://scenes/controls/add.png")
|
||||||
subchild.add_button(0, buttontxt, 0, false, "CONTROL_ADD_INPUT")
|
subchild.add_button(0, buttontxt, 0, false, "CONTROL_ADD_INPUT")
|
||||||
|
@ -184,8 +222,8 @@ func configure_control_by_group():
|
||||||
subchild.set_meta("group", action)
|
subchild.set_meta("group", action)
|
||||||
var a = InputMap.action_get_events(action)
|
var a = InputMap.action_get_events(action)
|
||||||
for z in a:
|
for z in a:
|
||||||
var text2:String = Common.get_string_input(z)
|
var text2:String = tr(Common.get_string_input(z)) + Common.get_input_plus_event(action ,z)
|
||||||
var subchild2:TreeItem = $Window/VBox/Tree.create_item(subchild)
|
var subchild2:TreeItem = $Window/Tab/CONTROL/Tree.create_item(subchild)
|
||||||
subchild2.set_text(0, tr(text2))
|
subchild2.set_text(0, tr(text2))
|
||||||
var button2txt : Texture2D = preload("res://scenes/controls/trash.png")
|
var button2txt : Texture2D = preload("res://scenes/controls/trash.png")
|
||||||
subchild2.add_button(0, button2txt, 0, false, "CONTROL_DEL_INPUT")
|
subchild2.add_button(0, button2txt, 0, false, "CONTROL_DEL_INPUT")
|
||||||
|
@ -193,7 +231,7 @@ func configure_control_by_group():
|
||||||
subchild2.set_meta("group", action)
|
subchild2.set_meta("group", action)
|
||||||
subchild2.set_meta("control", z)
|
subchild2.set_meta("control", z)
|
||||||
else:
|
else:
|
||||||
var subchild:TreeItem = $Window/VBox/Tree.create_item(child_other)
|
var subchild:TreeItem = $Window/Tab/CONTROL/Tree.create_item(child_other)
|
||||||
subchild.set_text(0, tr(text))
|
subchild.set_text(0, tr(text))
|
||||||
var buttontxt : Texture2D = preload("res://scenes/controls/add.png")
|
var buttontxt : Texture2D = preload("res://scenes/controls/add.png")
|
||||||
subchild.add_button(0, buttontxt, 0, false, "CONTROL_ADD_INPUT")
|
subchild.add_button(0, buttontxt, 0, false, "CONTROL_ADD_INPUT")
|
||||||
|
@ -201,8 +239,8 @@ func configure_control_by_group():
|
||||||
subchild.set_meta("group", action)
|
subchild.set_meta("group", action)
|
||||||
var a = InputMap.action_get_events(action)
|
var a = InputMap.action_get_events(action)
|
||||||
for z in a:
|
for z in a:
|
||||||
var text2:String = Common.get_string_input(z)
|
var text2:String = tr(Common.get_string_input(z)) + Common.get_input_plus_event(action ,z)
|
||||||
var subchild2:TreeItem = $Window/VBox/Tree.create_item(subchild)
|
var subchild2:TreeItem = $Window/Tab/CONTROL/Tree.create_item(subchild)
|
||||||
subchild2.set_text(0, tr(text2))
|
subchild2.set_text(0, tr(text2))
|
||||||
var button2txt : Texture2D = preload("res://scenes/controls/trash.png")
|
var button2txt : Texture2D = preload("res://scenes/controls/trash.png")
|
||||||
subchild2.add_button(0, button2txt, 0, false, "CONTROL_DEL_INPUT")
|
subchild2.add_button(0, button2txt, 0, false, "CONTROL_DEL_INPUT")
|
||||||
|
@ -216,7 +254,7 @@ func __button_pressed():
|
||||||
|
|
||||||
|
|
||||||
func configure_control_sort_by_input():
|
func configure_control_sort_by_input():
|
||||||
for child in $Window/VBox/Input/Control.get_children():
|
for child in $Window/Tab/CONTROL/Input/Control.get_children():
|
||||||
child.queue_free()
|
child.queue_free()
|
||||||
var def = {}
|
var def = {}
|
||||||
for action in InputMap.get_actions():
|
for action in InputMap.get_actions():
|
||||||
|
@ -232,59 +270,59 @@ func configure_control_sort_by_input():
|
||||||
var zhash = get_dict_inputevent(z).hash()
|
var zhash = get_dict_inputevent(z).hash()
|
||||||
if zhash != lastevent:
|
if zhash != lastevent:
|
||||||
var separator = HSeparator.new()
|
var separator = HSeparator.new()
|
||||||
$Window/VBox/Input/Control.add_child( separator )
|
$Window/Tab/CONTROL/Input/Control.add_child( separator )
|
||||||
lastevent = zhash
|
lastevent = zhash
|
||||||
if z is InputEventKey:
|
if z is InputEventKey:
|
||||||
var item = preload( "res://scenes/controls/control_input.tscn" ).instantiate() #.instance()
|
var item = preload( "res://scenes/controls/control_input.tscn" ).instantiate() #.instance()
|
||||||
item.set_param(action, "Key: " + Common.get_string_input_keyboard(z), action, z)
|
item.set_param(action, "Key: " + Common.get_string_input_keyboard(z), action, z)
|
||||||
item.connect( "del_pressed", _on_input_box_del_pressed.bind() )
|
item.connect( "del_pressed", _on_input_box_del_pressed.bind() )
|
||||||
$Window/VBox/Input/Control.add_child( item )
|
$Window/Tab/CONTROL/Input/Control.add_child( item )
|
||||||
elif z is InputEventMouseButton:
|
elif z is InputEventMouseButton:
|
||||||
var item = preload( "res://scenes/controls/control_input.tscn" ).instantiate()
|
var item = preload( "res://scenes/controls/control_input.tscn" ).instantiate()
|
||||||
item.set_param(action, "Mouse Button: " + Common.get_string_input_mousse_button(z), action, z)
|
item.set_param(action, "Mouse Button: " + Common.get_string_input_mousse_button(z), action, z)
|
||||||
item.connect( "del_pressed", _on_input_box_del_pressed.bind() )
|
item.connect( "del_pressed", _on_input_box_del_pressed.bind() )
|
||||||
$Window/VBox/Input/Control.add_child( item )
|
$Window/Tab/CONTROL/Input/Control.add_child( item )
|
||||||
elif z is InputEventJoypadButton:
|
elif z is InputEventJoypadButton:
|
||||||
var item = preload( "res://scenes/controls/control_input.tscn" ).instantiate()
|
var item = preload( "res://scenes/controls/control_input.tscn" ).instantiate()
|
||||||
item.set_param(action, "Joypad Button: " + Common.get_string_input_joypad_button(z), action, z)
|
item.set_param(action, "Joypad Button: " + Common.get_string_input_joypad_button(z), action, z)
|
||||||
item.connect( "del_pressed", _on_input_box_del_pressed.bind() )
|
item.connect( "del_pressed", _on_input_box_del_pressed.bind() )
|
||||||
$Window/VBox/Input/Control.add_child( item )
|
$Window/Tab/CONTROL/Input/Control.add_child( item )
|
||||||
for action in InputMap.get_actions():
|
for action in InputMap.get_actions():
|
||||||
var separator = HSeparator.new()
|
var separator = HSeparator.new()
|
||||||
$Window/VBox/Input/Control.add_child( separator )
|
$Window/Tab/CONTROL/Input/Control.add_child( separator )
|
||||||
var control_box = preload( "res://scenes/controls/control_function.tscn" ).instantiate()
|
var control_box = preload( "res://scenes/controls/control_function.tscn" ).instantiate()
|
||||||
control_box.set_param(action, action, true)
|
control_box.set_param(action, action, true)
|
||||||
control_box.connect( "add_pressed", _on_control_box_add_pressed.bind() )
|
control_box.connect( "add_pressed", _on_control_box_add_pressed.bind() )
|
||||||
$Window/VBox/Input/Control.add_child( control_box )
|
$Window/Tab/CONTROL/Input/Control.add_child( control_box )
|
||||||
|
|
||||||
|
|
||||||
func configure_control_sort_by_categories():
|
func configure_control_sort_by_categories():
|
||||||
for child in $Window/VBox/Input/Control.get_children():
|
for child in $Window/Tab/CONTROL/Input/Control.get_children():
|
||||||
child.queue_free()
|
child.queue_free()
|
||||||
for action in InputMap.get_actions():
|
for action in InputMap.get_actions():
|
||||||
var control_box = preload( "res://scenes/controls/control_function.tscn" ).instantiate()
|
var control_box = preload( "res://scenes/controls/control_function.tscn" ).instantiate()
|
||||||
control_box.set_param(action, action, false)
|
control_box.set_param(action, action, false)
|
||||||
control_box.connect( "add_pressed", _on_control_box_add_pressed.bind() )
|
control_box.connect( "add_pressed", _on_control_box_add_pressed.bind() )
|
||||||
$Window/VBox/Input/Control.add_child( control_box )
|
$Window/Tab/CONTROL/Input/Control.add_child( control_box )
|
||||||
var a = InputMap.action_get_events(action)
|
var a = InputMap.action_get_events(action)
|
||||||
for z in a:
|
for z in a:
|
||||||
if z is InputEventKey:
|
if z is InputEventKey:
|
||||||
var item = preload( "res://scenes/controls/control_input.tscn" ).instantiate()
|
var item = preload( "res://scenes/controls/control_input.tscn" ).instantiate()
|
||||||
item.set_param(action, "Key: " + Common.get_string_input_keyboard(z), "", z)
|
item.set_param(action, "Key: " + Common.get_string_input_keyboard(z), "", z)
|
||||||
item.connect( "del_pressed", _on_input_box_del_pressed.bind() )
|
item.connect( "del_pressed", _on_input_box_del_pressed.bind() )
|
||||||
$Window/VBox/Input/Control.add_child( item )
|
$Window/Tab/CONTROL/Input/Control.add_child( item )
|
||||||
elif z is InputEventMouseButton:
|
elif z is InputEventMouseButton:
|
||||||
var item = preload( "res://scenes/controls/control_input.tscn" ).instantiate()
|
var item = preload( "res://scenes/controls/control_input.tscn" ).instantiate()
|
||||||
item.set_param(action, "Mouse Button: " + Common.get_string_input_mousse_button(z), "", z)
|
item.set_param(action, "Mouse Button: " + Common.get_string_input_mousse_button(z), "", z)
|
||||||
item.connect( "del_pressed", _on_input_box_del_pressed.bind() )
|
item.connect( "del_pressed", _on_input_box_del_pressed.bind() )
|
||||||
$Window/VBox/Input/Control.add_child( item )
|
$Window/Tab/CONTROL/Input/Control.add_child( item )
|
||||||
elif z is InputEventJoypadButton:
|
elif z is InputEventJoypadButton:
|
||||||
var item = preload( "res://scenes/controls/control_input.tscn" ).instantiate()
|
var item = preload( "res://scenes/controls/control_input.tscn" ).instantiate()
|
||||||
item.set_param(action, "Joypad Button: " + Common.get_string_input_joypad_button(z), "", z)
|
item.set_param(action, "Joypad Button: " + Common.get_string_input_joypad_button(z), "", z)
|
||||||
item.connect( "del_pressed", _on_input_box_del_pressed.bind() )
|
item.connect( "del_pressed", _on_input_box_del_pressed.bind() )
|
||||||
$Window/VBox/Input/Control.add_child( item )
|
$Window/Tab/CONTROL/Input/Control.add_child( item )
|
||||||
var separator = HSeparator.new()
|
var separator = HSeparator.new()
|
||||||
$Window/VBox/Input/Control.add_child( separator )
|
$Window/Tab/CONTROL/Input/Control.add_child( separator )
|
||||||
|
|
||||||
|
|
||||||
func load_control_system():
|
func load_control_system():
|
||||||
|
@ -305,12 +343,12 @@ func _on_input_box_del_pressed(command, control, inputevent):
|
||||||
|
|
||||||
|
|
||||||
func _on_control_box_add_pressed(action, command):
|
func _on_control_box_add_pressed(action, command):
|
||||||
|
$Window.hide()
|
||||||
$SelectType.set_param(action, "signal_refresh" )
|
$SelectType.set_param(action, "signal_refresh" )
|
||||||
$SelectType/Window.popup_centered()
|
$SelectType/Window.popup_centered()
|
||||||
$SelectType/Window.visible = true
|
$SelectType/Window.visible = true
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
func _on_option_button_item_selected(index):
|
func _on_option_button_item_selected(index):
|
||||||
configure_control()
|
configure_control()
|
||||||
|
|
||||||
|
@ -319,6 +357,7 @@ func _on_tree_button_pressed(item:TreeItem, column, id):
|
||||||
if item.has_meta("action") and item.has_meta("group"):
|
if item.has_meta("action") and item.has_meta("group"):
|
||||||
var action = item.get_meta("group")
|
var action = item.get_meta("group")
|
||||||
if item.get_meta("action") == 0:
|
if item.get_meta("action") == 0:
|
||||||
|
$Window.hide()
|
||||||
$SelectType.set_param(action, "signal_refresh" )
|
$SelectType.set_param(action, "signal_refresh" )
|
||||||
$SelectType/Window.popup_centered()
|
$SelectType/Window.popup_centered()
|
||||||
$SelectType/Window.visible = true
|
$SelectType/Window.visible = true
|
||||||
|
@ -326,3 +365,33 @@ func _on_tree_button_pressed(item:TreeItem, column, id):
|
||||||
var control = item.get_meta("control")
|
var control = item.get_meta("control")
|
||||||
InputMap.action_erase_event(action, control)
|
InputMap.action_erase_event(action, control)
|
||||||
configure_control()
|
configure_control()
|
||||||
|
|
||||||
|
|
||||||
|
func show_windows():
|
||||||
|
$Window.visible = true
|
||||||
|
|
||||||
|
|
||||||
|
func define_mouse_camera_move():
|
||||||
|
configure_control()
|
||||||
|
show_windows()
|
||||||
|
|
||||||
|
|
||||||
|
func _on_select_button_pressed():
|
||||||
|
$Window.visible = false
|
||||||
|
$DefineInput.set_param(2, "INPUT_VIEW_CAMERA_MOVE_PLAYER_FOLLOW")
|
||||||
|
$DefineInput/Window.popup_centered()
|
||||||
|
$DefineInput/Window.visible = true
|
||||||
|
|
||||||
|
|
||||||
|
func _on_camear_only_button_pressed():
|
||||||
|
$Window.visible = false
|
||||||
|
$DefineInput.set_param(2, "INPUT_VIEW_CAMERA_MOVE_ONLY")
|
||||||
|
$DefineInput/Window.popup_centered()
|
||||||
|
$DefineInput/Window.visible = true
|
||||||
|
|
||||||
|
|
||||||
|
func _on_camera_player_walk_button_pressed():
|
||||||
|
$Window.visible = false
|
||||||
|
$DefineInput.set_param(2, "INPUT_VIEW_CAMERA_PLAYER_WALK")
|
||||||
|
$DefineInput/Window.popup_centered()
|
||||||
|
$DefineInput/Window.visible = true
|
||||||
|
|
|
@ -1,16 +1,14 @@
|
||||||
[gd_scene load_steps=3 format=3 uid="uid://cl8xk8w3jmta0"]
|
[gd_scene load_steps=4 format=3 uid="uid://cl8xk8w3jmta0"]
|
||||||
|
|
||||||
[ext_resource type="Script" path="res://scenes/controls/controls.gd" id="1_2c8s6"]
|
[ext_resource type="Script" path="res://scenes/controls/controls.gd" id="1_2c8s6"]
|
||||||
[ext_resource type="PackedScene" uid="uid://bhidap7eniou8" path="res://scenes/controls/select_type_control.tscn" id="2_ps0mu"]
|
[ext_resource type="PackedScene" uid="uid://bhidap7eniou8" path="res://scenes/controls/select_type_control.tscn" id="2_ps0mu"]
|
||||||
|
[ext_resource type="PackedScene" uid="uid://cvmel2sx7qfvy" path="res://scenes/controls/option_define_input.tscn" id="3_dxrwd"]
|
||||||
|
|
||||||
[node name="Control" type="Control"]
|
[node name="Control" type="Control"]
|
||||||
visible = false
|
visible = false
|
||||||
anchor_right = 1.0
|
anchor_right = 1.0
|
||||||
anchor_bottom = 1.0
|
anchor_bottom = 1.0
|
||||||
script = ExtResource( "1_2c8s6" )
|
script = ExtResource( "1_2c8s6" )
|
||||||
__meta__ = {
|
|
||||||
"_edit_use_anchors_": false
|
|
||||||
}
|
|
||||||
|
|
||||||
[node name="Window" type="Window" parent="."]
|
[node name="Window" type="Window" parent="."]
|
||||||
title = "EDIT_CONTROL/TITLE"
|
title = "EDIT_CONTROL/TITLE"
|
||||||
|
@ -20,26 +18,32 @@ visible = false
|
||||||
content_scale_mode = 1
|
content_scale_mode = 1
|
||||||
content_scale_aspect = 4
|
content_scale_aspect = 4
|
||||||
|
|
||||||
[node name="VBox" type="VBoxContainer" parent="Window"]
|
[node name="Tab" type="TabContainer" parent="Window"]
|
||||||
anchor_right = 1.0
|
anchor_right = 1.0
|
||||||
anchor_bottom = 1.0
|
anchor_bottom = 1.0
|
||||||
grow_horizontal = 2
|
grow_horizontal = 2
|
||||||
grow_vertical = 2
|
grow_vertical = 2
|
||||||
|
size_flags_horizontal = 3
|
||||||
|
size_flags_vertical = 3
|
||||||
|
metadata/_edit_use_custom_anchors = false
|
||||||
|
|
||||||
|
[node name="CONTROL" type="VBoxContainer" parent="Window/Tab"]
|
||||||
|
anchor_right = 1.0
|
||||||
|
anchor_bottom = 1.0
|
||||||
|
offset_top = 31.0
|
||||||
|
grow_horizontal = 2
|
||||||
|
grow_vertical = 2
|
||||||
size_flags_horizontal = 6
|
size_flags_horizontal = 6
|
||||||
size_flags_vertical = 6
|
size_flags_vertical = 6
|
||||||
__meta__ = {
|
|
||||||
"_edit_use_custom_anchors": false
|
|
||||||
}
|
|
||||||
|
|
||||||
[node name="Menu" type="HBoxContainer" parent="Window/VBox"]
|
[node name="Menu" type="HBoxContainer" parent="Window/Tab/CONTROL"]
|
||||||
offset_right = 1024.0
|
offset_right = 1024.0
|
||||||
offset_bottom = 31.0
|
offset_bottom = 31.0
|
||||||
size_flags_horizontal = 3
|
size_flags_horizontal = 3
|
||||||
|
|
||||||
[node name="ShowMethod" type="OptionButton" parent="Window/VBox/Menu"]
|
[node name="ShowMethod" type="OptionButton" parent="Window/Tab/CONTROL/Menu"]
|
||||||
offset_right = 43.0
|
offset_right = 43.0
|
||||||
offset_bottom = 31.0
|
offset_bottom = 31.0
|
||||||
text = "CONTROL_VIEW_BY_GROUP"
|
|
||||||
item_count = 3
|
item_count = 3
|
||||||
selected = 0
|
selected = 0
|
||||||
popup/item_0/text = "CONTROL_VIEW_BY_GROUP"
|
popup/item_0/text = "CONTROL_VIEW_BY_GROUP"
|
||||||
|
@ -49,53 +53,162 @@ popup/item_1/id = 1
|
||||||
popup/item_2/text = "CONTROL_VIEW_BY_INPUT_SORTED"
|
popup/item_2/text = "CONTROL_VIEW_BY_INPUT_SORTED"
|
||||||
popup/item_2/id = 2
|
popup/item_2/id = 2
|
||||||
|
|
||||||
[node name="SortByInput" type="CheckBox" parent="Window/VBox/Menu"]
|
[node name="SortByInput" type="CheckBox" parent="Window/Tab/CONTROL/Menu"]
|
||||||
visible = false
|
visible = false
|
||||||
offset_right = 510.0
|
offset_right = 510.0
|
||||||
offset_bottom = 31.0
|
offset_bottom = 31.0
|
||||||
size_flags_horizontal = 7
|
size_flags_horizontal = 7
|
||||||
text = "EDIT_CONTROL/SORT_BY_INPUT"
|
text = "EDIT_CONTROL/SORT_BY_INPUT"
|
||||||
|
|
||||||
[node name="Reload" type="Button" parent="Window/VBox/Menu"]
|
[node name="Reload" type="Button" parent="Window/Tab/CONTROL/Menu"]
|
||||||
offset_left = 514.0
|
offset_left = 514.0
|
||||||
offset_right = 1024.0
|
offset_right = 1024.0
|
||||||
offset_bottom = 31.0
|
offset_bottom = 31.0
|
||||||
size_flags_horizontal = 7
|
size_flags_horizontal = 7
|
||||||
text = "EDIT_CONTROL/RELOAD_SYSTEM_CONFIG"
|
text = "EDIT_CONTROL/RELOAD_SYSTEM_CONFIG"
|
||||||
|
|
||||||
[node name="Input" type="ScrollContainer" parent="Window/VBox"]
|
[node name="Input" type="ScrollContainer" parent="Window/Tab/CONTROL"]
|
||||||
offset_top = 35.0
|
offset_top = 35.0
|
||||||
offset_right = 1024.0
|
offset_right = 1024.0
|
||||||
offset_bottom = 565.0
|
offset_bottom = 565.0
|
||||||
size_flags_horizontal = 3
|
size_flags_horizontal = 3
|
||||||
size_flags_vertical = 3
|
size_flags_vertical = 3
|
||||||
|
|
||||||
[node name="Control" type="VBoxContainer" parent="Window/VBox/Input"]
|
[node name="Control" type="VBoxContainer" parent="Window/Tab/CONTROL/Input"]
|
||||||
offset_right = 1024.0
|
offset_right = 1024.0
|
||||||
offset_bottom = 530.0
|
offset_bottom = 530.0
|
||||||
size_flags_horizontal = 3
|
size_flags_horizontal = 3
|
||||||
size_flags_vertical = 3
|
size_flags_vertical = 3
|
||||||
|
|
||||||
[node name="Tree" type="Tree" parent="Window/VBox"]
|
[node name="Tree" type="Tree" parent="Window/Tab/CONTROL"]
|
||||||
visible = false
|
visible = false
|
||||||
offset_right = 40.0
|
offset_right = 40.0
|
||||||
offset_bottom = 40.0
|
offset_bottom = 40.0
|
||||||
size_flags_vertical = 3
|
size_flags_vertical = 3
|
||||||
|
|
||||||
[node name="Quit" type="Button" parent="Window/VBox"]
|
[node name="Quit" type="Button" parent="Window/Tab/CONTROL"]
|
||||||
offset_left = 491.0
|
anchor_left = 0.5
|
||||||
offset_top = 569.0
|
anchor_top = 1.0
|
||||||
offset_right = 533.0
|
anchor_right = 0.5
|
||||||
offset_bottom = 600.0
|
anchor_bottom = 1.0
|
||||||
size_flags_horizontal = 6
|
offset_left = -85.5
|
||||||
|
offset_top = -31.0
|
||||||
|
offset_right = 85.5
|
||||||
|
grow_horizontal = 2
|
||||||
|
grow_vertical = 0
|
||||||
|
size_flags_horizontal = 4
|
||||||
size_flags_vertical = 8
|
size_flags_vertical = 8
|
||||||
text = "EDIT_CONTROL/QUIT"
|
text = "EDIT_CONTROL/QUIT"
|
||||||
|
metadata/_edit_use_custom_anchors = false
|
||||||
|
|
||||||
|
[node name="JOYPAD" type="VBoxContainer" parent="Window/Tab"]
|
||||||
|
visible = false
|
||||||
|
offset_right = 40.0
|
||||||
|
offset_bottom = 40.0
|
||||||
|
|
||||||
|
[node name="MOUSE" type="VBoxContainer" parent="Window/Tab"]
|
||||||
|
visible = false
|
||||||
|
offset_right = 40.0
|
||||||
|
offset_bottom = 40.0
|
||||||
|
|
||||||
|
[node name="CameraPlayer" type="HBoxContainer" parent="Window/Tab/MOUSE"]
|
||||||
|
offset_right = 1344.0
|
||||||
|
offset_bottom = 31.0
|
||||||
|
|
||||||
|
[node name="Label" type="Label" parent="Window/Tab/MOUSE/CameraPlayer"]
|
||||||
|
offset_right = 40.0
|
||||||
|
offset_bottom = 23.0
|
||||||
|
text = "INPUT_VIEW_CAMERA_MOVE_PLAYER_FOLLOW"
|
||||||
|
|
||||||
|
[node name="SelectButton" type="Button" parent="Window/Tab/MOUSE/CameraPlayer"]
|
||||||
|
offset_right = 8.0
|
||||||
|
offset_bottom = 31.0
|
||||||
|
text = "NOBUTTON"
|
||||||
|
|
||||||
|
[node name="ReverseHorizontal" type="CheckBox" parent="Window/Tab/MOUSE/CameraPlayer"]
|
||||||
|
offset_right = 24.0
|
||||||
|
offset_bottom = 31.0
|
||||||
|
text = "EDIT_CONTROL/MOVE_CAMERA_REVERSE_HORIZONTAL"
|
||||||
|
|
||||||
|
[node name="ReverseVertical" type="CheckBox" parent="Window/Tab/MOUSE/CameraPlayer"]
|
||||||
|
offset_right = 24.0
|
||||||
|
offset_bottom = 31.0
|
||||||
|
text = "EDIT_CONTROL/MOVE_CAMERA_REVERSE_VERTICAL"
|
||||||
|
|
||||||
|
[node name="CameraOnly" type="HBoxContainer" parent="Window/Tab/MOUSE"]
|
||||||
|
offset_right = 1257.0
|
||||||
|
offset_bottom = 31.0
|
||||||
|
|
||||||
|
[node name="Label" type="Label" parent="Window/Tab/MOUSE/CameraOnly"]
|
||||||
|
offset_right = 40.0
|
||||||
|
offset_bottom = 23.0
|
||||||
|
text = "INPUT_VIEW_CAMERA_MOVE_ONLY"
|
||||||
|
|
||||||
|
[node name="SelectButton" type="Button" parent="Window/Tab/MOUSE/CameraOnly"]
|
||||||
|
offset_right = 8.0
|
||||||
|
offset_bottom = 31.0
|
||||||
|
text = "NOBUTTON"
|
||||||
|
|
||||||
|
[node name="ReverseHorizontal" type="CheckBox" parent="Window/Tab/MOUSE/CameraOnly"]
|
||||||
|
offset_right = 24.0
|
||||||
|
offset_bottom = 31.0
|
||||||
|
text = "EDIT_CONTROL/MOVE_CAMERA_REVERSE_HORIZONTAL"
|
||||||
|
|
||||||
|
[node name="ReverseVertical" type="CheckBox" parent="Window/Tab/MOUSE/CameraOnly"]
|
||||||
|
offset_right = 24.0
|
||||||
|
offset_bottom = 31.0
|
||||||
|
text = "EDIT_CONTROL/MOVE_CAMERA_REVERSE_VERTICAL"
|
||||||
|
|
||||||
|
[node name="CameraPlayerWalk" type="HBoxContainer" parent="Window/Tab/MOUSE"]
|
||||||
|
offset_right = 1270.0
|
||||||
|
offset_bottom = 31.0
|
||||||
|
|
||||||
|
[node name="Label" type="Label" parent="Window/Tab/MOUSE/CameraPlayerWalk"]
|
||||||
|
offset_right = 40.0
|
||||||
|
offset_bottom = 23.0
|
||||||
|
text = "INPUT_VIEW_CAMERA_PLAYER_WALK"
|
||||||
|
|
||||||
|
[node name="SelectButton" type="Button" parent="Window/Tab/MOUSE/CameraPlayerWalk"]
|
||||||
|
offset_right = 8.0
|
||||||
|
offset_bottom = 31.0
|
||||||
|
text = "NOBUTTON"
|
||||||
|
|
||||||
|
[node name="ReverseHorizontal" type="CheckBox" parent="Window/Tab/MOUSE/CameraPlayerWalk"]
|
||||||
|
offset_right = 24.0
|
||||||
|
offset_bottom = 31.0
|
||||||
|
text = "EDIT_CONTROL/MOVE_CAMERA_REVERSE_HORIZONTAL"
|
||||||
|
|
||||||
|
[node name="ReverseVertical" type="CheckBox" parent="Window/Tab/MOUSE/CameraPlayerWalk"]
|
||||||
|
offset_right = 24.0
|
||||||
|
offset_bottom = 31.0
|
||||||
|
text = "EDIT_CONTROL/MOVE_CAMERA_REVERSE_VERTICAL"
|
||||||
|
|
||||||
|
[node name="Tree" type="Tree" parent="Window/Tab/MOUSE"]
|
||||||
|
offset_bottom = 40.0
|
||||||
|
size_flags_vertical = 3
|
||||||
|
column_titles_visible = true
|
||||||
|
select_mode = 2
|
||||||
|
|
||||||
|
[node name="Label" type="Label" parent="Window/Tab/MOUSE/Tree"]
|
||||||
|
offset_right = 40.0
|
||||||
|
offset_bottom = 23.0
|
||||||
|
text = "INPUT_VIEW_CAMERA_MOVE_PLAYER_FOLLOW"
|
||||||
|
|
||||||
|
[node name="Button" type="Button" parent="Window/Tab/MOUSE/Tree/Label"]
|
||||||
|
offset_right = 8.0
|
||||||
|
offset_bottom = 31.0
|
||||||
|
text = "Example"
|
||||||
|
|
||||||
[node name="SelectType" parent="." instance=ExtResource( "2_ps0mu" )]
|
[node name="SelectType" parent="." instance=ExtResource( "2_ps0mu" )]
|
||||||
|
|
||||||
|
[node name="DefineInput" parent="." instance=ExtResource( "3_dxrwd" )]
|
||||||
|
|
||||||
[connection signal="close_requested" from="Window" to="." method="_on_quit_pressed"]
|
[connection signal="close_requested" from="Window" to="." method="_on_quit_pressed"]
|
||||||
[connection signal="item_selected" from="Window/VBox/Menu/ShowMethod" to="." method="_on_option_button_item_selected"]
|
[connection signal="item_selected" from="Window/Tab/CONTROL/Menu/ShowMethod" to="." method="_on_option_button_item_selected"]
|
||||||
[connection signal="pressed" from="Window/VBox/Menu/SortByInput" to="." method="_on_sort_by_input_pressed"]
|
[connection signal="pressed" from="Window/Tab/CONTROL/Menu/SortByInput" to="." method="_on_sort_by_input_pressed"]
|
||||||
[connection signal="pressed" from="Window/VBox/Menu/Reload" to="." method="reload_control_system"]
|
[connection signal="pressed" from="Window/Tab/CONTROL/Menu/Reload" to="." method="reload_control_system"]
|
||||||
[connection signal="button_pressed" from="Window/VBox/Tree" to="." method="_on_tree_button_pressed"]
|
[connection signal="button_pressed" from="Window/Tab/CONTROL/Tree" to="." method="_on_tree_button_pressed"]
|
||||||
[connection signal="pressed" from="Window/VBox/Quit" to="." method="_on_quit_pressed"]
|
[connection signal="pressed" from="Window/Tab/CONTROL/Quit" to="." method="_on_quit_pressed"]
|
||||||
|
[connection signal="pressed" from="Window/Tab/MOUSE/CameraPlayer/SelectButton" to="." method="_on_select_button_pressed"]
|
||||||
|
[connection signal="pressed" from="Window/Tab/MOUSE/CameraOnly/SelectButton" to="." method="_on_camear_only_button_pressed"]
|
||||||
|
[connection signal="pressed" from="Window/Tab/MOUSE/CameraPlayerWalk/SelectButton" to="." method="_on_camera_player_walk_button_pressed"]
|
||||||
|
|
|
@ -1,11 +1,14 @@
|
||||||
extends Control
|
extends Control
|
||||||
|
|
||||||
signal refresh_control_define_input
|
signal refresh_control_define_input
|
||||||
|
signal cancel_define_input
|
||||||
|
|
||||||
var type_event:int
|
var type_event:int
|
||||||
var action = null
|
var action = null
|
||||||
var last_event = null
|
var last_event = null
|
||||||
|
var last_last_event = null
|
||||||
|
var focus_ok:bool = false
|
||||||
|
var detect_two_event: bool = false
|
||||||
|
|
||||||
func _ready():
|
func _ready():
|
||||||
type_event = 0
|
type_event = 0
|
||||||
|
@ -15,6 +18,14 @@ func set_disabled(state:bool):
|
||||||
$Window/v/h/Ok.disabled = state
|
$Window/v/h/Ok.disabled = state
|
||||||
|
|
||||||
|
|
||||||
|
func get_action():
|
||||||
|
return action
|
||||||
|
|
||||||
|
|
||||||
|
func get_type_event():
|
||||||
|
return type_event
|
||||||
|
|
||||||
|
|
||||||
func set_param(typeevent:int, _action):
|
func set_param(typeevent:int, _action):
|
||||||
var comment = ""
|
var comment = ""
|
||||||
if typeevent == 1:
|
if typeevent == 1:
|
||||||
|
@ -26,6 +37,9 @@ func set_param(typeevent:int, _action):
|
||||||
type_event = typeevent
|
type_event = typeevent
|
||||||
action = _action
|
action = _action
|
||||||
last_event = null
|
last_event = null
|
||||||
|
last_last_event = null
|
||||||
|
focus_ok = false
|
||||||
|
detect_two_event = false
|
||||||
$Window/v/result.set_text("")
|
$Window/v/result.set_text("")
|
||||||
$Window/v/label.set_text(comment)
|
$Window/v/label.set_text(comment)
|
||||||
set_disabled(true)
|
set_disabled(true)
|
||||||
|
@ -33,25 +47,65 @@ func set_param(typeevent:int, _action):
|
||||||
|
|
||||||
func _on_cancel_pressed():
|
func _on_cancel_pressed():
|
||||||
$Window.hide()
|
$Window.hide()
|
||||||
|
emit_signal("cancel_define_input")
|
||||||
|
|
||||||
|
|
||||||
func _on_ok_pressed():
|
func _on_ok_pressed():
|
||||||
$Window.hide()
|
$Window.hide()
|
||||||
InputMap.action_add_event(action, last_event)
|
if last_last_event != null:
|
||||||
|
Common.set_input_plus(action, last_event, last_last_event, self.type_event == 2)
|
||||||
|
else:
|
||||||
|
Common.set_input(action, last_event, self.type_event == 2)
|
||||||
|
# if self.type_event == 2:
|
||||||
|
# for curaction in InputMap.get_actions():
|
||||||
|
# var text:String = curaction
|
||||||
|
# if text == action:
|
||||||
|
# for z in InputMap.action_get_events(curaction):
|
||||||
|
# if z is InputEventMouseButton:
|
||||||
|
# InputMap.action_erase_event(text, z)
|
||||||
|
# InputMap.action_add_event(action, last_event)
|
||||||
emit_signal("refresh_control_define_input")
|
emit_signal("refresh_control_define_input")
|
||||||
|
|
||||||
|
|
||||||
func _on_window_window_input(event):
|
func _on_window_window_input(event):
|
||||||
if event.is_pressed() == false:
|
if event.is_pressed() == false:
|
||||||
return
|
return
|
||||||
|
if focus_ok:
|
||||||
|
return
|
||||||
if (event is InputEventKey) && (self.type_event == 1):
|
if (event is InputEventKey) && (self.type_event == 1):
|
||||||
|
#last_last_event = last_event
|
||||||
last_event = event
|
last_event = event
|
||||||
$Window/v/result.set_text( Common.get_string_input(event) )
|
$Window/v/result.set_text( Common.get_string_input(event) )
|
||||||
elif event is InputEventMouseButton and self.type_event == 2:
|
elif event is InputEventMouseButton and self.type_event == 2:
|
||||||
|
last_last_event = last_event
|
||||||
last_event = event
|
last_event = event
|
||||||
$Window/v/result.set_text( Common.get_string_input(event) )
|
if last_last_event:
|
||||||
|
if last_last_event.get_button_index() == last_event.get_button_index():
|
||||||
|
detect_two_event = false
|
||||||
|
last_last_event = null
|
||||||
|
elif Input.is_mouse_button_pressed( last_last_event.get_button_index() ):
|
||||||
|
detect_two_event = true
|
||||||
|
else:
|
||||||
|
detect_two_event = false
|
||||||
|
last_last_event = null
|
||||||
|
else:
|
||||||
|
detect_two_event = false
|
||||||
|
last_last_event = null
|
||||||
|
if detect_two_event == false:
|
||||||
|
$Window/v/result.set_text( Common.get_string_input(event) )
|
||||||
|
else:
|
||||||
|
$Window/v/result.set_text( tr(Common.get_string_input(event)) + " + " + tr(Common.get_string_input(last_last_event)))
|
||||||
elif event is InputEventJoypadButton and self.type_event == 3:
|
elif event is InputEventJoypadButton and self.type_event == 3:
|
||||||
|
#last_last_event = last_event
|
||||||
last_event = event
|
last_event = event
|
||||||
$Window/v/result.set_text( Common.get_string_input(event) )
|
$Window/v/result.set_text( Common.get_string_input(event) )
|
||||||
if last_event != null:
|
if last_event != null:
|
||||||
set_disabled(false)
|
set_disabled(false)
|
||||||
|
|
||||||
|
|
||||||
|
func _on_ok_mouse_entered():
|
||||||
|
focus_ok = true
|
||||||
|
|
||||||
|
|
||||||
|
func _on_ok_mouse_exited():
|
||||||
|
focus_ok = false
|
||||||
|
|
|
@ -10,6 +10,7 @@ script = ExtResource( "1_pgm2r" )
|
||||||
[node name="Window" type="Window" parent="."]
|
[node name="Window" type="Window" parent="."]
|
||||||
title = "OPTION_DEFINE_INPUT/TITLE"
|
title = "OPTION_DEFINE_INPUT/TITLE"
|
||||||
position = Vector2i(30, 70)
|
position = Vector2i(30, 70)
|
||||||
|
size = Vector2i(300, 100)
|
||||||
visible = false
|
visible = false
|
||||||
|
|
||||||
[node name="v" type="VBoxContainer" parent="Window"]
|
[node name="v" type="VBoxContainer" parent="Window"]
|
||||||
|
@ -17,9 +18,8 @@ anchor_right = 1.0
|
||||||
anchor_bottom = 1.0
|
anchor_bottom = 1.0
|
||||||
grow_horizontal = 2
|
grow_horizontal = 2
|
||||||
grow_vertical = 2
|
grow_vertical = 2
|
||||||
__meta__ = {
|
size_flags_horizontal = 3
|
||||||
"_edit_use_custom_anchors": false
|
size_flags_vertical = 3
|
||||||
}
|
|
||||||
|
|
||||||
[node name="label" type="Label" parent="Window/v"]
|
[node name="label" type="Label" parent="Window/v"]
|
||||||
offset_right = 1024.0
|
offset_right = 1024.0
|
||||||
|
@ -30,12 +30,12 @@ text = "OPTION_DEFINE_INPUT/MESSAGE_KEY"
|
||||||
offset_top = 30.0
|
offset_top = 30.0
|
||||||
offset_right = 1024.0
|
offset_right = 1024.0
|
||||||
offset_bottom = 53.0
|
offset_bottom = 53.0
|
||||||
|
size_flags_vertical = 6
|
||||||
|
|
||||||
[node name="h" type="HBoxContainer" parent="Window/v"]
|
[node name="h" type="HBoxContainer" parent="Window/v"]
|
||||||
offset_top = 57.0
|
offset_top = 57.0
|
||||||
offset_right = 1024.0
|
offset_right = 1024.0
|
||||||
offset_bottom = 88.0
|
offset_bottom = 88.0
|
||||||
size_flags_vertical = 3
|
|
||||||
|
|
||||||
[node name="Cancel" type="Button" parent="Window/v/h"]
|
[node name="Cancel" type="Button" parent="Window/v/h"]
|
||||||
offset_right = 255.0
|
offset_right = 255.0
|
||||||
|
@ -52,4 +52,6 @@ text = "OPTION_DEFINE_INPUT/OK"
|
||||||
|
|
||||||
[connection signal="window_input" from="Window" to="." method="_on_window_window_input"]
|
[connection signal="window_input" from="Window" to="." method="_on_window_window_input"]
|
||||||
[connection signal="pressed" from="Window/v/h/Cancel" to="." method="_on_cancel_pressed"]
|
[connection signal="pressed" from="Window/v/h/Cancel" to="." method="_on_cancel_pressed"]
|
||||||
|
[connection signal="mouse_entered" from="Window/v/h/Ok" to="." method="_on_ok_mouse_entered"]
|
||||||
|
[connection signal="mouse_exited" from="Window/v/h/Ok" to="." method="_on_ok_mouse_exited"]
|
||||||
[connection signal="pressed" from="Window/v/h/Ok" to="." method="_on_ok_pressed"]
|
[connection signal="pressed" from="Window/v/h/Ok" to="." method="_on_ok_pressed"]
|
||||||
|
|
|
@ -2,12 +2,14 @@ extends Control
|
||||||
|
|
||||||
|
|
||||||
signal refresh_select_type_control
|
signal refresh_select_type_control
|
||||||
|
signal cancel_define_input
|
||||||
|
|
||||||
var action = null
|
var action = null
|
||||||
var signalrefresh = null
|
var signalrefresh = null
|
||||||
|
|
||||||
func _ready():
|
func _ready():
|
||||||
$DefineInput.connect("refresh_control_define_input", refresh.bind() )
|
$DefineInput.connect("refresh_control_define_input", refresh.bind() )
|
||||||
|
$DefineInput.connect("cancel_define_input", _on_quit_pressed.bind() )
|
||||||
|
|
||||||
|
|
||||||
func refresh():
|
func refresh():
|
||||||
|
@ -21,6 +23,7 @@ func set_param(_action, _signalrefresh):
|
||||||
|
|
||||||
func _on_quit_pressed():
|
func _on_quit_pressed():
|
||||||
$Window.visible = false
|
$Window.visible = false
|
||||||
|
emit_signal("cancel_define_input")
|
||||||
|
|
||||||
|
|
||||||
func get_input(typevent) -> void:
|
func get_input(typevent) -> void:
|
||||||
|
|
|
@ -19,9 +19,6 @@ anchor_right = 1.0
|
||||||
anchor_bottom = 1.0
|
anchor_bottom = 1.0
|
||||||
grow_horizontal = 2
|
grow_horizontal = 2
|
||||||
grow_vertical = 2
|
grow_vertical = 2
|
||||||
__meta__ = {
|
|
||||||
"_edit_use_custom_anchors": false
|
|
||||||
}
|
|
||||||
|
|
||||||
[node name="Key" type="Button" parent="Window/VBoxContainer"]
|
[node name="Key" type="Button" parent="Window/VBoxContainer"]
|
||||||
offset_right = 1024.0
|
offset_right = 1024.0
|
||||||
|
|
|
@ -2,19 +2,29 @@ extends Control
|
||||||
|
|
||||||
var git_branch:String
|
var git_branch:String
|
||||||
var git_commit:String
|
var git_commit:String
|
||||||
|
var tag_release:String
|
||||||
|
|
||||||
func _ready():
|
func _ready():
|
||||||
# .connect("mute_pressed", self, "_on_signal_mute_pressed")
|
|
||||||
$MenuTheme.connect("update_theme", update_theme.bind())
|
$MenuTheme.connect("update_theme", update_theme.bind())
|
||||||
var file = File.new()
|
var file = File.new()
|
||||||
file.open("res://.git/HEAD", File.READ)
|
if file.file_exists("res://commit.txt"):
|
||||||
var content = file.get_as_text().strip_escapes()
|
file.open("res://commit.txt", File.READ)
|
||||||
file.close()
|
tag_release = file.get_as_text().strip_escapes()
|
||||||
git_branch = content.split(' ')[1]
|
file.close()
|
||||||
file.open("res://.git/" + git_branch, File.READ)
|
Common.msg_debug("Tag: " + tag_release)
|
||||||
git_commit = file.get_as_text().strip_escapes()
|
elif file.file_exists("res://.git/HEAD"):
|
||||||
file.close()
|
file.open("res://.git/HEAD", File.READ)
|
||||||
Common.msg_debug("Commit: " + git_commit)
|
var content = file.get_as_text().strip_escapes()
|
||||||
|
file.close()
|
||||||
|
git_branch = content.split(' ')[1]
|
||||||
|
|
||||||
|
file.open("res://.git/" + git_branch, File.READ)
|
||||||
|
git_commit = file.get_as_text().strip_escapes()
|
||||||
|
file.close()
|
||||||
|
Common.msg_debug("Commit: " + git_commit)
|
||||||
|
else:
|
||||||
|
git_branch = "Unknown"
|
||||||
|
git_commit = "Unknown"
|
||||||
|
|
||||||
|
|
||||||
func update_theme():
|
func update_theme():
|
||||||
|
@ -43,8 +53,8 @@ func _on_confirmation_dialog_confirmed():
|
||||||
|
|
||||||
|
|
||||||
func _on_languages_pressed():
|
func _on_languages_pressed():
|
||||||
$MenuOption/Window.popup_centered()
|
$MenuLanguage/Window.popup_centered()
|
||||||
$MenuOption/Window.visible = true
|
$MenuLanguage/Window.visible = true
|
||||||
|
|
||||||
|
|
||||||
func _on_keys_pressed():
|
func _on_keys_pressed():
|
||||||
|
@ -58,7 +68,15 @@ func _on_themes_pressed():
|
||||||
|
|
||||||
|
|
||||||
func _on_about_pressed():
|
func _on_about_pressed():
|
||||||
var aboutmessage = "Khaganat client test\nBranch: " + git_branch + "\nCommit: " + git_commit
|
var aboutmessage:String
|
||||||
|
if tag_release.is_empty():
|
||||||
|
aboutmessage = "Khaganat client test\nBranch: " + git_branch + "\nCommit: " + git_commit
|
||||||
|
else:
|
||||||
|
aboutmessage = "Khaganat client test\nVersion: " + tag_release
|
||||||
$AboutMessage.set_text(aboutmessage)
|
$AboutMessage.set_text(aboutmessage)
|
||||||
$AboutMessage.popup_centered()
|
$AboutMessage.popup_centered()
|
||||||
$AboutMessage.visible = true
|
$AboutMessage.visible = true
|
||||||
|
|
||||||
|
|
||||||
|
func _on_music_pressed():
|
||||||
|
$MusicManager.show_config()
|
||||||
|
|
|
@ -1,10 +1,11 @@
|
||||||
[gd_scene load_steps=6 format=3 uid="uid://cdyi1a858p7em"]
|
[gd_scene load_steps=7 format=3 uid="uid://cdyi1a858p7em"]
|
||||||
|
|
||||||
[ext_resource type="Theme" uid="uid://bi1js53ni6ehd" path="res://UI/themes/zbasu/zbasu.theme" id="1_iq3fo"]
|
[ext_resource type="Theme" uid="uid://bi1js53ni6ehd" path="res://UI/themes/zbasu/zbasu.theme" id="1_iq3fo"]
|
||||||
[ext_resource type="Script" path="res://scenes/hud/hud.gd" id="1_s6f6d"]
|
[ext_resource type="Script" path="res://scenes/hud/hud.gd" id="1_s6f6d"]
|
||||||
[ext_resource type="PackedScene" uid="uid://dpvequp5fv27k" path="res://scenes/languages/languages.tscn" id="2_um8fw"]
|
[ext_resource type="PackedScene" uid="uid://dpvequp5fv27k" path="res://scenes/languages/languages.tscn" id="2_um8fw"]
|
||||||
[ext_resource type="PackedScene" uid="uid://cl8xk8w3jmta0" path="res://scenes/controls/controls.tscn" id="3_08xl7"]
|
[ext_resource type="PackedScene" uid="uid://cl8xk8w3jmta0" path="res://scenes/controls/controls.tscn" id="3_08xl7"]
|
||||||
[ext_resource type="PackedScene" uid="uid://cb0gfweooxdsl" path="res://scenes/themes/themes.tscn" id="4_1poje"]
|
[ext_resource type="PackedScene" uid="uid://cb0gfweooxdsl" path="res://scenes/themes/themes.tscn" id="4_1poje"]
|
||||||
|
[ext_resource type="PackedScene" uid="uid://ebfrhgrluixd" path="res://scenes/music/music_manager.tscn" id="6_0ivsi"]
|
||||||
|
|
||||||
[node name="Control" type="Control"]
|
[node name="Control" type="Control"]
|
||||||
anchor_right = 1.0
|
anchor_right = 1.0
|
||||||
|
@ -17,9 +18,6 @@ anchor_right = 1.0
|
||||||
size_flags_horizontal = 0
|
size_flags_horizontal = 0
|
||||||
size_flags_vertical = 0
|
size_flags_vertical = 0
|
||||||
alignment = 2
|
alignment = 2
|
||||||
__meta__ = {
|
|
||||||
"_edit_use_anchors_": false
|
|
||||||
}
|
|
||||||
|
|
||||||
[node name="Label" type="Label" parent="Message"]
|
[node name="Label" type="Label" parent="Message"]
|
||||||
offset_left = 917.0
|
offset_left = 917.0
|
||||||
|
@ -27,9 +25,6 @@ offset_right = 1024.0
|
||||||
offset_bottom = 27.0
|
offset_bottom = 27.0
|
||||||
size_flags_vertical = 1
|
size_flags_vertical = 1
|
||||||
text = "Echap = Menu"
|
text = "Echap = Menu"
|
||||||
__meta__ = {
|
|
||||||
"_edit_use_anchors_": false
|
|
||||||
}
|
|
||||||
|
|
||||||
[node name="Menu" type="HBoxContainer" parent="."]
|
[node name="Menu" type="HBoxContainer" parent="."]
|
||||||
visible = false
|
visible = false
|
||||||
|
@ -37,9 +32,6 @@ anchor_right = 1.0
|
||||||
offset_right = 40.0
|
offset_right = 40.0
|
||||||
offset_bottom = 40.0
|
offset_bottom = 40.0
|
||||||
alignment = 1
|
alignment = 1
|
||||||
__meta__ = {
|
|
||||||
"_edit_use_anchors_": false
|
|
||||||
}
|
|
||||||
|
|
||||||
[node name="Keys" type="Button" parent="Menu"]
|
[node name="Keys" type="Button" parent="Menu"]
|
||||||
offset_left = 510.0
|
offset_left = 510.0
|
||||||
|
@ -58,6 +50,11 @@ offset_right = 574.0
|
||||||
offset_bottom = 40.0
|
offset_bottom = 40.0
|
||||||
text = "HUD/LANGUAGES"
|
text = "HUD/LANGUAGES"
|
||||||
|
|
||||||
|
[node name="Music" type="Button" parent="Menu"]
|
||||||
|
offset_right = 87.0
|
||||||
|
offset_bottom = 19.0
|
||||||
|
text = "HUD/MUSIC"
|
||||||
|
|
||||||
[node name="About" type="Button" parent="Menu"]
|
[node name="About" type="Button" parent="Menu"]
|
||||||
offset_right = 40.0
|
offset_right = 40.0
|
||||||
offset_bottom = 19.0
|
offset_bottom = 19.0
|
||||||
|
@ -81,7 +78,7 @@ dialog_text = "POPUP_CONFIRM_QUIT/MESSAGE"
|
||||||
[node name="AboutMessage" type="AcceptDialog" parent="."]
|
[node name="AboutMessage" type="AcceptDialog" parent="."]
|
||||||
title = "POPUP_ABOUT_MESSAGE/TITLE"
|
title = "POPUP_ABOUT_MESSAGE/TITLE"
|
||||||
|
|
||||||
[node name="MenuOption" parent="." instance=ExtResource( "2_um8fw" )]
|
[node name="MenuLanguage" parent="." instance=ExtResource( "2_um8fw" )]
|
||||||
visible = false
|
visible = false
|
||||||
|
|
||||||
[node name="MenuControl" parent="." instance=ExtResource( "3_08xl7" )]
|
[node name="MenuControl" parent="." instance=ExtResource( "3_08xl7" )]
|
||||||
|
@ -89,9 +86,12 @@ visible = false
|
||||||
[node name="MenuTheme" parent="." instance=ExtResource( "4_1poje" )]
|
[node name="MenuTheme" parent="." instance=ExtResource( "4_1poje" )]
|
||||||
visible = false
|
visible = false
|
||||||
|
|
||||||
|
[node name="MusicManager" parent="." instance=ExtResource( "6_0ivsi" )]
|
||||||
|
|
||||||
[connection signal="pressed" from="Menu/Keys" to="." method="_on_keys_pressed"]
|
[connection signal="pressed" from="Menu/Keys" to="." method="_on_keys_pressed"]
|
||||||
[connection signal="pressed" from="Menu/Themes" to="." method="_on_themes_pressed"]
|
[connection signal="pressed" from="Menu/Themes" to="." method="_on_themes_pressed"]
|
||||||
[connection signal="pressed" from="Menu/Languages" to="." method="_on_languages_pressed"]
|
[connection signal="pressed" from="Menu/Languages" to="." method="_on_languages_pressed"]
|
||||||
|
[connection signal="pressed" from="Menu/Music" to="." method="_on_music_pressed"]
|
||||||
[connection signal="pressed" from="Menu/About" to="." method="_on_about_pressed"]
|
[connection signal="pressed" from="Menu/About" to="." method="_on_about_pressed"]
|
||||||
[connection signal="pressed" from="Menu/Quit" to="." method="_on_quit_pressed"]
|
[connection signal="pressed" from="Menu/Quit" to="." method="_on_quit_pressed"]
|
||||||
[connection signal="timeout" from="Timer" to="." method="_on_timer_timeout"]
|
[connection signal="timeout" from="Timer" to="." method="_on_timer_timeout"]
|
||||||
|
|
|
@ -4,9 +4,6 @@
|
||||||
|
|
||||||
[node name="Control" type="Control"]
|
[node name="Control" type="Control"]
|
||||||
script = ExtResource( "1_qc7c5" )
|
script = ExtResource( "1_qc7c5" )
|
||||||
__meta__ = {
|
|
||||||
"_edit_use_anchors_": false
|
|
||||||
}
|
|
||||||
|
|
||||||
[node name="Window" type="Window" parent="."]
|
[node name="Window" type="Window" parent="."]
|
||||||
title = "Language"
|
title = "Language"
|
||||||
|
|
|
@ -3,17 +3,23 @@ extends Node3D
|
||||||
var oldobject:Node3D = null
|
var oldobject:Node3D = null
|
||||||
@onready var player_ptr = $player
|
@onready var player_ptr = $player
|
||||||
|
|
||||||
func _init():
|
#func _init():
|
||||||
var file = File.new()
|
# var content = "N/A"
|
||||||
file.open("res://.git/HEAD", File.READ)
|
# var file = File.new()
|
||||||
var content = file.get_as_text().strip_escapes()
|
# if file.file_exists("res://.git/HEAD"):
|
||||||
file.close()
|
# file.open("res://.git/HEAD", File.READ)
|
||||||
var head:String = content.split(' ')[1]
|
# content = file.get_as_text().strip_escapes()
|
||||||
|
# file.close()
|
||||||
file.open("res://.git/" + head, File.READ)
|
# var head:String = content.split(' ')[1]
|
||||||
content = file.get_as_text().strip_escapes()
|
#
|
||||||
file.close()
|
# file.open("res://.git/" + head, File.READ)
|
||||||
Common.msg_debug("Commit: " + content)
|
# content = file.get_as_text().strip_escapes()
|
||||||
|
# file.close()
|
||||||
|
# elif file.file_exists("res://commit.txt"):
|
||||||
|
# file.open("res://commit.txt", File.READ)
|
||||||
|
# content = file.get_as_text().strip_escapes()
|
||||||
|
# file.close()
|
||||||
|
# Common.msg_debug("Commit: " + content)
|
||||||
|
|
||||||
|
|
||||||
# Called when the node enters the scene tree for the first time.
|
# Called when the node enters the scene tree for the first time.
|
||||||
|
|
|
@ -1,10 +1,9 @@
|
||||||
[gd_scene load_steps=6 format=3 uid="uid://cem7wppuuoabv"]
|
[gd_scene load_steps=5 format=3 uid="uid://cem7wppuuoabv"]
|
||||||
|
|
||||||
[ext_resource type="PackedScene" uid="uid://dwxrvijqyym70" path="res://player/player.tscn" id="1_btdsd"]
|
[ext_resource type="PackedScene" uid="uid://dwxrvijqyym70" path="res://player/player.tscn" id="1_btdsd"]
|
||||||
[ext_resource type="Script" path="res://scenes/main/main.gd" id="1_ld2xt"]
|
[ext_resource type="Script" path="res://scenes/main/main.gd" id="1_ld2xt"]
|
||||||
[ext_resource type="PackedScene" uid="uid://b8p2h0rmwy7qn" path="res://maps/basic_setup.tscn" id="2_jj4oa"]
|
[ext_resource type="PackedScene" uid="uid://b8p2h0rmwy7qn" path="res://maps/basic_setup.tscn" id="2_jj4oa"]
|
||||||
[ext_resource type="PackedScene" uid="uid://cdyi1a858p7em" path="res://scenes/hud/hud.tscn" id="3_5vcj4"]
|
[ext_resource type="PackedScene" uid="uid://cdyi1a858p7em" path="res://scenes/hud/hud.tscn" id="3_5vcj4"]
|
||||||
[ext_resource type="PackedScene" uid="uid://ebfrhgrluixd" path="res://scenes/music/music_manager.tscn" id="5_nlfpg"]
|
|
||||||
|
|
||||||
[node name="main_scene" type="Node3D"]
|
[node name="main_scene" type="Node3D"]
|
||||||
script = ExtResource( "1_ld2xt" )
|
script = ExtResource( "1_ld2xt" )
|
||||||
|
@ -15,6 +14,3 @@ transform = Transform3D(0.677723, 0, -0.735317, 0, 1, 0, 0.735317, 0, 0.677723,
|
||||||
[node name="terrain_basic_setup" parent="." instance=ExtResource( "2_jj4oa" )]
|
[node name="terrain_basic_setup" parent="." instance=ExtResource( "2_jj4oa" )]
|
||||||
|
|
||||||
[node name="Control" parent="." instance=ExtResource( "3_5vcj4" )]
|
[node name="Control" parent="." instance=ExtResource( "3_5vcj4" )]
|
||||||
|
|
||||||
[node name="MusicManager" parent="." instance=ExtResource( "5_nlfpg" )]
|
|
||||||
visible = false
|
|
||||||
|
|
18
scenes/music/music_field.gd
Normal file
18
scenes/music/music_field.gd
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
extends HBoxContainer
|
||||||
|
|
||||||
|
|
||||||
|
signal selected_music(pos)
|
||||||
|
|
||||||
|
var filename:String = ""
|
||||||
|
var pos:int = 0
|
||||||
|
|
||||||
|
|
||||||
|
func set_music(_filename, musicname, _pos, selected:bool):
|
||||||
|
filename = _filename
|
||||||
|
pos = _pos
|
||||||
|
$Music.set_text(musicname)
|
||||||
|
$Selected.set_pressed(selected)
|
||||||
|
|
||||||
|
|
||||||
|
func _on_music_pressed():
|
||||||
|
emit_signal( "selected_music", pos )
|
22
scenes/music/music_field.tscn
Normal file
22
scenes/music/music_field.tscn
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
[gd_scene load_steps=2 format=3 uid="uid://co13dert7ixio"]
|
||||||
|
|
||||||
|
[ext_resource type="Script" path="res://scenes/music/music_field.gd" id="1_u1fvf"]
|
||||||
|
|
||||||
|
[node name="Control" type="HBoxContainer"]
|
||||||
|
anchor_right = 1.0
|
||||||
|
anchor_bottom = 1.0
|
||||||
|
script = ExtResource( "1_u1fvf" )
|
||||||
|
|
||||||
|
[node name="Selected" type="CheckBox" parent="."]
|
||||||
|
offset_right = 24.0
|
||||||
|
offset_bottom = 600.0
|
||||||
|
focus_mode = 0
|
||||||
|
disabled = true
|
||||||
|
|
||||||
|
[node name="Music" type="Button" parent="."]
|
||||||
|
offset_left = 28.0
|
||||||
|
offset_right = 1024.0
|
||||||
|
offset_bottom = 600.0
|
||||||
|
size_flags_horizontal = 3
|
||||||
|
|
||||||
|
[connection signal="pressed" from="Music" to="." method="_on_music_pressed"]
|
|
@ -1,25 +1,29 @@
|
||||||
extends Control
|
extends Control
|
||||||
|
|
||||||
|
|
||||||
@onready var music_player:AudioStreamPlayer = $music
|
@onready var music_player:AudioStreamPlayer = $Music
|
||||||
var official_music:Dictionary = {}
|
var official_music:Dictionary = {}
|
||||||
var current_area:String = "extra"
|
var default_domain:String = "default"
|
||||||
var current_music:String = ""
|
var current_domain:String = ""
|
||||||
|
var current_music:int = 0
|
||||||
|
var music_play:bool = false
|
||||||
|
var select_rand:bool = true
|
||||||
|
var list_music:Array = []
|
||||||
|
|
||||||
func _ready():
|
func _ready():
|
||||||
var directory:Directory = Directory.new()
|
var directory:Directory = Directory.new()
|
||||||
var files = []
|
var files = []
|
||||||
get_tree().paused = false
|
get_tree().paused = false
|
||||||
Common.msg_debug("Load MusicManager")
|
Common.msg_info("Load MusicManager")
|
||||||
if not directory.dir_exists( "res://music/" ):
|
if not directory.dir_exists( "res://music/" ):
|
||||||
Common.msg_debug("No Music")
|
Common.msg_info("No Music")
|
||||||
return
|
return
|
||||||
directory.open( "res://music/" )
|
directory.open( "res://music/" )
|
||||||
for dir in directory.get_directories():
|
for dir in directory.get_directories():
|
||||||
var dir2:Directory = Directory.new()
|
var dir2:Directory = Directory.new()
|
||||||
var fullpath: String = "res://music/" + dir
|
var fullpath: String = "res://music/" + dir
|
||||||
dir2.open( fullpath )
|
dir2.open( fullpath )
|
||||||
Common.msg_debug("Dir: " + str(dir))
|
# Common.msg_debug("Dir: " + str(dir))
|
||||||
for file in dir2.get_files():
|
for file in dir2.get_files():
|
||||||
if file == "":
|
if file == "":
|
||||||
break
|
break
|
||||||
|
@ -28,17 +32,60 @@ func _ready():
|
||||||
official_music[dir] = []
|
official_music[dir] = []
|
||||||
official_music[dir].append(fullpath + "/" + file)
|
official_music[dir].append(fullpath + "/" + file)
|
||||||
files.append(file)
|
files.append(file)
|
||||||
Common.msg_debug("File: " + str(file))
|
|
||||||
Common.msg_debug("List: " + str(official_music))
|
|
||||||
# music_player.connect("finished", self._on_stream_finished.bind())
|
|
||||||
# music_player.connect("finished", _on_stream_finished.bind())
|
|
||||||
#music_player.finished.connect(_on_stream_finished.bind())
|
#music_player.finished.connect(_on_stream_finished.bind())
|
||||||
music_player.finished.connect(self._on_stream_finished.bind())
|
_on_random_pressed()
|
||||||
#music_player.loop = false
|
select_domain( default_domain )
|
||||||
if official_music.has(current_area):
|
current_music = official_music[current_domain].size()
|
||||||
var first = official_music[current_area][0]
|
# Get Volume
|
||||||
Common.msg_debug("Play music: " + first)
|
# Common.msg_debug("volume :" + str($Music.get_volume_db()))
|
||||||
play_music(first)
|
# var t = linear2db(0.0)
|
||||||
|
# var u = db2linear($Music.get_volume_db())
|
||||||
|
# Common.msg_debug("volume :" + str(u))
|
||||||
|
$Window/VBox/Tab/Mixer/MusicLevel/music.set_value( int(db2linear($Music.get_volume_db()) * 100.0))
|
||||||
|
var bus_name = $Music.get_bus()
|
||||||
|
Common.msg_debug("bus_name: " + str(bus_name))
|
||||||
|
var bus_id = AudioServer.get_bus_index(bus_name)
|
||||||
|
Common.msg_debug("bus_id: " + str(bus_id))
|
||||||
|
var glb_volume = AudioServer.get_bus_volume_db(bus_id)
|
||||||
|
Common.msg_debug("GLB Volume: " + str(glb_volume))
|
||||||
|
# AudioServer.get_bus_volume_db(AudioServer.get_bus_index($Music.get_bus()))
|
||||||
|
$Window/VBox/Tab/Mixer/GlobalLevel/global.set_value( int(db2linear(AudioServer.get_bus_volume_db(AudioServer.get_bus_index($Music.get_bus()))) * 100.0))
|
||||||
|
|
||||||
|
|
||||||
|
func select_domain(new_domain:String):
|
||||||
|
var found:bool = false
|
||||||
|
for key in official_music.keys():
|
||||||
|
if new_domain == key:
|
||||||
|
found = true
|
||||||
|
if found == false:
|
||||||
|
return
|
||||||
|
current_domain = new_domain
|
||||||
|
reinitialize_jukebox()
|
||||||
|
|
||||||
|
|
||||||
|
func reinitialize_jukebox():
|
||||||
|
list_music.clear()
|
||||||
|
if select_rand:
|
||||||
|
var temp:Array
|
||||||
|
for i in range(0, official_music[current_domain].size()):
|
||||||
|
temp.append(i)
|
||||||
|
for i in range(0, official_music[current_domain].size()):
|
||||||
|
var pos = randi() % temp.size()
|
||||||
|
list_music.append(temp[pos])
|
||||||
|
temp.remove_at(pos)
|
||||||
|
else:
|
||||||
|
for i in range(0, official_music[current_domain].size()):
|
||||||
|
list_music.append(i)
|
||||||
|
|
||||||
|
|
||||||
|
func next_music():
|
||||||
|
var pos:float
|
||||||
|
current_music += 1
|
||||||
|
if current_music >= list_music.size():
|
||||||
|
reinitialize_jukebox()
|
||||||
|
play_music(0)
|
||||||
|
return
|
||||||
|
play_music(current_music)
|
||||||
|
|
||||||
|
|
||||||
func load_external_music(filepath):
|
func load_external_music(filepath):
|
||||||
|
@ -76,40 +123,106 @@ func load_music(filepath: String):
|
||||||
func _on_stream_finished():
|
func _on_stream_finished():
|
||||||
Common.msg_debug("_on_stream_finished")
|
Common.msg_debug("_on_stream_finished")
|
||||||
music_player.stop()
|
music_player.stop()
|
||||||
|
music_play = false
|
||||||
|
|
||||||
|
|
||||||
func play_music(filename: String):
|
func show_list_music():
|
||||||
if current_music == filename:
|
for child in $Window/VBox/Tab/Music/ScrollContainer/ListMusic.get_children():
|
||||||
|
child.queue_free()
|
||||||
|
for pos in range(0, list_music.size()):
|
||||||
|
var filename:String = official_music[current_domain][list_music[pos]]
|
||||||
|
var music_box = preload( "res://scenes/music/music_field.tscn" ).instantiate()
|
||||||
|
music_box.set_music( filename, filename.get_file().get_basename() , pos, pos == current_music)
|
||||||
|
music_box.connect("selected_music", force_music.bind())
|
||||||
|
$Window/VBox/Tab/Music/ScrollContainer/ListMusic.add_child( music_box )
|
||||||
|
|
||||||
|
|
||||||
|
func force_music(pos:int):
|
||||||
|
Common.msg_debug("Force: " + str(pos))
|
||||||
|
play_music(pos)
|
||||||
|
|
||||||
|
|
||||||
|
func play_music(pos: int):
|
||||||
|
if pos >= list_music.size():
|
||||||
return
|
return
|
||||||
#music_player.stream = load_music( filename )
|
var filename:String = official_music[current_domain][list_music[pos]]
|
||||||
|
music_play = true
|
||||||
music_player.set_stream(load_music( filename ))
|
music_player.set_stream(load_music( filename ))
|
||||||
music_player.play()
|
music_player.play()
|
||||||
music_player.get_stream().set_loop(false)
|
music_player.get_stream().set_loop(false)
|
||||||
Common.msg_debug("Signal:" + str(music_player.get_signal_list()))
|
var timer = music_player.get_stream().get_length()
|
||||||
Common.msg_debug("Signal:" + str(music_player.get_stream().get_signal_list()))
|
$EndMusic.start(timer)
|
||||||
Common.msg_debug("Signal connecte:" + str(music_player.finished.get_connections()))
|
music_player.connect("finished", _on_stream_finished.bind())
|
||||||
# music_player.connect("finished", _on_stream_finished.bind())
|
current_music = pos
|
||||||
current_music = filename
|
show_list_music()
|
||||||
# music_play = true
|
|
||||||
# for child in $window_box/scroll_box/musics_box.get_children():
|
|
||||||
# child.set_play()
|
|
||||||
# if Config.mute:
|
|
||||||
# child.set_disabled()
|
|
||||||
# elif child.get_music() == filename or not Config.playermusic :
|
|
||||||
# child.set_play()
|
|
||||||
# else:
|
|
||||||
# child.set_unplay()
|
|
||||||
|
|
||||||
|
|
||||||
# Called every frame. 'delta' is the elapsed time since the previous frame.
|
|
||||||
func _process(delta):
|
func _process(delta):
|
||||||
# if ! music_player.get_stream().is_playing():
|
if ! music_play and $Window/VBox/Tab/Music/HBox/Play.is_pressed():
|
||||||
# Common.msg_debug("Not playing")
|
next_music()
|
||||||
# else:
|
|
||||||
# Common.msg_debug("Playing")
|
|
||||||
pass
|
|
||||||
|
|
||||||
|
|
||||||
func _on_music_finished():
|
func _on_music_finished():
|
||||||
Common.msg_debug("_on_music_finished")
|
Common.msg_debug("_on_music_finished")
|
||||||
music_player.stop()
|
music_player.stop()
|
||||||
|
music_play = false
|
||||||
|
|
||||||
|
|
||||||
|
func _on_end_music_timeout():
|
||||||
|
# Timer end - sometimes, signal finished is not sent
|
||||||
|
Common.msg_debug("_on_end_music_timeout")
|
||||||
|
music_play = false
|
||||||
|
|
||||||
|
|
||||||
|
func show_config():
|
||||||
|
#$Window.popup_centered()
|
||||||
|
$Window.visible = true
|
||||||
|
|
||||||
|
|
||||||
|
func _on_button_pressed():
|
||||||
|
$Window.hide()
|
||||||
|
|
||||||
|
|
||||||
|
func _on_play_pressed():
|
||||||
|
var current_time = $EndMusic.get_time_left()
|
||||||
|
Common.msg_debug("_on_play_pressed : " + str(current_time))
|
||||||
|
if $Window/VBox/Tab/Music/HBox/Play.is_pressed():
|
||||||
|
$Music.set_stream_paused(false)
|
||||||
|
$EndMusic.set_paused(false)
|
||||||
|
else:
|
||||||
|
$Music.set_stream_paused(true)
|
||||||
|
$EndMusic.set_paused(true)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
func _on_random_pressed():
|
||||||
|
if $Window/VBox/Tab/Music/HBox/Random.is_pressed():
|
||||||
|
select_rand = true
|
||||||
|
else:
|
||||||
|
select_rand = false
|
||||||
|
|
||||||
|
|
||||||
|
func _on_reinit_pressed():
|
||||||
|
reinitialize_jukebox()
|
||||||
|
play_music(0)
|
||||||
|
|
||||||
|
|
||||||
|
func _on_mute_toggled(button_pressed):
|
||||||
|
Common.msg_debug("Mute:" + str(button_pressed))
|
||||||
|
AudioServer.set_bus_mute(AudioServer.get_bus_index($Music.get_bus()), button_pressed)
|
||||||
|
|
||||||
|
|
||||||
|
func _on_effect_value_changed(value):
|
||||||
|
pass # Replace with function body.
|
||||||
|
|
||||||
|
|
||||||
|
func _on_music_value_changed(value):
|
||||||
|
$Music.set_volume_db(linear2db(value/100.0))
|
||||||
|
|
||||||
|
|
||||||
|
func _on_global_value_changed(value):
|
||||||
|
AudioServer.set_bus_volume_db(AudioServer.get_bus_index($Music.get_bus()), linear2db(value/100.0))
|
||||||
|
|
||||||
|
|
||||||
|
func _on_window_close_requested():
|
||||||
|
$Window.hide()
|
||||||
|
|
|
@ -3,10 +3,160 @@
|
||||||
[ext_resource type="Script" path="res://scenes/music/music_manager.gd" id="1_dltpv"]
|
[ext_resource type="Script" path="res://scenes/music/music_manager.gd" id="1_dltpv"]
|
||||||
|
|
||||||
[node name="MusicManager" type="Control"]
|
[node name="MusicManager" type="Control"]
|
||||||
anchor_right = 1.0
|
|
||||||
anchor_bottom = 1.0
|
|
||||||
script = ExtResource( "1_dltpv" )
|
script = ExtResource( "1_dltpv" )
|
||||||
|
|
||||||
[node name="music" type="AudioStreamPlayer" parent="."]
|
[node name="Music" type="AudioStreamPlayer" parent="."]
|
||||||
|
|
||||||
[connection signal="finished" from="music" to="." method="_on_music_finished"]
|
[node name="EndMusic" type="Timer" parent="."]
|
||||||
|
|
||||||
|
[node name="Window" type="Window" parent="."]
|
||||||
|
title = "MUSIC_MANAGER/TITLE"
|
||||||
|
position = Vector2i(100, 100)
|
||||||
|
size = Vector2i(800, 450)
|
||||||
|
visible = false
|
||||||
|
|
||||||
|
[node name="VBox" type="VBoxContainer" parent="Window"]
|
||||||
|
anchor_right = 1.0
|
||||||
|
anchor_bottom = 1.0
|
||||||
|
grow_horizontal = 2
|
||||||
|
grow_vertical = 2
|
||||||
|
|
||||||
|
[node name="Tab" type="TabContainer" parent="Window/VBox"]
|
||||||
|
offset_right = 1024.0
|
||||||
|
offset_bottom = 565.0
|
||||||
|
grow_horizontal = 2
|
||||||
|
grow_vertical = 2
|
||||||
|
size_flags_vertical = 3
|
||||||
|
tab_alignment = 1
|
||||||
|
|
||||||
|
[node name="Music" type="VBoxContainer" parent="Window/VBox/Tab"]
|
||||||
|
anchor_right = 1.0
|
||||||
|
anchor_bottom = 1.0
|
||||||
|
offset_top = 31.0
|
||||||
|
grow_horizontal = 2
|
||||||
|
grow_vertical = 2
|
||||||
|
|
||||||
|
[node name="HBox" type="HBoxContainer" parent="Window/VBox/Tab/Music"]
|
||||||
|
offset_left = 160.0
|
||||||
|
offset_right = 864.0
|
||||||
|
offset_bottom = 31.0
|
||||||
|
size_flags_horizontal = 4
|
||||||
|
size_flags_vertical = 0
|
||||||
|
|
||||||
|
[node name="Play" type="CheckButton" parent="Window/VBox/Tab/Music/HBox"]
|
||||||
|
offset_right = 230.0
|
||||||
|
offset_bottom = 31.0
|
||||||
|
button_pressed = true
|
||||||
|
text = "MUSIC_MANAGER/PLAY"
|
||||||
|
|
||||||
|
[node name="Random" type="CheckButton" parent="Window/VBox/Tab/Music/HBox"]
|
||||||
|
offset_left = 234.0
|
||||||
|
offset_right = 498.0
|
||||||
|
offset_bottom = 31.0
|
||||||
|
button_pressed = true
|
||||||
|
text = "MUSIC_MANAGER/RANDOM"
|
||||||
|
|
||||||
|
[node name="Reinit" type="Button" parent="Window/VBox/Tab/Music/HBox"]
|
||||||
|
offset_left = 502.0
|
||||||
|
offset_right = 704.0
|
||||||
|
offset_bottom = 31.0
|
||||||
|
text = "MUSIC_MANAGER/REINIT"
|
||||||
|
|
||||||
|
[node name="ScrollContainer" type="ScrollContainer" parent="Window/VBox/Tab/Music"]
|
||||||
|
offset_top = 35.0
|
||||||
|
offset_right = 1024.0
|
||||||
|
offset_bottom = 534.0
|
||||||
|
size_flags_vertical = 3
|
||||||
|
|
||||||
|
[node name="ListMusic" type="VBoxContainer" parent="Window/VBox/Tab/Music/ScrollContainer"]
|
||||||
|
offset_right = 1024.0
|
||||||
|
offset_bottom = 499.0
|
||||||
|
size_flags_horizontal = 3
|
||||||
|
size_flags_vertical = 3
|
||||||
|
|
||||||
|
[node name="Mixer" type="VBoxContainer" parent="Window/VBox/Tab"]
|
||||||
|
visible = false
|
||||||
|
offset_right = 40.0
|
||||||
|
offset_bottom = 40.0
|
||||||
|
|
||||||
|
[node name="GlobalLevel" type="HBoxContainer" parent="Window/VBox/Tab/Mixer"]
|
||||||
|
offset_right = 40.0
|
||||||
|
offset_bottom = 40.0
|
||||||
|
|
||||||
|
[node name="Label" type="Label" parent="Window/VBox/Tab/Mixer/GlobalLevel"]
|
||||||
|
offset_right = 40.0
|
||||||
|
offset_bottom = 23.0
|
||||||
|
size_flags_horizontal = 3
|
||||||
|
text = "MUSIC_MANAGER/GLOBAL_VOLUME"
|
||||||
|
|
||||||
|
[node name="global" type="HSlider" parent="Window/VBox/Tab/Mixer/GlobalLevel"]
|
||||||
|
offset_right = 8.0
|
||||||
|
offset_bottom = 16.0
|
||||||
|
size_flags_horizontal = 3
|
||||||
|
|
||||||
|
[node name="MusicLevel" type="HBoxContainer" parent="Window/VBox/Tab/Mixer"]
|
||||||
|
offset_right = 40.0
|
||||||
|
offset_bottom = 40.0
|
||||||
|
|
||||||
|
[node name="Label" type="Label" parent="Window/VBox/Tab/Mixer/MusicLevel"]
|
||||||
|
offset_right = 40.0
|
||||||
|
offset_bottom = 23.0
|
||||||
|
size_flags_horizontal = 3
|
||||||
|
text = "MUSIC_MANAGER/MUSIC_VOLUME"
|
||||||
|
|
||||||
|
[node name="music" type="HSlider" parent="Window/VBox/Tab/Mixer/MusicLevel"]
|
||||||
|
offset_right = 8.0
|
||||||
|
offset_bottom = 16.0
|
||||||
|
size_flags_horizontal = 3
|
||||||
|
|
||||||
|
[node name="EffectLevel" type="HBoxContainer" parent="Window/VBox/Tab/Mixer"]
|
||||||
|
offset_right = 40.0
|
||||||
|
offset_bottom = 40.0
|
||||||
|
|
||||||
|
[node name="Label" type="Label" parent="Window/VBox/Tab/Mixer/EffectLevel"]
|
||||||
|
offset_right = 40.0
|
||||||
|
offset_bottom = 23.0
|
||||||
|
size_flags_horizontal = 3
|
||||||
|
text = "MUSIC_MANAGER/EFFECT_VOLUME"
|
||||||
|
|
||||||
|
[node name="effect" type="HSlider" parent="Window/VBox/Tab/Mixer/EffectLevel"]
|
||||||
|
offset_right = 8.0
|
||||||
|
offset_bottom = 16.0
|
||||||
|
size_flags_horizontal = 3
|
||||||
|
|
||||||
|
[node name="HBoxContainer" type="HBoxContainer" parent="Window/VBox"]
|
||||||
|
offset_right = 40.0
|
||||||
|
offset_bottom = 40.0
|
||||||
|
size_flags_vertical = 8
|
||||||
|
|
||||||
|
[node name="Label" type="Label" parent="Window/VBox/HBoxContainer"]
|
||||||
|
offset_right = 40.0
|
||||||
|
offset_bottom = 23.0
|
||||||
|
size_flags_horizontal = 3
|
||||||
|
|
||||||
|
[node name="Button" type="Button" parent="Window/VBox/HBoxContainer"]
|
||||||
|
offset_left = 496.0
|
||||||
|
offset_top = 569.0
|
||||||
|
offset_right = 527.0
|
||||||
|
offset_bottom = 600.0
|
||||||
|
size_flags_horizontal = 6
|
||||||
|
size_flags_vertical = 8
|
||||||
|
text = "OK"
|
||||||
|
|
||||||
|
[node name="Mute" type="CheckButton" parent="Window/VBox/HBoxContainer"]
|
||||||
|
offset_right = 236.0
|
||||||
|
offset_bottom = 31.0
|
||||||
|
size_flags_horizontal = 10
|
||||||
|
text = "MUSIC_MANAGER/MUTE"
|
||||||
|
|
||||||
|
[connection signal="finished" from="Music" to="." method="_on_music_finished"]
|
||||||
|
[connection signal="timeout" from="EndMusic" to="." method="_on_end_music_timeout"]
|
||||||
|
[connection signal="close_requested" from="Window" to="." method="_on_window_close_requested"]
|
||||||
|
[connection signal="pressed" from="Window/VBox/Tab/Music/HBox/Play" to="." method="_on_play_pressed"]
|
||||||
|
[connection signal="pressed" from="Window/VBox/Tab/Music/HBox/Random" to="." method="_on_random_pressed"]
|
||||||
|
[connection signal="pressed" from="Window/VBox/Tab/Music/HBox/Reinit" to="." method="_on_reinit_pressed"]
|
||||||
|
[connection signal="value_changed" from="Window/VBox/Tab/Mixer/GlobalLevel/global" to="." method="_on_global_value_changed"]
|
||||||
|
[connection signal="value_changed" from="Window/VBox/Tab/Mixer/MusicLevel/music" to="." method="_on_music_value_changed"]
|
||||||
|
[connection signal="value_changed" from="Window/VBox/Tab/Mixer/EffectLevel/effect" to="." method="_on_effect_value_changed"]
|
||||||
|
[connection signal="pressed" from="Window/VBox/HBoxContainer/Button" to="." method="_on_button_pressed"]
|
||||||
|
[connection signal="toggled" from="Window/VBox/HBoxContainer/Mute" to="." method="_on_mute_toggled"]
|
||||||
|
|
|
@ -3,6 +3,11 @@ extends Node
|
||||||
|
|
||||||
var debug:bool = true
|
var debug:bool = true
|
||||||
|
|
||||||
|
|
||||||
|
func _ready():
|
||||||
|
randomize()
|
||||||
|
|
||||||
|
|
||||||
func get_time_text() -> String:
|
func get_time_text() -> String:
|
||||||
var time = Time.get_datetime_dict_from_system()
|
var time = Time.get_datetime_dict_from_system()
|
||||||
return "%s/%02d/%02d %02d:%02d:%02d" % [
|
return "%s/%02d/%02d %02d:%02d:%02d" % [
|
||||||
|
@ -124,3 +129,43 @@ func get_string_input(event) -> String:
|
||||||
return get_string_input_joypad_button(event)
|
return get_string_input_joypad_button(event)
|
||||||
else:
|
else:
|
||||||
return str(event)
|
return str(event)
|
||||||
|
|
||||||
|
func get_input_plus_event(action:String, event_ref):
|
||||||
|
if InputMap.has_action(action + "_PLUS"):
|
||||||
|
for z in InputMap.action_get_events(action + "_PLUS"):
|
||||||
|
if typeof(event_ref) == typeof(z):
|
||||||
|
return " & " + tr(Common.get_string_input(z))
|
||||||
|
return ""
|
||||||
|
|
||||||
|
|
||||||
|
func get_input_plus(action:String):
|
||||||
|
var comment:String = "None"
|
||||||
|
if InputMap.has_action(action):
|
||||||
|
for z in InputMap.action_get_events(action):
|
||||||
|
return tr(Common.get_string_input(z)) + get_input_plus_event(action, z)
|
||||||
|
# Common.msg_debug(comment)
|
||||||
|
# #$Window/Tab/MOUSE/HBox/SelectButton.set_text(text1)
|
||||||
|
# break
|
||||||
|
# if InputMap.has_action(action + "_PLUS"):
|
||||||
|
# for z in InputMap.action_get_events(action + "_PLUS"):
|
||||||
|
# if z is InputEventMouseButton:
|
||||||
|
# comment = comment + " & " + tr(Common.get_string_input(z))
|
||||||
|
# Common.msg_debug(comment)
|
||||||
|
# break
|
||||||
|
return comment
|
||||||
|
|
||||||
|
func set_input(action:String, event, eraselast:bool):
|
||||||
|
if eraselast:
|
||||||
|
for curaction in InputMap.get_actions():
|
||||||
|
var text:String = curaction
|
||||||
|
if text == action:
|
||||||
|
for z in InputMap.action_get_events(curaction):
|
||||||
|
if typeof(event) == typeof(z):
|
||||||
|
InputMap.action_erase_event(text, z)
|
||||||
|
InputMap.action_add_event(action, event)
|
||||||
|
|
||||||
|
|
||||||
|
func set_input_plus(action:String, event, eventplus, eraselast:bool):
|
||||||
|
set_input(action, event, eraselast)
|
||||||
|
set_input(action + "_PLUS", eventplus, eraselast)
|
||||||
|
|
||||||
|
|
|
@ -7,7 +7,7 @@ declare FORCE=0
|
||||||
declare IMPORT=0
|
declare IMPORT=0
|
||||||
declare ERASEIMPORT=0
|
declare ERASEIMPORT=0
|
||||||
declare WORKDIR="$(dirname $(readlink -f $0))"
|
declare WORKDIR="$(dirname $(readlink -f $0))"
|
||||||
declare GODOT_SRC="https://downloads.tuxfamily.org/godotengine/4.0/alpha5/Godot_v4.0-alpha5_linux.64.zip"
|
declare GODOT_SRC="https://downloads.tuxfamily.org/godotengine/4.0/alpha6/Godot_v4.0-alpha6_linux.64.zip"
|
||||||
declare OUTZIP="$WORKDIR/$(basename $GODOT_SRC)"
|
declare OUTZIP="$WORKDIR/$(basename $GODOT_SRC)"
|
||||||
declare OPTION=""
|
declare OPTION=""
|
||||||
declare NEWPRG=0
|
declare NEWPRG=0
|
||||||
|
@ -139,7 +139,9 @@ fi
|
||||||
|
|
||||||
if [[ ($IMPORT -ne 0) || (! -d $WORKDIR/.godot) ]]
|
if [[ ($IMPORT -ne 0) || (! -d $WORKDIR/.godot) ]]
|
||||||
then
|
then
|
||||||
|
echo "Launch import (please wait)"
|
||||||
$WORKDIR/$EXE --editor --quit
|
$WORKDIR/$EXE --editor --quit
|
||||||
|
echo "Import finished"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ $EDITOR -ne 0 ]
|
if [ $EDITOR -ne 0 ]
|
||||||
|
|
Loading…
Reference in a new issue