mirror of
https://github.com/Relintai/pandemonium_demo_projects.git
synced 2025-01-04 14:49:41 +01:00
129 lines
4.8 KiB
GDScript
129 lines
4.8 KiB
GDScript
extends Control
|
|
|
|
# Joypads demo, written by Dana Olson <dana@shineuponthee.com>
|
|
#
|
|
# This is a demo of joypad support, and doubles as a testing application
|
|
# inspired by and similar to jstest-gtk.
|
|
#
|
|
# Licensed under the MIT license
|
|
|
|
const DEADZONE = 0.2
|
|
const FONT_COLOR_DEFAULT = Color(1.0, 1.0, 1.0, 0.5)
|
|
const FONT_COLOR_ACTIVE = Color.white
|
|
|
|
var joy_num
|
|
var cur_joy = -1
|
|
var axis_value
|
|
|
|
onready var axes = $Axes
|
|
onready var button_grid = $Buttons/ButtonGrid
|
|
onready var joypad_axes = $JoypadDiagram/Axes
|
|
onready var joypad_buttons = $JoypadDiagram/Buttons
|
|
onready var joypad_name = $DeviceInfo/JoyName
|
|
onready var joypad_number = $DeviceInfo/JoyNumber
|
|
|
|
func _ready():
|
|
set_physics_process(true)
|
|
Input.connect("joy_connection_changed", self, "_on_joy_connection_changed")
|
|
# Guide button, not supported <= 3.2.3, so manually hide to account for that case.
|
|
joypad_buttons.get_child(16).hide()
|
|
|
|
|
|
func _process(_delta):
|
|
# Get the joypad device number from the spinbox.
|
|
joy_num = joypad_number.get_value()
|
|
|
|
# Display the name of the joypad if we haven't already.
|
|
if joy_num != cur_joy:
|
|
cur_joy = joy_num
|
|
joypad_name.set_text(Input.get_joy_name(joy_num) + "\n" + Input.get_joy_guid(joy_num))
|
|
|
|
# Loop through the axes and show their current values.
|
|
for axis in range(int(min(JOY_AXIS_MAX, 11))):
|
|
axis_value = Input.get_joy_axis(joy_num, axis)
|
|
axes.get_node("Axis" + str(axis) + "/ProgressBar").set_value(100 * axis_value)
|
|
axes.get_node("Axis" + str(axis) + "/ProgressBar/Value").set_text(str(axis_value))
|
|
# Scaled value used for alpha channel using valid range rather than including unusable deadzone values.
|
|
var scaled_alpha_value = (abs(axis_value) - DEADZONE) / (1.0 - DEADZONE)
|
|
# Show joypad direction indicators
|
|
if axis <= JOY_ANALOG_RY:
|
|
if abs(axis_value) < DEADZONE:
|
|
joypad_axes.get_node(str(axis) + "+").hide()
|
|
joypad_axes.get_node(str(axis) + "-").hide()
|
|
elif axis_value > 0:
|
|
joypad_axes.get_node(str(axis) + "+").show()
|
|
joypad_axes.get_node(str(axis) + "-").hide()
|
|
# Transparent white modulate, non-alpha color channels are not changed here.
|
|
joypad_axes.get_node(str(axis) + "+").self_modulate.a = scaled_alpha_value
|
|
else:
|
|
joypad_axes.get_node(str(axis) + "+").hide()
|
|
joypad_axes.get_node(str(axis) + "-").show()
|
|
# Transparent white modulate, non-alpha color channels are not changed here.
|
|
joypad_axes.get_node(str(axis) + "-").self_modulate.a = scaled_alpha_value
|
|
elif axis == JOY_ANALOG_L2:
|
|
if axis_value <= DEADZONE:
|
|
joypad_buttons.get_child(JOY_ANALOG_L2).hide()
|
|
else:
|
|
joypad_buttons.get_child(JOY_ANALOG_L2).show()
|
|
# Transparent white modulate, non-alpha color channels are not changed here.
|
|
joypad_buttons.get_child(JOY_ANALOG_L2).self_modulate.a = scaled_alpha_value
|
|
elif axis == JOY_ANALOG_R2:
|
|
if axis_value <= DEADZONE:
|
|
joypad_buttons.get_child(JOY_ANALOG_R2).hide()
|
|
else:
|
|
joypad_buttons.get_child(JOY_ANALOG_R2).show()
|
|
# Transparent white modulate, non-alpha color channels are not changed here.
|
|
joypad_buttons.get_child(JOY_ANALOG_R2).self_modulate.a = scaled_alpha_value
|
|
|
|
# Highlight axis labels that are within the "active" value range. Simular to the button highlighting for loop below.
|
|
axes.get_node("Axis" + str(axis) + "/Label").add_theme_color_override("font_color", FONT_COLOR_DEFAULT)
|
|
if abs(axis_value) >= DEADZONE:
|
|
axes.get_node("Axis" + str(axis) + "/Label").add_theme_color_override("font_color", FONT_COLOR_ACTIVE)
|
|
|
|
# Loop through the buttons and highlight the ones that are pressed.
|
|
for btn in range(JOY_BUTTON_0, int(min(JOY_BUTTON_MAX, 24))):
|
|
if Input.is_joy_button_pressed(joy_num, btn):
|
|
button_grid.get_child(btn).add_theme_color_override("font_color", FONT_COLOR_ACTIVE)
|
|
if btn < 17 and btn != JOY_ANALOG_L2 and btn != JOY_ANALOG_R2:
|
|
joypad_buttons.get_child(btn).show()
|
|
else:
|
|
button_grid.get_child(btn).add_theme_color_override("font_color", FONT_COLOR_DEFAULT)
|
|
if btn < 17 and btn != JOY_ANALOG_L2 and btn != JOY_ANALOG_R2:
|
|
joypad_buttons.get_child(btn).hide()
|
|
|
|
|
|
# Called whenever a joypad has been connected or disconnected.
|
|
func _on_joy_connection_changed(device_id, connected):
|
|
if device_id == cur_joy:
|
|
if connected:
|
|
joypad_name.set_text(Input.get_joy_name(device_id) + "\n" + Input.get_joy_guid(device_id))
|
|
else:
|
|
joypad_name.set_text("")
|
|
|
|
|
|
func _on_start_vibration_pressed():
|
|
var weak = $Vibration/Weak/Value.get_value()
|
|
var strong = $Vibration/Strong/Value.get_value()
|
|
var duration = $Vibration/Duration/Value.get_value()
|
|
Input.start_joy_vibration(cur_joy, weak, strong, duration)
|
|
|
|
|
|
func _on_stop_vibration_pressed():
|
|
Input.stop_joy_vibration(cur_joy)
|
|
|
|
|
|
func _on_Remap_pressed():
|
|
$RemapWizard.start(cur_joy)
|
|
|
|
|
|
func _on_Clear_pressed():
|
|
var guid = Input.get_joy_guid(cur_joy)
|
|
if guid.empty():
|
|
printerr("No gamepad selected")
|
|
return
|
|
Input.remove_joy_mapping(guid)
|
|
|
|
|
|
func _on_Show_pressed():
|
|
$RemapWizard.show_map()
|