From 95ed8ef7a7f34580a0db4bc6ba27370ccecfa128 Mon Sep 17 00:00:00 2001 From: Relintai Date: Tue, 2 Jan 2024 12:07:55 +0100 Subject: [PATCH] Added a new App Web interface demo. --- web/app_web_interface/ColorSetButton.gd | 8 ++ web/app_web_interface/MainScene.gd | 13 ++++ web/app_web_interface/MainScene.tscn | 87 ++++++++++++++++++++++ web/app_web_interface/WebInterface.gd | 63 ++++++++++++++++ web/app_web_interface/default_env.tres | 7 ++ web/app_web_interface/icon.png | Bin 0 -> 3218 bytes web/app_web_interface/icon.png.import | 35 +++++++++ web/app_web_interface/project.pandemonium | 25 +++++++ 8 files changed, 238 insertions(+) create mode 100644 web/app_web_interface/ColorSetButton.gd create mode 100644 web/app_web_interface/MainScene.gd create mode 100644 web/app_web_interface/MainScene.tscn create mode 100644 web/app_web_interface/WebInterface.gd create mode 100644 web/app_web_interface/default_env.tres create mode 100644 web/app_web_interface/icon.png create mode 100644 web/app_web_interface/icon.png.import create mode 100644 web/app_web_interface/project.pandemonium diff --git a/web/app_web_interface/ColorSetButton.gd b/web/app_web_interface/ColorSetButton.gd new file mode 100644 index 0000000..7d768e7 --- /dev/null +++ b/web/app_web_interface/ColorSetButton.gd @@ -0,0 +1,8 @@ +extends Button + +export(NodePath) var target_node : NodePath + +func _on_ColorSetButton_pressed() -> void: + var color : Color = get_parent().get_node("ColorPickerButton").color + + get_node(target_node).set_color(color) diff --git a/web/app_web_interface/MainScene.gd b/web/app_web_interface/MainScene.gd new file mode 100644 index 0000000..792a348 --- /dev/null +++ b/web/app_web_interface/MainScene.gd @@ -0,0 +1,13 @@ +extends Node + +export(NodePath) var color_picker_path + +func get_color() -> Color: + var style_box : StyleBoxFlat = get_node(^"PanelContainer").get_theme_stylebox("panel") + return style_box.bg_color + +func set_color(color : Color): + var style_box : StyleBoxFlat = get_node(^"PanelContainer").get_theme_stylebox("panel") + style_box.bg_color = color + + get_node(color_picker_path).color = color diff --git a/web/app_web_interface/MainScene.tscn b/web/app_web_interface/MainScene.tscn new file mode 100644 index 0000000..229997d --- /dev/null +++ b/web/app_web_interface/MainScene.tscn @@ -0,0 +1,87 @@ +[gd_scene load_steps=6 format=2] + +[ext_resource path="res://ColorSetButton.gd" type="Script" id=1] +[ext_resource path="res://WebInterface.gd" type="Script" id=2] +[ext_resource path="res://MainScene.gd" type="Script" id=3] + +[sub_resource type="StyleBoxFlat" id=1] +bg_color = Color( 0, 0, 0, 1 ) + +[sub_resource type="StyleBoxFlat" id=2] +bg_color = Color( 1, 1, 1, 1 ) + +[node name="MainScene" type="Node"] +script = ExtResource( 3 ) +color_picker_path = NodePath("PanelContainer/VBoxContainer/PanelContainer/MarginContainer/HBoxContainer/ColorPickerButton") + +[node name="WebServerSimple" type="WebServerSimple" parent="."] +start_on_ready = true + +[node name="WebInterface" type="WebNode" parent="WebServerSimple"] +script = ExtResource( 2 ) +target_node = NodePath("../..") + +[node name="PanelContainer" type="PanelContainer" parent="."] +anchor_right = 1.0 +anchor_bottom = 1.0 +custom_styles/panel = SubResource( 1 ) + +[node name="VBoxContainer" type="VBoxContainer" parent="PanelContainer"] +margin_right = 1024.0 +margin_bottom = 600.0 + +[node name="LinkButton" type="LinkButton" parent="PanelContainer/VBoxContainer"] +margin_left = 359.0 +margin_right = 665.0 +margin_bottom = 14.0 +size_flags_horizontal = 4 +text = "Open the web interface at http://127.0.0.1:8080" +uri = "http://127.0.0.1:8080" + +[node name="PanelContainer" type="PanelContainer" parent="PanelContainer/VBoxContainer"] +margin_left = 418.0 +margin_top = 289.0 +margin_right = 606.0 +margin_bottom = 329.0 +size_flags_horizontal = 6 +size_flags_vertical = 6 +custom_styles/panel = SubResource( 2 ) + +[node name="MarginContainer" type="MarginContainer" parent="PanelContainer/VBoxContainer/PanelContainer"] +margin_right = 188.0 +margin_bottom = 40.0 +custom_constants/margin_left = 10 +custom_constants/margin_top = 10 +custom_constants/margin_right = 10 +custom_constants/margin_bottom = 10 + +[node name="HBoxContainer" type="HBoxContainer" parent="PanelContainer/VBoxContainer/PanelContainer/MarginContainer"] +margin_left = 10.0 +margin_top = 10.0 +margin_right = 178.0 +margin_bottom = 30.0 +size_flags_vertical = 0 +alignment = 1 + +[node name="Label" type="Label" parent="PanelContainer/VBoxContainer/PanelContainer/MarginContainer/HBoxContainer"] +margin_top = 3.0 +margin_right = 80.0 +margin_bottom = 17.0 +custom_colors/font_color = Color( 0, 0, 0, 1 ) +text = "Set BG Color" + +[node name="ColorPickerButton" type="ColorPickerButton" parent="PanelContainer/VBoxContainer/PanelContainer/MarginContainer/HBoxContainer"] +margin_left = 84.0 +margin_right = 132.0 +margin_bottom = 20.0 +text = " " + +[node name="ColorSetButton" type="Button" parent="PanelContainer/VBoxContainer/PanelContainer/MarginContainer/HBoxContainer"] +margin_left = 136.0 +margin_right = 168.0 +margin_bottom = 20.0 +text = "Set" +script = ExtResource( 1 ) +target_node = NodePath("../../../../../..") + +[connection signal="pressed" from="PanelContainer/VBoxContainer/PanelContainer/MarginContainer/HBoxContainer/ColorSetButton" to="PanelContainer/VBoxContainer/PanelContainer/MarginContainer/HBoxContainer/ColorSetButton" method="_on_ColorSetButton_pressed"] diff --git a/web/app_web_interface/WebInterface.gd b/web/app_web_interface/WebInterface.gd new file mode 100644 index 0000000..e4cb8a4 --- /dev/null +++ b/web/app_web_interface/WebInterface.gd @@ -0,0 +1,63 @@ +extends WebNode + +export(NodePath) var target_node : NodePath + +func _handle_request(request: WebServerRequest) -> void: + if request.get_method() == HTTPServerEnums.HTTP_METHOD_POST: + var cs : String = request.get_post_parameter("bg_color") + + if cs.is_valid_html_color(): + var c : Color = Color(cs) + get_node(target_node).set_color(c) + + var color : Color = get_node(target_node).get_color() + + var b : HTMLBuilder = HTMLBuilder.new() + + b.style() + b.w("body { background-color: #%s; }" % [ color.to_html(false) ]) + b.w(".content {") + b.w("width: 200px;") + b.w("margin-left: auto;") + b.w("margin-right: auto;") + b.w("text-align: center;") + b.w("margin-top: 360px;") + b.w("background-color: white;") + b.w("padding: 10px;") + b.w("}") + b.cstyle() + + b.write_tag() + + request.head += b.result + + b.result = "" + + b.div("content") + + b.a("/").f().w("Refresh").ca() + b.br() + b.br() + + b.form_post("/") + + if true: # Scope for better separation + b.label().fora("bg_color") + b.w("Set BG Color ") + b.clabel() + + b.input_color("bg_color", "#" + color.to_html(false), "", "bg_color") + b.br() + b.br() + b.input_submit("Set") + + b.cform() + + b.cdiv() + + b.write_tag() + + request.body += b.result + + request.compile_and_send_body() + diff --git a/web/app_web_interface/default_env.tres b/web/app_web_interface/default_env.tres new file mode 100644 index 0000000..4f08e8f --- /dev/null +++ b/web/app_web_interface/default_env.tres @@ -0,0 +1,7 @@ +[gd_resource type="Environment3D" load_steps=2 format=2] + +[sub_resource type="ProceduralSky" id=1] + +[resource] +background_mode = 2 +background_sky = SubResource( 1 ) diff --git a/web/app_web_interface/icon.png b/web/app_web_interface/icon.png new file mode 100644 index 0000000000000000000000000000000000000000..87f1f7549e0489d0758939152cd1f879f1e653b5 GIT binary patch literal 3218 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 literal 0 HcmV?d00001 diff --git a/web/app_web_interface/icon.png.import b/web/app_web_interface/icon.png.import new file mode 100644 index 0000000..a4c02e6 --- /dev/null +++ b/web/app_web_interface/icon.png.import @@ -0,0 +1,35 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/icon.png-487276ed1e3a0c39cad0279d744ee560.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://icon.png" +dest_files=[ "res://.import/icon.png-487276ed1e3a0c39cad0279d744ee560.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +process/normal_map_invert_y=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/web/app_web_interface/project.pandemonium b/web/app_web_interface/project.pandemonium new file mode 100644 index 0000000..59bc820 --- /dev/null +++ b/web/app_web_interface/project.pandemonium @@ -0,0 +1,25 @@ +; Engine configuration file. +; It's best edited using the editor UI and not directly, +; since the parameters that go here are not all obvious. +; +; Format: +; [section] ; section goes between [] +; param=value ; assign values to parameters + +config_version=4 + +[application] + +config/name="App Web Interface" +run/main_scene="res://MainScene.tscn" +config/icon="res://icon.png" + +[physics] + +common/enable_pause_aware_picking=true + +[rendering] + +vram_compression/import_etc=true +vram_compression/import_etc2=false +environment/default_environment="res://default_env.tres"