mirror of
https://github.com/CrispyPin/ovr-utils.git
synced 2024-11-22 07:30:25 +01:00
overlay visibility is saved and loaded
This commit is contained in:
parent
e50f85d970
commit
6385d7c165
5 changed files with 37 additions and 10 deletions
|
@ -39,6 +39,7 @@ alignment = 2
|
||||||
margin_left = 952.0
|
margin_left = 952.0
|
||||||
margin_right = 1128.0
|
margin_right = 1128.0
|
||||||
margin_bottom = 191.0
|
margin_bottom = 191.0
|
||||||
|
focus_mode = 0
|
||||||
toggle_mode = true
|
toggle_mode = true
|
||||||
icon = ExtResource( 5 )
|
icon = ExtResource( 5 )
|
||||||
|
|
||||||
|
@ -46,12 +47,14 @@ icon = ExtResource( 5 )
|
||||||
margin_left = 1132.0
|
margin_left = 1132.0
|
||||||
margin_right = 1308.0
|
margin_right = 1308.0
|
||||||
margin_bottom = 191.0
|
margin_bottom = 191.0
|
||||||
|
focus_mode = 0
|
||||||
icon = ExtResource( 6 )
|
icon = ExtResource( 6 )
|
||||||
|
|
||||||
[node name="Target" type="OptionButton" parent="HBoxContainer"]
|
[node name="Target" type="OptionButton" parent="HBoxContainer"]
|
||||||
margin_left = 1312.0
|
margin_left = 1312.0
|
||||||
margin_right = 1492.0
|
margin_right = 1492.0
|
||||||
margin_bottom = 191.0
|
margin_bottom = 191.0
|
||||||
|
focus_mode = 0
|
||||||
text = "Left"
|
text = "Left"
|
||||||
icon = ExtResource( 8 )
|
icon = ExtResource( 8 )
|
||||||
clip_text = true
|
clip_text = true
|
||||||
|
@ -62,6 +65,7 @@ selected = 1
|
||||||
margin_left = 1496.0
|
margin_left = 1496.0
|
||||||
margin_right = 1672.0
|
margin_right = 1672.0
|
||||||
margin_bottom = 191.0
|
margin_bottom = 191.0
|
||||||
|
focus_mode = 0
|
||||||
toggle_mode = true
|
toggle_mode = true
|
||||||
icon = ExtResource( 7 )
|
icon = ExtResource( 7 )
|
||||||
|
|
||||||
|
@ -69,6 +73,7 @@ icon = ExtResource( 7 )
|
||||||
margin_left = 1676.0
|
margin_left = 1676.0
|
||||||
margin_right = 1852.0
|
margin_right = 1852.0
|
||||||
margin_bottom = 191.0
|
margin_bottom = 191.0
|
||||||
|
focus_mode = 0
|
||||||
toggle_mode = true
|
toggle_mode = true
|
||||||
icon = ExtResource( 4 )
|
icon = ExtResource( 4 )
|
||||||
|
|
||||||
|
@ -76,6 +81,7 @@ icon = ExtResource( 4 )
|
||||||
margin_left = 1856.0
|
margin_left = 1856.0
|
||||||
margin_right = 2032.0
|
margin_right = 2032.0
|
||||||
margin_bottom = 191.0
|
margin_bottom = 191.0
|
||||||
|
focus_mode = 0
|
||||||
toggle_mode = true
|
toggle_mode = true
|
||||||
pressed = true
|
pressed = true
|
||||||
icon = ExtResource( 2 )
|
icon = ExtResource( 2 )
|
||||||
|
|
|
@ -3,6 +3,7 @@ extends Spatial
|
||||||
signal width_changed
|
signal width_changed
|
||||||
signal offset_changed
|
signal offset_changed
|
||||||
signal target_changed
|
signal target_changed
|
||||||
|
signal overlay_visibility_changed
|
||||||
|
|
||||||
const TARGETS = ["head", "left", "right", "world"]
|
const TARGETS = ["head", "left", "right", "world"]
|
||||||
export (String, "head", "left", "right", "world") var target = "left" setget set_target
|
export (String, "head", "left", "right", "world") var target = "left" setget set_target
|
||||||
|
@ -66,17 +67,20 @@ func add_grab():
|
||||||
|
|
||||||
func load_settings():
|
func load_settings():
|
||||||
if Settings.s.overlays.has(name):
|
if Settings.s.overlays.has(name):
|
||||||
if Settings.s.overlays[name].has("fallback"):
|
var loaded = Settings.s.overlays[name]
|
||||||
fallback = Settings.s.overlays[name].fallback
|
if loaded.has("fallback"):
|
||||||
set_target(Settings.s.overlays[name].target)
|
fallback = loaded.fallback
|
||||||
|
set_target(loaded.target)
|
||||||
|
|
||||||
set_width_in_meters(Settings.s.overlays[name].width)
|
set_width_in_meters(loaded.width)
|
||||||
|
|
||||||
for t_key in Settings.s.overlays[name].offsets:
|
for t_key in loaded.offsets:
|
||||||
var t_offset = Settings.s.overlays[name].offsets[t_key]
|
var t_offset = loaded.offsets[t_key]
|
||||||
_offsets[t_key].pos = t_offset.pos
|
_offsets[t_key].pos = t_offset.pos
|
||||||
_offsets[t_key].rot = t_offset.rot
|
_offsets[t_key].rot = t_offset.rot
|
||||||
update_offset()
|
update_offset()
|
||||||
|
if loaded.has("visible"):
|
||||||
|
set_overlay_visible(loaded.visible)
|
||||||
else:
|
else:
|
||||||
#TEMP defaults (remove when dragging any overlay is possible)
|
#TEMP defaults (remove when dragging any overlay is possible)
|
||||||
set_offset(current_target, translation, transform.basis.get_rotation_quat())
|
set_offset(current_target, translation, transform.basis.get_rotation_quat())
|
||||||
|
@ -143,6 +147,9 @@ func update_current_target():
|
||||||
func set_overlay_visible(state: bool):
|
func set_overlay_visible(state: bool):
|
||||||
overlay_visible = state
|
overlay_visible = state
|
||||||
$OverlayViewport.overlay_visible = state
|
$OverlayViewport.overlay_visible = state
|
||||||
|
Settings.s.overlays[name].visible = state
|
||||||
|
emit_signal("overlay_visibility_changed", state)
|
||||||
|
save_settings()
|
||||||
|
|
||||||
|
|
||||||
func _tracker_changed(tracker_name: String, type: int, id: int):
|
func _tracker_changed(tracker_name: String, type: int, id: int):
|
||||||
|
|
|
@ -20,6 +20,11 @@ const DEF = {
|
||||||
"type": "string",
|
"type": "string",
|
||||||
"default": "UI_demo"
|
"default": "UI_demo"
|
||||||
},
|
},
|
||||||
|
"visible": {
|
||||||
|
"name": "Overlay Visible",
|
||||||
|
"type": "bool",
|
||||||
|
"default": true
|
||||||
|
},
|
||||||
"width": {
|
"width": {
|
||||||
"name": "Width (m)",
|
"name": "Width (m)",
|
||||||
"type": "number",
|
"type": "number",
|
||||||
|
@ -61,6 +66,7 @@ const DEF = {
|
||||||
"default": {
|
"default": {
|
||||||
"MainOverlay": {
|
"MainOverlay": {
|
||||||
"type": "MainOverlay",
|
"type": "MainOverlay",
|
||||||
|
"visible": true,
|
||||||
"width": 0.4,
|
"width": 0.4,
|
||||||
"target": "left",
|
"target": "left",
|
||||||
"fallback": ["left", "right", "head"],
|
"fallback": ["left", "right", "head"],
|
||||||
|
|
|
@ -7,14 +7,11 @@ func _ready() -> void:
|
||||||
overlay = get_node("/root/Main/OverlayManager").get_node(overlay_name)
|
overlay = get_node("/root/Main/OverlayManager").get_node(overlay_name)
|
||||||
$Label.text = overlay_name
|
$Label.text = overlay_name
|
||||||
$HBoxContainer/Target.selected = overlay.TARGETS.find(overlay.target)
|
$HBoxContainer/Target.selected = overlay.TARGETS.find(overlay.target)
|
||||||
|
overlay.connect("overlay_visibility_changed", self, "_overlay_visibility_changed")
|
||||||
|
|
||||||
|
|
||||||
func _on_Visibility_toggled(state: bool) -> void:
|
func _on_Visibility_toggled(state: bool) -> void:
|
||||||
overlay.overlay_visible = state
|
overlay.overlay_visible = state
|
||||||
if state:
|
|
||||||
$HBoxContainer/Visibility.icon = preload("res://icons/visible.svg")
|
|
||||||
else:
|
|
||||||
$HBoxContainer/Visibility.icon = preload("res://icons/hidden.svg")
|
|
||||||
|
|
||||||
|
|
||||||
func _on_Target_item_selected(index: int) -> void:
|
func _on_Target_item_selected(index: int) -> void:
|
||||||
|
@ -27,3 +24,11 @@ func _on_Reset_pressed() -> void:
|
||||||
|
|
||||||
func _on_Grab_toggled(state: bool) -> void:
|
func _on_Grab_toggled(state: bool) -> void:
|
||||||
overlay.get_node("OverlayInteraction").grab_mode = state
|
overlay.get_node("OverlayInteraction").grab_mode = state
|
||||||
|
|
||||||
|
|
||||||
|
func _overlay_visibility_changed(state: bool):
|
||||||
|
$HBoxContainer/Visibility.pressed = state
|
||||||
|
if state:
|
||||||
|
$HBoxContainer/Visibility.icon = preload("res://icons/visible.svg")
|
||||||
|
else:
|
||||||
|
$HBoxContainer/Visibility.icon = preload("res://icons/hidden.svg")
|
||||||
|
|
|
@ -47,6 +47,7 @@ __meta__ = {
|
||||||
[node name="GrabMode" type="Button" parent="VSplitContainer/MainBar"]
|
[node name="GrabMode" type="Button" parent="VSplitContainer/MainBar"]
|
||||||
margin_right = 176.0
|
margin_right = 176.0
|
||||||
margin_bottom = 191.0
|
margin_bottom = 191.0
|
||||||
|
focus_mode = 0
|
||||||
toggle_mode = true
|
toggle_mode = true
|
||||||
icon = ExtResource( 5 )
|
icon = ExtResource( 5 )
|
||||||
|
|
||||||
|
@ -54,6 +55,7 @@ icon = ExtResource( 5 )
|
||||||
margin_left = 180.0
|
margin_left = 180.0
|
||||||
margin_right = 356.0
|
margin_right = 356.0
|
||||||
margin_bottom = 191.0
|
margin_bottom = 191.0
|
||||||
|
focus_mode = 0
|
||||||
toggle_mode = true
|
toggle_mode = true
|
||||||
icon = ExtResource( 6 )
|
icon = ExtResource( 6 )
|
||||||
|
|
||||||
|
@ -61,6 +63,7 @@ icon = ExtResource( 6 )
|
||||||
margin_left = 360.0
|
margin_left = 360.0
|
||||||
margin_right = 536.0
|
margin_right = 536.0
|
||||||
margin_bottom = 191.0
|
margin_bottom = 191.0
|
||||||
|
focus_mode = 0
|
||||||
icon = ExtResource( 4 )
|
icon = ExtResource( 4 )
|
||||||
|
|
||||||
[connection signal="toggled" from="VSplitContainer/MainBar/GrabMode" to="." method="_on_GrabMode_toggled"]
|
[connection signal="toggled" from="VSplitContainer/MainBar/GrabMode" to="." method="_on_GrabMode_toggled"]
|
||||||
|
|
Loading…
Reference in a new issue