Bläddra i källkod

Input mapping: Add code to load/save config

Rémi Verschelde 8 år sedan
förälder
incheckning
71e832089d

+ 54 - 8
gui/input_mapping/controls.gd

@@ -1,4 +1,3 @@
-
 extends Control
 
 # Note for the reader:
@@ -12,12 +11,56 @@ extends Control
 # action and the node, e.g.:
 # button.connect("pressed", self, "wait_for_input", [ button, action ])
 
+# Constants
+const INPUT_ACTIONS = [ "move_up", "move_down", "move_left", "move_right", "jump" ]
+const CONFIG_FILE = "user://input.cfg"
+
 # Member variables
-var player_actions = [ "move_up", "move_down", "move_left", "move_right", "jump" ]
 var action # To register the action the UI is currently handling
 var button # Button node corresponding to the above action
 
 
+# Load/save input mapping to a config file
+# Changes done while testing the demo will be persistent, saved to CONFIG_FILE
+
+func load_config():
+	var config = ConfigFile.new()
+	var err = config.load(CONFIG_FILE)
+	if err: # Assuming that file is missing, generate default config
+		for action_name in INPUT_ACTIONS:
+			var action_list = InputMap.get_action_list(action_name)
+			# There could be multiple actions in the list, but we save the first one by default
+			var scancode = OS.get_scancode_string(action_list[0].scancode)
+			config.set_value("input", action_name, scancode)
+		config.save(CONFIG_FILE)
+	else: # ConfigFile was properly loaded, initialize InputMap
+		for action_name in config.get_section_keys("input"):
+			# Get the key scancode corresponding to the saved human-readable string
+			var scancode = OS.find_scancode_from_string(config.get_value("input", action_name))
+			# Create a new event object based on the saved scancode
+			var event = InputEvent()
+			event.type = InputEvent.KEY
+			event.scancode = scancode
+			# Replace old action (key) events by the new one
+			for old_event in InputMap.get_action_list(action_name):
+				if old_event.type == InputEvent.KEY:
+					InputMap.action_erase_event(action_name, old_event)
+			InputMap.action_add_event(action_name, event)
+
+
+func save_to_config(section, key, value):
+	"""Helper function to redefine a parameter in the settings file"""
+	var config = ConfigFile.new()
+	var err = config.load(CONFIG_FILE)
+	if err:
+		print("Error code when loading config file: ", err)
+	else:
+		config.set_value(section, key, value)
+		config.save(CONFIG_FILE)
+
+
+# Input management
+
 func wait_for_input(action_bind):
 	action = action_bind
 	# See note at the beginning of the script
@@ -28,28 +71,31 @@ func wait_for_input(action_bind):
 
 func _input(event):
 	# Handle the first pressed key
-	if (event.type == InputEvent.KEY):
+	if event.type == InputEvent.KEY:
 		# Register the event as handled and stop polling
 		get_tree().set_input_as_handled()
 		set_process_input(false)
 		# Reinitialise the contextual help label
 		get_node("contextual_help").set_text("Click a key binding to reassign it, or press the Cancel action.")
-		if (not event.is_action("ui_cancel")):
+		if not event.is_action("ui_cancel"):
 			# Display the string corresponding to the pressed key
-			button.set_text(OS.get_scancode_string(event.scancode))
+			var scancode = OS.get_scancode_string(event.scancode)
+			button.set_text(scancode)
 			# Start by removing previously key binding(s)
 			for old_event in InputMap.get_action_list(action):
 				InputMap.action_erase_event(action, old_event)
 			# Add the new key binding
 			InputMap.action_add_event(action, event)
+			save_to_config("input", action, scancode)
 
 
 func _ready():
+	# Load config if existing, if not it will be generated with default values
+	load_config()
 	# Initialise each button with the default key binding from InputMap
-	var input_event
-	for action in player_actions:
+	for action in INPUT_ACTIONS:
 		# We assume that the key binding that we want is the first one (0), if there are several
-		input_event = InputMap.get_action_list(action)[0]
+		var input_event = InputMap.get_action_list(action)[0]
 		# See note at the beginning of the script
 		var button = get_node("bindings").get_node(action).get_node("Button")
 		button.set_text(OS.get_scancode_string(input_event.scancode))

BIN
gui/input_mapping/controls.scn


+ 251 - 0
gui/input_mapping/controls.tscn

@@ -0,0 +1,251 @@
+[gd_scene load_steps=2 format=1]
+
+[ext_resource path="res://controls.gd" type="Script" id=1]
+
+[node name="controls_ui" type="Control"]
+
+focus/ignore_mouse = false
+focus/stop_mouse = true
+size_flags/horizontal = 2
+size_flags/vertical = 2
+margin/left = 0.0
+margin/top = 0.0
+margin/right = 40.0
+margin/bottom = 40.0
+script/script = ExtResource( 1 )
+__meta__ = {
+"__editor_plugin_screen__": "2D"
+}
+
+[node name="contextual_help" type="Label" parent="."]
+
+focus/ignore_mouse = true
+focus/stop_mouse = true
+size_flags/horizontal = 2
+size_flags/vertical = 0
+margin/left = 100.0
+margin/top = 50.0
+margin/right = 465.0
+margin/bottom = 89.0
+text = "Click on a key binding to reassign it, or press the Cancel action."
+percent_visible = 1.0
+lines_skipped = 0
+max_lines_visible = -1
+
+[node name="bindings" type="Control" parent="."]
+
+focus/ignore_mouse = false
+focus/stop_mouse = true
+size_flags/horizontal = 2
+size_flags/vertical = 2
+margin/left = 50.0
+margin/top = 50.0
+margin/right = 90.0
+margin/bottom = 90.0
+
+[node name="move_up" type="Control" parent="bindings"]
+
+focus/ignore_mouse = false
+focus/stop_mouse = true
+size_flags/horizontal = 2
+size_flags/vertical = 2
+margin/left = 50.0
+margin/top = 50.0
+margin/right = 90.0
+margin/bottom = 90.0
+
+[node name="Label" type="Label" parent="bindings/move_up"]
+
+focus/ignore_mouse = true
+focus/stop_mouse = true
+size_flags/horizontal = 2
+size_flags/vertical = 0
+margin/left = 5.0
+margin/top = 8.0
+margin/right = 45.0
+margin/bottom = 21.0
+text = "Up"
+percent_visible = 1.0
+lines_skipped = 0
+max_lines_visible = -1
+
+[node name="Button" type="Button" parent="bindings/move_up"]
+
+focus/ignore_mouse = false
+focus/stop_mouse = true
+size_flags/horizontal = 2
+size_flags/vertical = 2
+margin/left = 84.0
+margin/top = -1.0
+margin/right = 144.0
+margin/bottom = 29.0
+toggle_mode = false
+enabled_focus_mode = 2
+shortcut = null
+flat = false
+
+[node name="move_down" type="Control" parent="bindings"]
+
+focus/ignore_mouse = false
+focus/stop_mouse = true
+size_flags/horizontal = 2
+size_flags/vertical = 2
+margin/left = 50.0
+margin/top = 100.0
+margin/right = 90.0
+margin/bottom = 140.0
+
+[node name="Label" type="Label" parent="bindings/move_down"]
+
+focus/ignore_mouse = true
+focus/stop_mouse = true
+size_flags/horizontal = 2
+size_flags/vertical = 0
+margin/left = 5.0
+margin/top = 8.0
+margin/right = 45.0
+margin/bottom = 21.0
+text = "Down"
+percent_visible = 1.0
+lines_skipped = 0
+max_lines_visible = -1
+
+[node name="Button" type="Button" parent="bindings/move_down"]
+
+focus/ignore_mouse = false
+focus/stop_mouse = true
+size_flags/horizontal = 2
+size_flags/vertical = 2
+margin/left = 84.0
+margin/top = -1.0
+margin/right = 144.0
+margin/bottom = 29.0
+toggle_mode = false
+enabled_focus_mode = 2
+shortcut = null
+flat = false
+
+[node name="move_left" type="Control" parent="bindings"]
+
+focus/ignore_mouse = false
+focus/stop_mouse = true
+size_flags/horizontal = 2
+size_flags/vertical = 2
+margin/left = 50.0
+margin/top = 150.0
+margin/right = 90.0
+margin/bottom = 190.0
+
+[node name="Label" type="Label" parent="bindings/move_left"]
+
+focus/ignore_mouse = true
+focus/stop_mouse = true
+size_flags/horizontal = 2
+size_flags/vertical = 0
+margin/left = 5.0
+margin/top = 8.0
+margin/right = 45.0
+margin/bottom = 21.0
+text = "Left"
+percent_visible = 1.0
+lines_skipped = 0
+max_lines_visible = -1
+
+[node name="Button" type="Button" parent="bindings/move_left"]
+
+focus/ignore_mouse = false
+focus/stop_mouse = true
+size_flags/horizontal = 2
+size_flags/vertical = 2
+margin/left = 84.0
+margin/top = -1.0
+margin/right = 144.0
+margin/bottom = 29.0
+toggle_mode = false
+enabled_focus_mode = 2
+shortcut = null
+flat = false
+
+[node name="move_right" type="Control" parent="bindings"]
+
+focus/ignore_mouse = false
+focus/stop_mouse = true
+size_flags/horizontal = 2
+size_flags/vertical = 2
+margin/left = 50.0
+margin/top = 200.0
+margin/right = 90.0
+margin/bottom = 240.0
+
+[node name="Label" type="Label" parent="bindings/move_right"]
+
+focus/ignore_mouse = true
+focus/stop_mouse = true
+size_flags/horizontal = 2
+size_flags/vertical = 0
+margin/left = 5.0
+margin/top = 8.0
+margin/right = 45.0
+margin/bottom = 21.0
+text = "Right"
+percent_visible = 1.0
+lines_skipped = 0
+max_lines_visible = -1
+
+[node name="Button" type="Button" parent="bindings/move_right"]
+
+focus/ignore_mouse = false
+focus/stop_mouse = true
+size_flags/horizontal = 2
+size_flags/vertical = 2
+margin/left = 84.0
+margin/top = -1.0
+margin/right = 144.0
+margin/bottom = 29.0
+toggle_mode = false
+enabled_focus_mode = 2
+shortcut = null
+flat = false
+
+[node name="jump" type="Control" parent="bindings"]
+
+focus/ignore_mouse = false
+focus/stop_mouse = true
+size_flags/horizontal = 2
+size_flags/vertical = 2
+margin/left = 50.0
+margin/top = 250.0
+margin/right = 90.0
+margin/bottom = 290.0
+
+[node name="Label" type="Label" parent="bindings/jump"]
+
+focus/ignore_mouse = true
+focus/stop_mouse = true
+size_flags/horizontal = 2
+size_flags/vertical = 0
+margin/left = 5.0
+margin/top = 8.0
+margin/right = 45.0
+margin/bottom = 21.0
+text = "Jump"
+percent_visible = 1.0
+lines_skipped = 0
+max_lines_visible = -1
+
+[node name="Button" type="Button" parent="bindings/jump"]
+
+focus/ignore_mouse = false
+focus/stop_mouse = true
+size_flags/horizontal = 2
+size_flags/vertical = 2
+margin/left = 84.0
+margin/top = -1.0
+margin/right = 144.0
+margin/bottom = 29.0
+toggle_mode = false
+enabled_focus_mode = 2
+shortcut = null
+flat = false
+
+

+ 1 - 1
gui/input_mapping/engine.cfg

@@ -1,7 +1,7 @@
 [application]
 
 name="Input Mapping GUI"
-main_scene="res://controls.scn"
+main_scene="res://controls.tscn"
 icon="res://icon.png"
 
 [display]