summaryrefslogtreecommitdiff
path: root/ui
diff options
context:
space:
mode:
authorDaniel Weipert <git@mail.dweipert.de>2025-04-07 11:45:05 +0200
committerDaniel Weipert <git@mail.dweipert.de>2025-04-07 11:45:05 +0200
commitf3d360e022fce829370c7d916abe98083b14818c (patch)
tree4ac9f886b45a9482dcd42e991e85ab2e4bea3dbc /ui
parentbd77c88efc9327805b6f6fd83fa0492ed59d0f9a (diff)
next commitHEADmain
Diffstat (limited to 'ui')
-rw-r--r--ui/chat_window.tscn12
-rw-r--r--ui/login.gd103
-rw-r--r--ui/login.tscn120
-rw-r--r--ui/login/character_creation.gd134
-rw-r--r--ui/login/character_creation.tscn304
-rw-r--r--ui/login/character_selection_item.tscn10
-rw-r--r--ui/login/login_character_selection_list.gd5
-rw-r--r--ui/login/login_character_selection_list.tscn22
-rw-r--r--ui/login/stat_entry.gd18
-rw-r--r--ui/login/stat_entry.tscn24
-rw-r--r--ui/message_window.tscn12
-rw-r--r--ui/theme.tres11
-rw-r--r--ui/theme_clear.tres2
-rw-r--r--ui/window.tscn38
14 files changed, 721 insertions, 94 deletions
diff --git a/ui/chat_window.tscn b/ui/chat_window.tscn
index b430fb8..5804fd0 100644
--- a/ui/chat_window.tscn
+++ b/ui/chat_window.tscn
@@ -1,8 +1,7 @@
-[gd_scene load_steps=5 format=3 uid="uid://c8uqw08hxfqlu"]
+[gd_scene load_steps=4 format=3 uid="uid://c8uqw08hxfqlu"]
[ext_resource type="Script" uid="uid://cy5bwkc4gokw1" path="res://ui/chat_window.gd" id="1_vovuq"]
-[ext_resource type="PackedScene" uid="uid://cjcm2mai50thr" path="res://ui/bmp_texture_button.tscn" id="2_2x3wj"]
-[ext_resource type="Texture2D" uid="uid://dqq3mtjcrwqnp" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/basic_interface/sys_base_off.bmp" id="3_smgio"]
+[ext_resource type="Texture2D" uid="uid://dwv8ca3u5xk3o" path="res://client_data/data/texture/유저인터페이스/basic_interface/sys_base_off.png" id="2_2x3wj"]
[sub_resource type="StyleBoxFlat" id="StyleBoxFlat_ku06j"]
bg_color = Color(0.133333, 0.133333, 0.133333, 0.784314)
@@ -45,6 +44,7 @@ layout_mode = 2
[node name="ToPlayer" type="LineEdit" parent="VBoxContainer/HBoxContainer"]
unique_name_in_owner = true
layout_mode = 2
+placeholder_text = "Player"
[node name="LineEdit" type="LineEdit" parent="VBoxContainer/HBoxContainer"]
unique_name_in_owner = true
@@ -52,9 +52,11 @@ layout_mode = 2
size_flags_horizontal = 3
placeholder_text = "Send Messages here"
-[node name="Handle" parent="VBoxContainer/HBoxContainer" instance=ExtResource("2_2x3wj")]
+[node name="Handle" type="TextureButton" parent="VBoxContainer/HBoxContainer"]
+texture_filter = 1
layout_mode = 2
-texture_normal = ExtResource("3_smgio")
+mouse_default_cursor_shape = 2
+texture_normal = ExtResource("2_2x3wj")
stretch_mode = 5
[connection signal="text_submitted" from="VBoxContainer/HBoxContainer/LineEdit" to="." method="_on_line_edit_text_submitted"]
diff --git a/ui/login.gd b/ui/login.gd
index 70cc52e..1c5284e 100644
--- a/ui/login.gd
+++ b/ui/login.gd
@@ -28,11 +28,16 @@ func switch_screen(screen: Node):
func _on_login_pressed() -> void:
SoundManager.sound_button_click.play()
- Network.login_server = LoginServer.new("127.0.0.1")
+ Network.login_server = LoginServer.new(Network.client_info.get_address(), Network.client_info.get_port())
Network.login_server.establish_connection()
if Network.login_server.get_status() == Error.FAILED:
- Client.show_message_window("Couldn't connect to server at 127.0.0.1", "Connection Error", %Login/Window, SIDE_BOTTOM)
+ Client.show_message_window(
+ "Couldn't connect to server at %s:%s" % [Network.login_server.host, Network.login_server.port],
+ "Connection Error",
+ %Login/Window,
+ SIDE_BOTTOM
+ )
return
var response = await Network.login_server.login(username.text, password.text)
@@ -48,6 +53,30 @@ func _on_login_pressed() -> void:
Client.show_message_window(message, "Login Error", %Login/Window, SIDE_BOTTOM)
return
+ if response is LoginFailedPacket2:
+ var message := ""
+ if response.reason == Constants.LoginFailedReason2.UnregisteredId:
+ message = "Unregistered ID"
+ elif response.reason == Constants.LoginFailedReason2.IncorrectPassword:
+ message = "Incorrect Password"
+ elif response.reason == Constants.LoginFailedReason2.IdExpired:
+ message = "ID expired"
+ elif response.reason == Constants.LoginFailedReason2.RejectedFromServer:
+ message = "Rejected from Server"
+ elif response.reason == Constants.LoginFailedReason2.BlockedByGMTeam:
+ message = "Blocked by GM Team"
+ elif response.reason == Constants.LoginFailedReason2.GameOutdated:
+ message = "Game Outdated"
+ elif response.reason == Constants.LoginFailedReason2.LoginProhibitedUntil:
+ message = "Login prohibited until %s" % response.unblock_time
+ elif response.reason == Constants.LoginFailedReason2.ServerFull:
+ message = "Server Full"
+ elif response.reason == Constants.LoginFailedReason2.CompanyAccountLimitReached:
+ message = "CompanyAccountLimitReached"
+
+ Client.show_message_window(message, "Login Error", %Login/Window, SIDE_BOTTOM)
+ return
+
account_information = response
character_server_information = account_information.character_server_information
@@ -96,10 +125,12 @@ func _on_character_server_login_pressed(character_server_info: CharacterServerIn
account_information.gender
)
- if response.login is CharacterSelectionFailedPacket:
+ if response.has(CharacterSelectionFailedPacket.HEADER):
Client.show_message_window(
- "Connection rejected from server \"%s\" at %s" % [
- character_server_info.server_name, character_server_info.get_server_ip()
+ "Connection rejected from server \"%s\" at %s:%s" % [
+ character_server_info.server_name,
+ character_server_info.get_server_ip(),
+ character_server_info.server_port
],
"Connection Error", %CharacterServer/Window, SIDE_BOTTOM
)
@@ -107,7 +138,7 @@ func _on_character_server_login_pressed(character_server_info: CharacterServerIn
get_tree().root.add_child(Network.character_server.get_keep_alive_timer())
- var character_list: CharacterServerLoginSuccessCharacterListPacket = response.character_list
+ var character_list: CharacterServerLoginSuccessCharacterListPacket = response[CharacterServerLoginSuccessCharacterListPacket.HEADER]
var login_character_list := LoginCharacterList.from_character_list_login_packet(character_list)
%CharacterSelectionList.login_character_list = login_character_list
@@ -118,11 +149,18 @@ func _on_character_server_login_pressed(character_server_info: CharacterServerIn
var info = login_character_list.get_info_for_slot(slot_idx)
if info:
current_character_information = info
+ %CharacterSelectionCreate.visible = false
+ %CharacterLogin.visible = true
else:
current_character_information = null
+ %CharacterSelectionCreate.visible = true
+ %CharacterLogin.visible = false
)
%CharacterSelectionList.requested_login.connect(func(slot_idx: int):
- _on_character_selected_pressed(slot_idx)
+ if current_character_information:
+ _on_character_selected_pressed(slot_idx)
+ else:
+ _on_character_selection_create_pressed()
)
# pre-select first character
@@ -178,5 +216,56 @@ func _on_character_selection_back_button_pressed() -> void:
switch_screen(%CharacterServer)
+func _on_character_selection_create_pressed() -> void:
+ SoundManager.sound_button_click.play()
+ switch_screen(%CharacterCreation)
+
+ %CharacterCreationInterface.strength = 5
+ %CharacterCreationInterface.agility = 5
+ %CharacterCreationInterface.vitality = 5
+ %CharacterCreationInterface.intelligence = 5
+ %CharacterCreationInterface.dexterity = 5
+ %CharacterCreationInterface.luck = 5
+
+
func _on_character_login_pressed() -> void:
_on_character_selected_pressed(current_character_slot_idx)
+
+
+func _on_character_creation_cancel_pressed() -> void:
+ SoundManager.sound_button_click.play()
+ switch_screen(%CharacterSelection)
+
+
+func _on_character_creation_create_pressed() -> void:
+ SoundManager.sound_button_click.play()
+
+ var response = await Network.character_server.create_character(
+ %CharacterCreationInterface.character_name,
+ current_character_slot_idx,
+ 0,
+ %CharacterCreationInterface.head_id,
+ Constants.Job.Novice,
+ account_information.gender
+ )
+
+ if response is CharacterCreationFailedPacket:
+ var message := ""
+ if response.reason == Constants.CharacterCreationFailedReason.CharacterNameAlreadyInUse:
+ message = "Character Name already in use"
+ elif response.reason == Constants.CharacterCreationFailedReason.NotOldEnough:
+ message = "Not old enough"
+ elif response.reason == Constants.CharacterCreationFailedReason.NotAllowedToUseSlot:
+ message = "Not allowed to use slot"
+ elif response.reason == Constants.CharacterCreationFailedReason.CharacterCreationFailed:
+ message = "Character creation failed. Reason unknown"
+
+ Client.show_message_window(message, "Character Creation Error")
+ return
+
+ # TODO: create character
+ # TODO: reload selection list data
+
+ switch_screen(%CharacterSelection)
+ %CharacterSelectionList.login_character_list.add_character_information(response.character_information)
+ print(inst_to_dict(response.character_information))
diff --git a/ui/login.tscn b/ui/login.tscn
index e889508..04f24b1 100644
--- a/ui/login.tscn
+++ b/ui/login.tscn
@@ -1,4 +1,4 @@
-[gd_scene load_steps=24 format=3 uid="uid://dser74lcd3a4g"]
+[gd_scene load_steps=25 format=3 uid="uid://dser74lcd3a4g"]
[ext_resource type="Script" uid="uid://dqswsdaamfhbq" path="res://ui/login.gd" id="1_1m5cv"]
[ext_resource type="Texture2D" uid="uid://cxd6dnc7s17vg" path="res://client_data/skin/login_background.jpg" id="2_elmti"]
@@ -6,22 +6,23 @@
[ext_resource type="Theme" uid="uid://c5sm3yvuakj3b" path="res://ui/theme.tres" id="3_7ogdv"]
[ext_resource type="PackedScene" uid="uid://cjcm2mai50thr" path="res://ui/bmp_texture_button.tscn" id="3_qemc0"]
[ext_resource type="PackedScene" uid="uid://c8uqw08hxfqlu" path="res://ui/chat_window.tscn" id="4_ah2a1"]
-[ext_resource type="Texture2D" uid="uid://bern5mhol3l8y" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/login_interface/btn_connect.bmp" id="4_wpax4"]
-[ext_resource type="Texture2D" uid="uid://c31u8nlyugk3p" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/login_interface/btn_connect_b.bmp" id="5_7ogdv"]
-[ext_resource type="Texture2D" uid="uid://c5kctdb8b2msx" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/login_interface/btn_connect_a.bmp" id="6_l3yss"]
-[ext_resource type="Texture2D" uid="uid://l3c7ssoc4lxq" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/login_interface/btn_connect.png" id="7_pfdi0"]
-[ext_resource type="Texture2D" uid="uid://p7bxfof7gd0t" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/login_interface/btn_connect_b.png" id="8_38pxr"]
-[ext_resource type="Texture2D" uid="uid://ba8j1t53lqxr0" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/login_interface/btn_connect_a.png" id="9_hqeko"]
+[ext_resource type="Texture2D" uid="uid://1vrog6v0c8dd" path="res://client_data/data/texture/유저인터페이스/login_interface/btn_connect.png" id="7_8pgsx"]
+[ext_resource type="Texture2D" uid="uid://txbfc4bmwl3o" path="res://client_data/data/texture/유저인터페이스/login_interface/btn_connect_b.png" id="8_dx2ir"]
+[ext_resource type="Texture2D" uid="uid://xj061qbyw4mp" path="res://client_data/data/texture/유저인터페이스/login_interface/btn_connect_a.png" id="9_tftjj"]
[ext_resource type="Theme" uid="uid://c6y6r8kcnbb10" path="res://ui/theme_clear.tres" id="9_toei2"]
[ext_resource type="PackedScene" uid="uid://f2urhroq21t0" path="res://ui/login/character_server_button.tscn" id="10_38pxr"]
-[ext_resource type="Texture2D" uid="uid://byn26biifjkng" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/btn_cancel.bmp" id="11_tihdy"]
-[ext_resource type="Texture2D" uid="uid://wvnt34j5mkvy" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/btn_cancel_b.bmp" id="12_mma3j"]
-[ext_resource type="Texture2D" uid="uid://pv886kwtlrq0" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/btn_cancel_a.bmp" id="13_0vsp3"]
-[ext_resource type="Texture2D" uid="uid://b13jh48hyjyrt" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/btn_next.bmp" id="14_pfdi0"]
-[ext_resource type="Texture2D" uid="uid://bo277gh8uyw1w" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/btn_next_b.bmp" id="15_38pxr"]
-[ext_resource type="Texture2D" uid="uid://qvmuk8xa3yej" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/btn_next_a.bmp" id="16_hqeko"]
+[ext_resource type="Texture2D" uid="uid://pjerdwsogw84" path="res://client_data/data/texture/유저인터페이스/btn_cancel.png" id="11_60jnu"]
+[ext_resource type="Texture2D" uid="uid://ba3g38r086pyk" path="res://client_data/data/texture/유저인터페이스/btn_cancel_b.png" id="12_up3vp"]
+[ext_resource type="Texture2D" uid="uid://bw3j7xm53qoqe" path="res://client_data/data/texture/유저인터페이스/btn_cancel_a.png" id="13_swwvu"]
+[ext_resource type="Texture2D" uid="uid://brkbxq02xuyw8" path="res://client_data/data/texture/유저인터페이스/btn_next.png" id="14_ohrmw"]
+[ext_resource type="Texture2D" uid="uid://dweiqt26hgws2" path="res://client_data/data/texture/유저인터페이스/btn_next_b.png" id="15_c1fiv"]
+[ext_resource type="Texture2D" uid="uid://h6r0smppndhq" path="res://client_data/data/texture/유저인터페이스/btn_next_a.png" id="16_14c6s"]
[ext_resource type="PackedScene" uid="uid://bxbprntny8duj" path="res://ui/login/login_character_selection_list.tscn" id="16_tihdy"]
[ext_resource type="PackedScene" uid="uid://swtqlba1wi3o" path="res://ui/window.tscn" id="17_mma3j"]
+[ext_resource type="Texture2D" uid="uid://cgsgfo5j5lm2t" path="res://client_data/data/texture/유저인터페이스/btn_make_b.png" id="19_dx2ir"]
+[ext_resource type="Texture2D" uid="uid://bvbne1gpgvk08" path="res://client_data/data/texture/유저인터페이스/btn_make_a.png" id="20_tftjj"]
+[ext_resource type="Texture2D" uid="uid://cnhrbacvvitjq" path="res://client_data/data/texture/유저인터페이스/btn_make.png" id="22_82qbc"]
+[ext_resource type="PackedScene" uid="uid://di8inwptr42fe" path="res://ui/login/character_creation.tscn" id="24_8pgsx"]
[sub_resource type="StyleBoxFlat" id="StyleBoxFlat_pfdi0"]
bg_color = Color(0.977834, 0.977834, 0.977834, 1)
@@ -119,9 +120,9 @@ secret_character = "*"
layout_mode = 2
size_flags_horizontal = 8
theme = ExtResource("3_7ogdv")
-texture_normal = ExtResource("7_pfdi0")
-texture_pressed = ExtResource("8_38pxr")
-texture_hover = ExtResource("9_hqeko")
+texture_normal = ExtResource("7_8pgsx")
+texture_pressed = ExtResource("8_dx2ir")
+texture_hover = ExtResource("9_tftjj")
[node name="CharacterServer" type="CenterContainer" parent="."]
unique_name_in_owner = true
@@ -169,16 +170,16 @@ layout_mode = 2
[node name="CharacterServerBackButton" parent="CharacterServer/Window/VBoxContainer/ButtonBar/ButtonBarElements/HBoxContainer" instance=ExtResource("3_qemc0")]
layout_mode = 2
size_flags_horizontal = 0
-texture_normal = ExtResource("11_tihdy")
-texture_pressed = ExtResource("12_mma3j")
-texture_hover = ExtResource("13_0vsp3")
+texture_normal = ExtResource("11_60jnu")
+texture_pressed = ExtResource("12_up3vp")
+texture_hover = ExtResource("13_swwvu")
[node name="CharacterServerNextButton" parent="CharacterServer/Window/VBoxContainer/ButtonBar/ButtonBarElements/HBoxContainer" instance=ExtResource("3_qemc0")]
layout_mode = 2
size_flags_horizontal = 10
-texture_normal = ExtResource("14_pfdi0")
-texture_pressed = ExtResource("15_38pxr")
-texture_hover = ExtResource("16_hqeko")
+texture_normal = ExtResource("14_ohrmw")
+texture_pressed = ExtResource("15_c1fiv")
+texture_hover = ExtResource("16_14c6s")
[node name="CharacterSelection" type="CenterContainer" parent="."]
unique_name_in_owner = true
@@ -294,17 +295,72 @@ layout_mode = 2
[node name="CharacterSelectionBackButton" parent="CharacterSelection/Window/VBoxContainer/ButtonBar/ButtonBarElements" index="0" instance=ExtResource("3_qemc0")]
layout_mode = 2
size_flags_horizontal = 0
-texture_normal = ExtResource("11_tihdy")
-texture_pressed = ExtResource("12_mma3j")
-texture_hover = ExtResource("13_0vsp3")
+texture_normal = ExtResource("11_60jnu")
+texture_pressed = ExtResource("12_up3vp")
+texture_hover = ExtResource("13_swwvu")
-[node name="CharacterLogin" parent="CharacterSelection/Window/VBoxContainer/ButtonBar/ButtonBarElements" index="1" instance=ExtResource("3_qemc0")]
+[node name="HBoxContainer" type="HBoxContainer" parent="CharacterSelection/Window/VBoxContainer/ButtonBar/ButtonBarElements" index="1"]
+layout_mode = 2
+size_flags_horizontal = 8
+
+[node name="CharacterSelectionCreate" type="TextureButton" parent="CharacterSelection/Window/VBoxContainer/ButtonBar/ButtonBarElements/HBoxContainer"]
+unique_name_in_owner = true
+texture_filter = 1
+layout_mode = 2
+size_flags_horizontal = 8
+mouse_default_cursor_shape = 2
+texture_normal = ExtResource("22_82qbc")
+texture_pressed = ExtResource("19_dx2ir")
+texture_hover = ExtResource("20_tftjj")
+
+[node name="CharacterLogin" parent="CharacterSelection/Window/VBoxContainer/ButtonBar/ButtonBarElements/HBoxContainer" instance=ExtResource("3_qemc0")]
+unique_name_in_owner = true
+layout_mode = 2
+size_flags_horizontal = 8
+texture_normal = ExtResource("7_8pgsx")
+texture_pressed = ExtResource("8_dx2ir")
+texture_hover = ExtResource("9_tftjj")
+
+[node name="CharacterCreation" type="CenterContainer" parent="."]
+unique_name_in_owner = true
+layout_mode = 1
+anchors_preset = 15
+anchor_right = 1.0
+anchor_bottom = 1.0
+grow_horizontal = 2
+grow_vertical = 2
+
+[node name="Window" parent="CharacterCreation" instance=ExtResource("17_mma3j")]
+layout_mode = 2
+
+[node name="MarginContainer" type="MarginContainer" parent="CharacterCreation/Window/VBoxContainer/Body" index="0"]
+layout_mode = 2
+theme_override_constants/margin_left = 16
+theme_override_constants/margin_top = 16
+theme_override_constants/margin_right = 16
+theme_override_constants/margin_bottom = 16
+
+[node name="CharacterCreationInterface" parent="CharacterCreation/Window/VBoxContainer/Body/MarginContainer" instance=ExtResource("24_8pgsx")]
unique_name_in_owner = true
layout_mode = 2
+
+[node name="CharacterCreationCancel" type="TextureButton" parent="CharacterCreation/Window/VBoxContainer/ButtonBar/ButtonBarElements" index="0"]
+texture_filter = 1
+layout_mode = 2
+size_flags_horizontal = 0
+mouse_default_cursor_shape = 2
+texture_normal = ExtResource("11_60jnu")
+texture_pressed = ExtResource("12_up3vp")
+texture_hover = ExtResource("13_swwvu")
+
+[node name="CharacterCreationCreate" type="TextureButton" parent="CharacterCreation/Window/VBoxContainer/ButtonBar/ButtonBarElements" index="1"]
+texture_filter = 1
+layout_mode = 2
size_flags_horizontal = 8
-texture_normal = ExtResource("4_wpax4")
-texture_pressed = ExtResource("5_7ogdv")
-texture_hover = ExtResource("6_l3yss")
+mouse_default_cursor_shape = 2
+texture_normal = ExtResource("22_82qbc")
+texture_pressed = ExtResource("19_dx2ir")
+texture_hover = ExtResource("20_tftjj")
[node name="BackgroundMusic" type="AudioStreamPlayer" parent="."]
stream = ExtResource("3_2nukd")
@@ -327,8 +383,12 @@ grow_vertical = 0
[connection signal="pressed" from="CharacterServer/Window/VBoxContainer/ButtonBar/ButtonBarElements/HBoxContainer/CharacterServerNextButton" to="." method="_on_character_server_next_button_pressed"]
[connection signal="pressed" from="CharacterSelection/VBoxContainer/CharacterSelectionBackButton" to="." method="_on_character_selection_back_button_pressed"]
[connection signal="pressed" from="CharacterSelection/Window/VBoxContainer/ButtonBar/ButtonBarElements/CharacterSelectionBackButton" to="." method="_on_character_selection_back_button_pressed"]
-[connection signal="pressed" from="CharacterSelection/Window/VBoxContainer/ButtonBar/ButtonBarElements/CharacterLogin" to="." method="_on_character_login_pressed"]
+[connection signal="pressed" from="CharacterSelection/Window/VBoxContainer/ButtonBar/ButtonBarElements/HBoxContainer/CharacterSelectionCreate" to="." method="_on_character_selection_create_pressed"]
+[connection signal="pressed" from="CharacterSelection/Window/VBoxContainer/ButtonBar/ButtonBarElements/HBoxContainer/CharacterLogin" to="." method="_on_character_login_pressed"]
+[connection signal="pressed" from="CharacterCreation/Window/VBoxContainer/ButtonBar/ButtonBarElements/CharacterCreationCancel" to="." method="_on_character_creation_cancel_pressed"]
+[connection signal="pressed" from="CharacterCreation/Window/VBoxContainer/ButtonBar/ButtonBarElements/CharacterCreationCreate" to="." method="_on_character_creation_create_pressed"]
[editable path="Login/Window"]
[editable path="CharacterServer/Window"]
[editable path="CharacterSelection/Window"]
+[editable path="CharacterCreation/Window"]
diff --git a/ui/login/character_creation.gd b/ui/login/character_creation.gd
new file mode 100644
index 0000000..f3989d1
--- /dev/null
+++ b/ui/login/character_creation.gd
@@ -0,0 +1,134 @@
+extends HBoxContainer
+
+
+var strength := 5:
+ set(value):
+ strength = value
+ %StatEntryStrength.value = value
+ %Polygon.polygon[0] = (
+ Vector2(100, 100) +
+ ((Vector2(100, 0) - Vector2(100, 100)) / 9.0) * value
+ )
+
+var vitality := 5:
+ set(value):
+ vitality = value
+ %StatEntryVitality.value = value
+ %Polygon.polygon[1] = (
+ Vector2(100, 100) +
+ ((Vector2(200, 50) - Vector2(100, 100)) / 9.0) * value
+ )
+
+var luck := 5:
+ set(value):
+ luck = value
+ %StatEntryLuck.value = value
+ %Polygon.polygon[2] = (
+ Vector2(100, 100) +
+ ((Vector2(200, 150) - Vector2(100, 100)) / 9.0) * value
+ )
+
+var intelligence := 5:
+ set(value):
+ intelligence = value
+ %StatEntryIntelligence.value = value
+ %Polygon.polygon[3] = (
+ Vector2(100, 100) +
+ ((Vector2(100, 200) - Vector2(100, 100)) / 9.0) * value
+ )
+
+var dexterity := 5:
+ set(value):
+ dexterity = value
+ %StatEntryDexterity.value = value
+ %Polygon.polygon[4] = (
+ Vector2(100, 100) +
+ ((Vector2(0, 150) - Vector2(100, 100)) / 9.0) * value
+ )
+
+var agility := 5:
+ set(value):
+ agility = value
+ %StatEntryAgility.value = value
+ %Polygon.polygon[5] = (
+ Vector2(100, 100) +
+ ((Vector2(0, 50) - Vector2(100, 100)) / 9.0) * value
+ )
+
+var head_id := 1:
+ set(value):
+ head_id = value
+ %Head.texture = load(
+ "%s/%s/000.png" % [
+ "res://client_data/data/sprite",
+ Constants.FilePaths.get_player_head(Constants.Gender.Male, head_id),
+ ]
+ )
+
+var character_name: String
+
+
+func _on_strength_button_pressed() -> void:
+ if strength >= 9:
+ return
+
+ strength += 1
+ intelligence -= 1
+
+
+func _on_vitality_button_pressed() -> void:
+ if vitality >= 9:
+ return
+
+ vitality += 1
+ dexterity -= 1
+
+
+func _on_luck_button_pressed() -> void:
+ if luck >= 9:
+ return
+
+ luck += 1
+ agility -= 1
+
+
+func _on_intelligence_button_pressed() -> void:
+ if intelligence >= 9:
+ return
+
+ intelligence += 1
+ strength -= 1
+
+
+func _on_dexterity_button_pressed() -> void:
+ if dexterity >= 9:
+ return
+
+ dexterity += 1
+ vitality -= 1
+
+
+func _on_agility_button_pressed() -> void:
+ if agility >= 9:
+ return
+
+ agility += 1
+ luck -= 1
+
+
+func _on_appearance_left_button_pressed() -> void:
+ head_id = (head_id - 1) % (42 + 1)
+ # TODO: fix
+
+
+func _on_appearance_right_button_pressed() -> void:
+ head_id = (head_id + 1) % (42 + 1)
+
+
+func _on_appearance_up_button_pressed() -> void:
+ # TODO: change hair color
+ pass # Replace with function body.
+
+
+func _on_name_text_changed(new_text: String) -> void:
+ character_name = new_text
diff --git a/ui/login/character_creation.tscn b/ui/login/character_creation.tscn
new file mode 100644
index 0000000..dbecf32
--- /dev/null
+++ b/ui/login/character_creation.tscn
@@ -0,0 +1,304 @@
+[gd_scene load_steps=21 format=3 uid="uid://di8inwptr42fe"]
+
+[ext_resource type="Script" uid="uid://w10xfhscfuo0" path="res://ui/login/character_creation.gd" id="1_i6vfx"]
+[ext_resource type="Theme" uid="uid://c6y6r8kcnbb10" path="res://ui/theme_clear.tres" id="1_kuhsd"]
+[ext_resource type="Texture2D" uid="uid://687s0xq708kn" path="res://client_data/data/texture/유저인터페이스/basic_interface/arw_left.png" id="2_6pdc2"]
+[ext_resource type="Texture2D" uid="uid://0to1babdx1js" path="res://client_data/data/texture/유저인터페이스/basic_interface/arw_right.png" id="3_60s0a"]
+[ext_resource type="Texture2D" uid="uid://mvgh8pjg7qar" path="res://client_data/data/texture/유저인터페이스/basic_interface/arw_up.png" id="4_ufd68"]
+[ext_resource type="Texture2D" uid="uid://ci2liot5s8jnb" path="res://client_data/data/sprite/인간족/머리통/남/16_남/000.png" id="5_6pdc2"]
+[ext_resource type="Texture2D" uid="uid://be3ax80esna7b" path="res://client_data/data/sprite/인간족/몸통/남/초보자_남/000.png" id="6_60s0a"]
+[ext_resource type="Texture2D" uid="uid://c0kd66xiup6qq" path="res://client_data/data/texture/유저인터페이스/login_interface/arw-str0.png" id="8_6pdc2"]
+[ext_resource type="Texture2D" uid="uid://c5k65ct7at0ns" path="res://client_data/data/texture/유저인터페이스/login_interface/arw-str1.png" id="9_60s0a"]
+[ext_resource type="Texture2D" uid="uid://cnpgjr7mj4j14" path="res://client_data/data/texture/유저인터페이스/login_interface/arw-vit0.png" id="10_6pdc2"]
+[ext_resource type="Texture2D" uid="uid://b4878jg8ex7tm" path="res://client_data/data/texture/유저인터페이스/login_interface/arw-vit1.png" id="11_60s0a"]
+[ext_resource type="Texture2D" uid="uid://iviinm4jtx2j" path="res://client_data/data/texture/유저인터페이스/login_interface/arw-luk0.png" id="12_6pdc2"]
+[ext_resource type="Texture2D" uid="uid://dx0w5jac6n12s" path="res://client_data/data/texture/유저인터페이스/login_interface/arw-luk1.png" id="13_60s0a"]
+[ext_resource type="PackedScene" uid="uid://cff164qwvlsqd" path="res://ui/login/stat_entry.tscn" id="14_b1a0f"]
+[ext_resource type="Texture2D" uid="uid://qrudl7mwwjvq" path="res://client_data/data/texture/유저인터페이스/login_interface/arw-int0.png" id="14_ufd68"]
+[ext_resource type="Texture2D" uid="uid://7vxidv2eb4uk" path="res://client_data/data/texture/유저인터페이스/login_interface/arw-int1.png" id="15_uors6"]
+[ext_resource type="Texture2D" uid="uid://bd20v4ovvst4r" path="res://client_data/data/texture/유저인터페이스/login_interface/arw-dex0.png" id="16_kbej0"]
+[ext_resource type="Texture2D" uid="uid://cyry27r8wpd7i" path="res://client_data/data/texture/유저인터페이스/login_interface/arw-dex1.png" id="17_1iw4y"]
+[ext_resource type="Texture2D" uid="uid://cd7riu7j5lyri" path="res://client_data/data/texture/유저인터페이스/login_interface/arw-agi0.png" id="18_225jb"]
+[ext_resource type="Texture2D" uid="uid://dcotmlbpx0iaa" path="res://client_data/data/texture/유저인터페이스/login_interface/arw-agi1.png" id="19_b1a0f"]
+
+[node name="CharacterCreation" type="HBoxContainer"]
+script = ExtResource("1_i6vfx")
+
+[node name="VBoxContainer" type="VBoxContainer" parent="."]
+layout_mode = 2
+size_flags_vertical = 8
+
+[node name="Control" type="Control" parent="VBoxContainer"]
+custom_minimum_size = Vector2(0, 20)
+layout_mode = 2
+
+[node name="AppearanceLeftButton" type="TextureButton" parent="VBoxContainer/Control"]
+texture_filter = 1
+layout_mode = 1
+anchors_preset = 4
+anchor_top = 0.5
+anchor_bottom = 0.5
+offset_top = -5.5
+offset_right = 11.0
+offset_bottom = 5.5
+grow_vertical = 2
+scale = Vector2(1.5, 1.5)
+mouse_default_cursor_shape = 2
+texture_normal = ExtResource("2_6pdc2")
+
+[node name="AppearanceRightButton" type="TextureButton" parent="VBoxContainer/Control"]
+texture_filter = 1
+layout_mode = 1
+anchors_preset = 6
+anchor_left = 1.0
+anchor_top = 0.5
+anchor_right = 1.0
+anchor_bottom = 0.5
+offset_left = -11.0
+offset_top = -5.5
+offset_bottom = 5.5
+grow_horizontal = 0
+grow_vertical = 2
+scale = Vector2(1.5, 1.5)
+mouse_default_cursor_shape = 2
+texture_normal = ExtResource("3_60s0a")
+
+[node name="AppearanceUpButton" type="TextureButton" parent="VBoxContainer/Control"]
+texture_filter = 1
+layout_mode = 1
+anchors_preset = 5
+anchor_left = 0.5
+anchor_right = 0.5
+offset_left = -5.5
+offset_top = -8.0
+offset_right = 5.5
+offset_bottom = 3.0
+grow_horizontal = 2
+scale = Vector2(1.5, 1.5)
+mouse_default_cursor_shape = 2
+texture_normal = ExtResource("4_ufd68")
+
+[node name="VBoxContainer" type="VBoxContainer" parent="VBoxContainer"]
+layout_mode = 2
+theme_override_constants/separation = -8
+
+[node name="Head" type="TextureRect" parent="VBoxContainer/VBoxContainer"]
+unique_name_in_owner = true
+z_index = 1
+texture_filter = 1
+layout_mode = 2
+texture = ExtResource("5_6pdc2")
+stretch_mode = 5
+
+[node name="Body" type="TextureRect" parent="VBoxContainer/VBoxContainer"]
+texture_filter = 1
+layout_mode = 2
+texture = ExtResource("6_60s0a")
+stretch_mode = 5
+
+[node name="HBoxContainer" type="HBoxContainer" parent="VBoxContainer"]
+layout_mode = 2
+
+[node name="Label" type="Label" parent="VBoxContainer/HBoxContainer"]
+texture_filter = 1
+layout_mode = 2
+theme = ExtResource("1_kuhsd")
+theme_type_variation = &"LabelLabel"
+text = "Name"
+
+[node name="Name" type="LineEdit" parent="VBoxContainer/HBoxContainer"]
+unique_name_in_owner = true
+layout_mode = 2
+size_flags_vertical = 4
+theme = ExtResource("1_kuhsd")
+
+[node name="Control" type="Control" parent="."]
+custom_minimum_size = Vector2(280, 280)
+layout_mode = 2
+
+[node name="Container" type="Node2D" parent="Control"]
+position = Vector2(40, 40)
+
+[node name="Polygon" type="Polygon2D" parent="Control/Container"]
+unique_name_in_owner = true
+color = Color(0.776471, 0.807843, 0.905882, 1)
+polygon = PackedVector2Array(100, 50, 148, 76, 148, 124, 100, 150, 52, 124, 52, 76)
+uv = PackedVector2Array(100, 0, 200, 50, 200, 150, 100, 200, 0, 150, 0, 75)
+
+[node name="LineCircle" type="Line2D" parent="Control/Container"]
+points = PackedVector2Array(100, 0, 200, 50, 200, 150, 100, 200, 0, 150, 0, 50)
+closed = true
+width = 1.0
+default_color = Color(0.776471, 0.807843, 0.905882, 1)
+
+[node name="LineNS" type="Line2D" parent="Control/Container"]
+points = PackedVector2Array(100, 0, 100, 200)
+closed = true
+width = 1.0
+default_color = Color(0.776471, 0.807843, 0.905882, 1)
+
+[node name="LineNESW" type="Line2D" parent="Control/Container"]
+points = PackedVector2Array(200, 50, 0, 150)
+closed = true
+width = 1.0
+default_color = Color(0.776471, 0.807843, 0.905882, 1)
+
+[node name="LineNWSE" type="Line2D" parent="Control/Container"]
+points = PackedVector2Array(0, 50, 200, 150)
+closed = true
+width = 1.0
+default_color = Color(0.776471, 0.807843, 0.905882, 1)
+
+[node name="StrengthButton" type="TextureButton" parent="Control"]
+texture_filter = 1
+layout_mode = 1
+anchors_preset = 5
+anchor_left = 0.5
+anchor_right = 0.5
+offset_left = -19.0
+offset_top = 1.0
+offset_right = 21.0
+offset_bottom = 41.0
+grow_horizontal = 2
+mouse_default_cursor_shape = 2
+texture_normal = ExtResource("8_6pdc2")
+texture_pressed = ExtResource("9_60s0a")
+
+[node name="VitalityButton" type="TextureButton" parent="Control"]
+texture_filter = 1
+layout_mode = 1
+anchors_preset = 1
+anchor_left = 1.0
+anchor_right = 1.0
+offset_left = -42.9999
+offset_top = 67.0
+offset_right = -2.99994
+offset_bottom = 107.0
+grow_horizontal = 0
+mouse_default_cursor_shape = 2
+texture_normal = ExtResource("10_6pdc2")
+texture_pressed = ExtResource("11_60s0a")
+
+[node name="LuckButton" type="TextureButton" parent="Control"]
+texture_filter = 1
+layout_mode = 1
+anchors_preset = 3
+anchor_left = 1.0
+anchor_top = 1.0
+anchor_right = 1.0
+anchor_bottom = 1.0
+offset_left = -44.0
+offset_top = -101.0
+offset_right = -4.0
+offset_bottom = -61.0
+grow_horizontal = 0
+grow_vertical = 0
+mouse_default_cursor_shape = 2
+texture_normal = ExtResource("12_6pdc2")
+texture_pressed = ExtResource("13_60s0a")
+
+[node name="IntelligenceButton" type="TextureButton" parent="Control"]
+texture_filter = 1
+layout_mode = 1
+anchors_preset = 7
+anchor_left = 0.5
+anchor_top = 1.0
+anchor_right = 0.5
+anchor_bottom = 1.0
+offset_left = -18.0
+offset_top = -40.0
+offset_right = 22.0
+grow_horizontal = 2
+grow_vertical = 0
+mouse_default_cursor_shape = 2
+texture_normal = ExtResource("14_ufd68")
+texture_pressed = ExtResource("15_uors6")
+
+[node name="DexterityButton" type="TextureButton" parent="Control"]
+texture_filter = 1
+layout_mode = 1
+anchors_preset = 2
+anchor_top = 1.0
+anchor_bottom = 1.0
+offset_left = 9.0
+offset_top = -104.0
+offset_right = 49.0
+offset_bottom = -64.0
+grow_vertical = 0
+mouse_default_cursor_shape = 2
+texture_normal = ExtResource("16_kbej0")
+texture_pressed = ExtResource("17_1iw4y")
+
+[node name="AgilityButton" type="TextureButton" parent="Control"]
+texture_filter = 1
+layout_mode = 1
+offset_left = 8.0
+offset_top = 67.0
+offset_right = 48.0
+offset_bottom = 107.0
+mouse_default_cursor_shape = 2
+texture_normal = ExtResource("18_225jb")
+texture_pressed = ExtResource("19_b1a0f")
+
+[node name="VBoxContainer2" type="VBoxContainer" parent="."]
+layout_mode = 2
+theme_override_constants/separation = 1
+
+[node name="StatEntryStrength" parent="VBoxContainer2" instance=ExtResource("14_b1a0f")]
+unique_name_in_owner = true
+layout_mode = 2
+theme_override_constants/separation = 0
+label = "STR"
+value = 5
+value_alignment = 1
+
+[node name="StatEntryAgility" parent="VBoxContainer2" instance=ExtResource("14_b1a0f")]
+unique_name_in_owner = true
+layout_mode = 2
+theme_override_constants/separation = 0
+label = "AGI"
+value = 5
+value_alignment = 1
+
+[node name="StatEntryVitality" parent="VBoxContainer2" instance=ExtResource("14_b1a0f")]
+unique_name_in_owner = true
+layout_mode = 2
+theme_override_constants/separation = 0
+label = "VIT"
+value = 5
+value_alignment = 1
+
+[node name="StatEntryIntelligence" parent="VBoxContainer2" instance=ExtResource("14_b1a0f")]
+unique_name_in_owner = true
+layout_mode = 2
+theme_override_constants/separation = 0
+label = "INT"
+value = 5
+value_alignment = 1
+
+[node name="StatEntryDexterity" parent="VBoxContainer2" instance=ExtResource("14_b1a0f")]
+unique_name_in_owner = true
+layout_mode = 2
+theme_override_constants/separation = 0
+label = "DEX"
+value = 5
+value_alignment = 1
+
+[node name="StatEntryLuck" parent="VBoxContainer2" instance=ExtResource("14_b1a0f")]
+unique_name_in_owner = true
+layout_mode = 2
+theme_override_constants/separation = 0
+label = "LUK"
+value = 5
+value_alignment = 1
+
+[connection signal="pressed" from="VBoxContainer/Control/AppearanceLeftButton" to="." method="_on_appearance_left_button_pressed"]
+[connection signal="pressed" from="VBoxContainer/Control/AppearanceRightButton" to="." method="_on_appearance_right_button_pressed"]
+[connection signal="pressed" from="VBoxContainer/Control/AppearanceUpButton" to="." method="_on_appearance_up_button_pressed"]
+[connection signal="text_changed" from="VBoxContainer/HBoxContainer/Name" to="." method="_on_name_text_changed"]
+[connection signal="pressed" from="Control/StrengthButton" to="." method="_on_strength_button_pressed"]
+[connection signal="pressed" from="Control/VitalityButton" to="." method="_on_vitality_button_pressed"]
+[connection signal="pressed" from="Control/LuckButton" to="." method="_on_luck_button_pressed"]
+[connection signal="pressed" from="Control/IntelligenceButton" to="." method="_on_intelligence_button_pressed"]
+[connection signal="pressed" from="Control/DexterityButton" to="." method="_on_dexterity_button_pressed"]
+[connection signal="pressed" from="Control/AgilityButton" to="." method="_on_agility_button_pressed"]
diff --git a/ui/login/character_selection_item.tscn b/ui/login/character_selection_item.tscn
index de28392..0dab44c 100644
--- a/ui/login/character_selection_item.tscn
+++ b/ui/login/character_selection_item.tscn
@@ -1,10 +1,10 @@
[gd_scene load_steps=7 format=3 uid="uid://rrd131rq74n5"]
[ext_resource type="Script" uid="uid://bsglhorusc7ug" path="res://ui/login/character_selection_item.gd" id="1_25yur"]
-[ext_resource type="Texture2D" uid="uid://danymuvfjf4o1" path="res://client_data/data/sprite/Àΰ£Á·/¸Ó¸®Åë/³²/16_³²/000.png" id="2_aqbfs"]
-[ext_resource type="Texture2D" uid="uid://cwqgdd00sf7pu" path="res://client_data/data/sprite/Àΰ£Á·/¸öÅë/³²/Ãʺ¸ÀÚ_³²/000.png" id="3_xv3pn"]
+[ext_resource type="Texture2D" uid="uid://ci2liot5s8jnb" path="res://client_data/data/sprite/인간족/머리통/남/16_남/000.png" id="2_u21ok"]
+[ext_resource type="Texture2D" uid="uid://be3ax80esna7b" path="res://client_data/data/sprite/인간족/몸통/남/초보자_남/000.png" id="3_vhrt2"]
[ext_resource type="PackedScene" uid="uid://knmmuhon34rh" path="res://ui/bmp_texture_rect.tscn" id="4_vhrt2"]
-[ext_resource type="Texture2D" uid="uid://1s8lrydoctbv" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/login_interface/box_select.png" id="5_vhrt2"]
+[ext_resource type="Texture2D" uid="uid://bfe86fb6ytqg3" path="res://client_data/data/texture/유저인터페이스/login_interface/box_select.png" id="5_vhrt2"]
[sub_resource type="StyleBoxFlat" id="StyleBoxFlat_u21ok"]
bg_color = Color(0, 0, 0, 0.0980392)
@@ -43,14 +43,14 @@ unique_name_in_owner = true
z_index = 1
texture_filter = 1
layout_mode = 2
-texture = ExtResource("2_aqbfs")
+texture = ExtResource("2_u21ok")
stretch_mode = 3
[node name="Body" type="TextureRect" parent="MarginContainer/VBoxContainer/Sprite"]
unique_name_in_owner = true
texture_filter = 1
layout_mode = 2
-texture = ExtResource("3_xv3pn")
+texture = ExtResource("3_vhrt2")
stretch_mode = 3
[node name="SelectionBorder" parent="." instance=ExtResource("4_vhrt2")]
diff --git a/ui/login/login_character_selection_list.gd b/ui/login/login_character_selection_list.gd
index bd19fa1..7ff43cf 100644
--- a/ui/login/login_character_selection_list.gd
+++ b/ui/login/login_character_selection_list.gd
@@ -76,6 +76,11 @@ func set_login_character_list(value: LoginCharacterList) -> void:
draw()
+func add_character_information(info: CharacterInformation) -> void:
+ login_character_list.add_character_information(info)
+ draw()
+
+
func draw():
if not login_character_list:
return
diff --git a/ui/login/login_character_selection_list.tscn b/ui/login/login_character_selection_list.tscn
index 02a9dc2..373dcde 100644
--- a/ui/login/login_character_selection_list.tscn
+++ b/ui/login/login_character_selection_list.tscn
@@ -4,12 +4,12 @@
[ext_resource type="Script" uid="uid://dmch4gi1khn2r" path="res://ui/login/login_character_selection_list.gd" id="1_togb6"]
[ext_resource type="PackedScene" uid="uid://rrd131rq74n5" path="res://ui/login/character_selection_item.tscn" id="2_k142l"]
[ext_resource type="PackedScene" uid="uid://cjcm2mai50thr" path="res://ui/bmp_texture_button.tscn" id="2_s7n6r"]
-[ext_resource type="Texture2D" uid="uid://cey66pn46da80" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/select_character/chr_arrow_l_out.png" id="3_wnv6e"]
-[ext_resource type="Texture2D" uid="uid://bbs77ppnvcm23" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/select_character/chr_arrow_l_press.png" id="4_rdaw5"]
-[ext_resource type="Texture2D" uid="uid://c4supu7w8gabw" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/select_character/chr_arrow_l_over.png" id="5_1vggc"]
-[ext_resource type="Texture2D" uid="uid://dqweltumn8n7t" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/select_character/chr_arrow_r_out.png" id="7_wnv6e"]
-[ext_resource type="Texture2D" uid="uid://bsdygckmj667w" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/select_character/chr_arrow_r_press.png" id="8_rdaw5"]
-[ext_resource type="Texture2D" uid="uid://dqdmks4uak1go" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/select_character/chr_arrow_r_over.png" id="9_1vggc"]
+[ext_resource type="Texture2D" uid="uid://c1cgkiyacvr4k" path="res://client_data/data/texture/유저인터페이스/styleshop/chr_arrow_l_out.png" id="3_wnv6e"]
+[ext_resource type="Texture2D" uid="uid://dar08umwslovr" path="res://client_data/data/texture/유저인터페이스/styleshop/chr_arrow_l_press.png" id="4_wnv6e"]
+[ext_resource type="Texture2D" uid="uid://b38efa2wsrsiw" path="res://client_data/data/texture/유저인터페이스/styleshop/chr_arrow_l_over.png" id="5_wnv6e"]
+[ext_resource type="Texture2D" uid="uid://cjmj1etf1wth7" path="res://client_data/data/texture/유저인터페이스/styleshop/chr_arrow_r_out.png" id="7_1vggc"]
+[ext_resource type="Texture2D" uid="uid://deorq2yjwe4ie" path="res://client_data/data/texture/유저인터페이스/styleshop/chr_arrow_r_press.png" id="8_1oc8k"]
+[ext_resource type="Texture2D" uid="uid://ccfm5ls854xpf" path="res://client_data/data/texture/유저인터페이스/styleshop/chr_arrow_r_over.png" id="9_muwiy"]
[node name="LoginCharacterSelectionList" type="VBoxContainer"]
theme_override_constants/separation = 32
@@ -31,8 +31,8 @@ unique_name_in_owner = true
texture_filter = 0
layout_mode = 2
texture_normal = ExtResource("3_wnv6e")
-texture_pressed = ExtResource("4_rdaw5")
-texture_hover = ExtResource("5_1vggc")
+texture_pressed = ExtResource("4_wnv6e")
+texture_hover = ExtResource("5_wnv6e")
stretch_mode = 5
[node name="CharacterList" type="HBoxContainer" parent="MarginContainer/HBoxContainer"]
@@ -50,9 +50,9 @@ layout_mode = 2
unique_name_in_owner = true
texture_filter = 0
layout_mode = 2
-texture_normal = ExtResource("7_wnv6e")
-texture_pressed = ExtResource("8_rdaw5")
-texture_hover = ExtResource("9_1vggc")
+texture_normal = ExtResource("7_1vggc")
+texture_pressed = ExtResource("8_1oc8k")
+texture_hover = ExtResource("9_muwiy")
stretch_mode = 5
[node name="CharacterSelectionStatus" parent="." instance=ExtResource("1_5anyi")]
diff --git a/ui/login/stat_entry.gd b/ui/login/stat_entry.gd
new file mode 100644
index 0000000..6d79ac0
--- /dev/null
+++ b/ui/login/stat_entry.gd
@@ -0,0 +1,18 @@
+@tool
+extends HBoxContainer
+
+
+@export var label: String:
+ set(value):
+ label = value
+ $Label.text = value
+
+@export var value: int:
+ set(v):
+ value = v
+ $Value.text = str(v)
+
+@export var value_alignment: HorizontalAlignment:
+ set(value):
+ value_alignment = value
+ $Value.horizontal_alignment = value
diff --git a/ui/login/stat_entry.tscn b/ui/login/stat_entry.tscn
new file mode 100644
index 0000000..91e9abe
--- /dev/null
+++ b/ui/login/stat_entry.tscn
@@ -0,0 +1,24 @@
+[gd_scene load_steps=3 format=3 uid="uid://cff164qwvlsqd"]
+
+[ext_resource type="Theme" uid="uid://c6y6r8kcnbb10" path="res://ui/theme_clear.tres" id="1_3i1yo"]
+[ext_resource type="Script" uid="uid://bjdgrc1kwcbtj" path="res://ui/login/stat_entry.gd" id="1_vt1a4"]
+
+[node name="StatEntry" type="HBoxContainer"]
+offset_right = 169.0
+offset_bottom = 20.0
+script = ExtResource("1_vt1a4")
+
+[node name="Label" type="Label" parent="."]
+custom_minimum_size = Vector2(45, 0)
+layout_mode = 2
+theme = ExtResource("1_3i1yo")
+theme_type_variation = &"CharacterSelectionStatusLabel"
+text = "Label"
+
+[node name="Value" type="Label" parent="."]
+custom_minimum_size = Vector2(120, 0)
+layout_mode = 2
+size_flags_horizontal = 3
+theme = ExtResource("1_3i1yo")
+theme_type_variation = &"CharacterSelectionStatusLabel2"
+text = "value"
diff --git a/ui/message_window.tscn b/ui/message_window.tscn
index 5c195bf..b46fbe3 100644
--- a/ui/message_window.tscn
+++ b/ui/message_window.tscn
@@ -4,9 +4,9 @@
[ext_resource type="PackedScene" uid="uid://cjcm2mai50thr" path="res://ui/bmp_texture_button.tscn" id="2_3gmlp"]
[ext_resource type="Theme" uid="uid://c6y6r8kcnbb10" path="res://ui/theme_clear.tres" id="2_prcjf"]
[ext_resource type="Script" uid="uid://o36qsov00kwb" path="res://ui/message_window.gd" id="2_rr7kw"]
-[ext_resource type="Texture2D" uid="uid://b1yjeotua8xj5" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/btn_close.bmp" id="3_prcjf"]
-[ext_resource type="Texture2D" uid="uid://d4mycn8dag5yl" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/inventory/btn_close_press.bmp" id="4_rr7kw"]
-[ext_resource type="Texture2D" uid="uid://ds70r0x5vvy6t" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/basic_interface/btn_close_a.bmp" id="5_ql6vf"]
+[ext_resource type="Texture2D" uid="uid://b0o61r0oau4k7" path="res://client_data/data/texture/유저인터페이스/btn_close.png" id="5_m5dfh"]
+[ext_resource type="Texture2D" uid="uid://6sx7uu2xjc4" path="res://client_data/data/texture/유저인터페이스/btn_close_b.png" id="6_m5dfh"]
+[ext_resource type="Texture2D" uid="uid://bdxjoywe2tdif" path="res://client_data/data/texture/유저인터페이스/btn_close_a.png" id="7_a7gey"]
[node name="MessageWindow" instance=ExtResource("1_m7647")]
offset_right = 63.0
@@ -40,8 +40,8 @@ text = "Message"
unique_name_in_owner = true
layout_mode = 2
size_flags_horizontal = 8
-texture_normal = ExtResource("3_prcjf")
-texture_pressed = ExtResource("4_rr7kw")
-texture_hover = ExtResource("5_ql6vf")
+texture_normal = ExtResource("5_m5dfh")
+texture_pressed = ExtResource("6_m5dfh")
+texture_hover = ExtResource("7_a7gey")
[connection signal="pressed" from="VBoxContainer/ButtonBar/ButtonBarElements/CloseButtonBottom" to="." method="_on_close_button_bottom_pressed"]
diff --git a/ui/theme.tres b/ui/theme.tres
index 69ad428..a2a513d 100644
--- a/ui/theme.tres
+++ b/ui/theme.tres
@@ -1,29 +1,20 @@
-[gd_resource type="Theme" load_steps=9 format=3 uid="uid://c5sm3yvuakj3b"]
-
-[ext_resource type="Texture2D" uid="uid://34bqfgx41tf0" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/login_interface/bt_otp_over.png" id="1_iqtc0"]
-[ext_resource type="Texture2D" uid="uid://cehi7txcq4p2q" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/login_interface/name-edit.bmp" id="1_rqugq"]
-[ext_resource type="Texture2D" uid="uid://b63yrv7hceon4" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/login_interface/bt_otp_normal.png" id="2_7any1"]
-[ext_resource type="Texture2D" uid="uid://yew2ev1s10pk" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/login_interface/bt_otp_press.png" id="3_3fgq6"]
+[gd_resource type="Theme" load_steps=5 format=3 uid="uid://c5sm3yvuakj3b"]
[sub_resource type="StyleBoxTexture" id="StyleBoxTexture_y5ki2"]
-texture = ExtResource("1_iqtc0")
[sub_resource type="StyleBoxTexture" id="StyleBoxTexture_rtqkv"]
content_margin_left = 4.0
content_margin_top = 2.0
content_margin_right = 4.0
content_margin_bottom = 2.0
-texture = ExtResource("2_7any1")
[sub_resource type="StyleBoxTexture" id="StyleBoxTexture_47c11"]
-texture = ExtResource("3_3fgq6")
[sub_resource type="StyleBoxTexture" id="StyleBoxTexture_jf26r"]
content_margin_left = 4.0
content_margin_top = 4.0
content_margin_right = 4.0
content_margin_bottom = 4.0
-texture = ExtResource("1_rqugq")
[resource]
Button/colors/font_color = Color(0.133333, 0.133333, 0.133333, 1)
diff --git a/ui/theme_clear.tres b/ui/theme_clear.tres
index f5028a8..7fa57f0 100644
--- a/ui/theme_clear.tres
+++ b/ui/theme_clear.tres
@@ -52,7 +52,7 @@ content_margin_left = 3.0
content_margin_top = 0.0
content_margin_right = 3.0
content_margin_bottom = 0.0
-bg_color = Color(0.94902, 0.94902, 0.94902, 1)
+bg_color = Color(0.980392, 0.980392, 0.980392, 1)
border_width_left = 1
border_width_top = 1
border_width_right = 1
diff --git a/ui/window.tscn b/ui/window.tscn
index d27d7c5..f0c3d95 100644
--- a/ui/window.tscn
+++ b/ui/window.tscn
@@ -2,17 +2,17 @@
[ext_resource type="PackedScene" uid="uid://knmmuhon34rh" path="res://ui/bmp_texture_rect.tscn" id="1_4qpm3"]
[ext_resource type="Script" uid="uid://qdg2tjk8xmjt" path="res://ui/window.gd" id="1_hfgic"]
-[ext_resource type="Texture2D" uid="uid://22px3uxdg48t" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/basic_interface/titlebar_left.png" id="3_74c65"]
-[ext_resource type="Texture2D" uid="uid://dc2f7tx5xsico" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/basic_interface/titlebar_mid.bmp" id="3_mngfx"]
-[ext_resource type="Texture2D" uid="uid://dkqx0rjvi6aba" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/basic_interface/titlebar_right.png" id="5_qkejn"]
-[ext_resource type="Texture2D" uid="uid://clqwl83uoxeue" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/basic_interface/btnbar_mid1.bmp" id="6_mnaxm"]
-[ext_resource type="Texture2D" uid="uid://dmuuq7siyfv4r" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/basic_interface/sys_base_off.png" id="6_uftm1"]
+[ext_resource type="Texture2D" uid="uid://b40mcjrv0d0gi" path="res://client_data/data/texture/유저인터페이스/basic_interface/titlebar_left.png" id="3_74c65"]
+[ext_resource type="Texture2D" uid="uid://b3d3jmq8eso2v" path="res://client_data/data/texture/유저인터페이스/basic_interface/titlebar_mid.png" id="4_qkejn"]
+[ext_resource type="Texture2D" uid="uid://d22mmihwnjj0c" path="res://client_data/data/texture/유저인터페이스/basic_interface/titlebar_right.png" id="5_uftm1"]
+[ext_resource type="Texture2D" uid="uid://dwv8ca3u5xk3o" path="res://client_data/data/texture/유저인터페이스/basic_interface/sys_base_off.png" id="6_74c65"]
[ext_resource type="PackedScene" uid="uid://cjcm2mai50thr" path="res://ui/bmp_texture_button.tscn" id="7_m42e5"]
-[ext_resource type="Texture2D" uid="uid://dtaegqi7vx4ia" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/basic_interface/big_sys_close_off.png" id="8_vjbfl"]
-[ext_resource type="Texture2D" uid="uid://jwguf7fj0iyx" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/basic_interface/big_sys_close_on.png" id="9_kh8ey"]
-[ext_resource type="Texture2D" uid="uid://dif01o7ri7qop" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/basic_interface/btnbar_left1.png" id="10_ug6hj"]
-[ext_resource type="Texture2D" uid="uid://bp60ikxqixf6q" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/basic_interface/btnbar_right1.png" id="12_xgidv"]
-[ext_resource type="Texture2D" uid="uid://ch1t3k18kvhtk" path="res://client_data/data/texture/À¯ÀúÀÎÅÍÆäÀ̽º/basic_interface/btn_comparison_resize.png" id="13_sy0l2"]
+[ext_resource type="Texture2D" uid="uid://dt2t71nhoaelo" path="res://client_data/data/texture/유저인터페이스/basic_interface/big_sys_close_off.png" id="8_74c65"]
+[ext_resource type="Texture2D" uid="uid://dguxqcl61xj50" path="res://client_data/data/texture/유저인터페이스/basic_interface/big_sys_close_on.png" id="9_qkejn"]
+[ext_resource type="Texture2D" uid="uid://k78jsflcoc84" path="res://client_data/data/texture/유저인터페이스/basic_interface/btnbar_left1.png" id="10_74c65"]
+[ext_resource type="Texture2D" uid="uid://bn66ekthd5657" path="res://client_data/data/texture/유저인터페이스/basic_interface/btnbar_mid1.png" id="11_qkejn"]
+[ext_resource type="Texture2D" uid="uid://bwi568g2qyf3o" path="res://client_data/data/texture/유저인터페이스/basic_interface/btnbar_right1.png" id="12_uftm1"]
+[ext_resource type="Texture2D" uid="uid://cygyjjv5s6dx0" path="res://client_data/data/texture/유저인터페이스/basic_interface/btn_comparison_resize.png" id="13_74c65"]
[sub_resource type="StyleBoxFlat" id="StyleBoxFlat_fufdc"]
bg_color = Color(1, 1, 1, 1)
@@ -45,11 +45,11 @@ texture = ExtResource("3_74c65")
[node name="Middle" parent="VBoxContainer/TitleBar/TitleBarBackground" instance=ExtResource("1_4qpm3")]
layout_mode = 2
size_flags_horizontal = 3
-texture = ExtResource("3_mngfx")
+texture = ExtResource("4_qkejn")
[node name="Right" parent="VBoxContainer/TitleBar/TitleBarBackground" instance=ExtResource("1_4qpm3")]
layout_mode = 2
-texture = ExtResource("5_qkejn")
+texture = ExtResource("5_uftm1")
[node name="TitleBarElements" type="MarginContainer" parent="VBoxContainer/TitleBar"]
unique_name_in_owner = true
@@ -67,15 +67,15 @@ theme_override_constants/margin_right = 2
[node name="BMPTextureRect" parent="VBoxContainer/TitleBar/TitleBarButtons" instance=ExtResource("1_4qpm3")]
layout_mode = 2
size_flags_horizontal = 0
-texture = ExtResource("6_uftm1")
+texture = ExtResource("6_74c65")
stretch_mode = 3
[node name="CloseButton" parent="VBoxContainer/TitleBar/TitleBarButtons" instance=ExtResource("7_m42e5")]
unique_name_in_owner = true
layout_mode = 2
size_flags_horizontal = 8
-texture_normal = ExtResource("8_vjbfl")
-texture_hover = ExtResource("9_kh8ey")
+texture_normal = ExtResource("8_74c65")
+texture_hover = ExtResource("9_qkejn")
stretch_mode = 5
[node name="Body" type="PanelContainer" parent="VBoxContainer"]
@@ -94,16 +94,16 @@ theme_override_constants/separation = 0
[node name="BMPTextureRect" parent="VBoxContainer/ButtonBar/ButtonBarBackground" instance=ExtResource("1_4qpm3")]
layout_mode = 2
-texture = ExtResource("10_ug6hj")
+texture = ExtResource("10_74c65")
[node name="BMPTextureRect2" parent="VBoxContainer/ButtonBar/ButtonBarBackground" instance=ExtResource("1_4qpm3")]
layout_mode = 2
size_flags_horizontal = 3
-texture = ExtResource("6_mnaxm")
+texture = ExtResource("11_qkejn")
[node name="BMPTextureRect3" parent="VBoxContainer/ButtonBar/ButtonBarBackground" instance=ExtResource("1_4qpm3")]
layout_mode = 2
-texture = ExtResource("12_xgidv")
+texture = ExtResource("12_uftm1")
[node name="ButtonBarElements" type="MarginContainer" parent="VBoxContainer/ButtonBar"]
unique_name_in_owner = true
@@ -120,7 +120,7 @@ layout_mode = 2
size_flags_horizontal = 8
size_flags_vertical = 8
mouse_default_cursor_shape = 2
-texture = ExtResource("13_sy0l2")
+texture = ExtResource("13_74c65")
stretch_mode = 5
[connection signal="gui_input" from="VBoxContainer/TitleBar" to="." method="_on_title_bar_gui_input"]