9.25上午

This commit is contained in:
TsubakiLoL 2024-09-25 11:52:36 +08:00
parent f0a6e44f61
commit 0bf7090291
14 changed files with 190 additions and 19 deletions

View File

@ -171,6 +171,7 @@ func _ready() -> void:
load_script_data() load_script_data()
load_event_data() load_event_data()
load_scene_data() load_scene_data()
load_card_data()
load_character_data() load_character_data()
load_map_data() load_map_data()
load_npc_data() load_npc_data()

View File

@ -1,6 +1,17 @@
{ {
"card_01":{ "card_01":{
"name":"测试卡01", "name":"测试卡01(友方目标)",
"icon":"?" "icon":"?",
} "target_queue":0
},
"card_02":{
"name":"测试卡02(不需要目标)",
"icon":"?",
},
"card_03":{
"name":"测试卡03(敌方目标)",
"icon":"?",
"target_queue":1
},
} }

View File

@ -54,3 +54,8 @@ mouse_right={
"events": [Object(InputEventMouseButton,"resource_local_to_scene":false,"resource_name":"","device":-1,"window_id":0,"alt_pressed":false,"shift_pressed":false,"ctrl_pressed":false,"meta_pressed":false,"button_mask":2,"position":Vector2(242, 15),"global_position":Vector2(251, 61),"factor":1.0,"button_index":2,"canceled":false,"pressed":true,"double_click":false,"script":null) "events": [Object(InputEventMouseButton,"resource_local_to_scene":false,"resource_name":"","device":-1,"window_id":0,"alt_pressed":false,"shift_pressed":false,"ctrl_pressed":false,"meta_pressed":false,"button_mask":2,"position":Vector2(242, 15),"global_position":Vector2(251, 61),"factor":1.0,"button_index":2,"canceled":false,"pressed":true,"double_click":false,"script":null)
] ]
} }
[layer_names]
2d_physics/layer_1="队伍0"
2d_physics/layer_2="队伍1"

View File

@ -2,10 +2,13 @@ extends Control
class_name Card class_name Card
@onready var state_machine: StateMachine = $state_machine @onready var state_machine: StateMachine = $state_machine
@onready var fight_card: TextureRect = $fight_card @onready var fight_card: TextureRect = $fight_card
@onready var arrow: card_arrow = $arrow
var target_queue:int=-1
var scale_multiple:float=1.1 var scale_multiple:float=1.1
func _ready() -> void: func _ready() -> void:
state_machine.launch() state_machine.launch()
func _on_fight_card_mouse_entered() -> void: func _on_fight_card_mouse_entered() -> void:
state_machine.send_message("mouse_enter") state_machine.send_message("mouse_enter")
pass # Replace with function body. pass # Replace with function body.
@ -16,10 +19,22 @@ func _on_fight_card_mouse_exited() -> void:
state_machine.send_message("mouse_exit") state_machine.send_message("mouse_exit")
pass # Replace with function body. pass # Replace with function body.
var data:Dictionary var data:Dictionary
##设置卡牌信息
func set_data(id:String): func set_data(id:String):
var d=Global.get_card_data(id)
print(d)
if d!=null:
data=d
fight_card.set_data(d)
if data.has("target_queue"):
target_queue=data["target_queue"]
pass pass
##该卡牌是否需要选择目标
func need_target():
return target_queue!=-1
##获取该卡牌的目标
func get_target()->int:
return target_queue
var last_move_tween:Tween var last_move_tween:Tween
func move_to(from_pos:Vector2,to_pos:Vector2,time:float=0.5): func move_to(from_pos:Vector2,to_pos:Vector2,time:float=0.5):
if last_move_tween!=null: if last_move_tween!=null:
@ -54,3 +69,9 @@ func get_self_index_position():
func request_resize(): func request_resize():
state_machine.send_message("resize") state_machine.send_message("resize")
func open_arrow():
arrow.start()
func close_arrow():
arrow.stop()
func set_arrow_queue(q:int):
arrow.set_select_queue(q)

View File

@ -1,4 +1,4 @@
[gd_scene load_steps=11 format=3 uid="uid://8a2mwnnmnecl"] [gd_scene load_steps=14 format=3 uid="uid://8a2mwnnmnecl"]
[ext_resource type="PackedScene" uid="uid://chowelwcfnsxs" path="res://scene/fight_card.tscn" id="1_nmkht"] [ext_resource type="PackedScene" uid="uid://chowelwcfnsxs" path="res://scene/fight_card.tscn" id="1_nmkht"]
[ext_resource type="Script" path="res://scene/card.gd" id="1_wc0x3"] [ext_resource type="Script" path="res://scene/card.gd" id="1_wc0x3"]
@ -8,8 +8,11 @@
[ext_resource type="Script" path="res://scene/card_state_machine/focus.gd" id="6_3e38c"] [ext_resource type="Script" path="res://scene/card_state_machine/focus.gd" id="6_3e38c"]
[ext_resource type="Script" path="res://scene/card_state_machine/selected.gd" id="7_ugr71"] [ext_resource type="Script" path="res://scene/card_state_machine/selected.gd" id="7_ugr71"]
[ext_resource type="Script" path="res://scene/card_state_machine/selected_back.gd" id="8_adb0l"] [ext_resource type="Script" path="res://scene/card_state_machine/selected_back.gd" id="8_adb0l"]
[ext_resource type="Script" path="res://scene/card_state_machine/select_target.gd" id="8_kik8t"]
[ext_resource type="Script" path="res://scene/card_state_machine/queue.gd" id="8_y4vrd"] [ext_resource type="Script" path="res://scene/card_state_machine/queue.gd" id="8_y4vrd"]
[ext_resource type="Script" path="res://scene/card_state_machine/exe.gd" id="9_40m88"] [ext_resource type="Script" path="res://scene/card_state_machine/exe.gd" id="9_40m88"]
[ext_resource type="PackedScene" uid="uid://c7vtcaeg4nkbu" path="res://scene/card_state_machine/arrow.tscn" id="11_gjfgy"]
[ext_resource type="Script" path="res://scene/card_state_machine/discard.gd" id="12_sl7jh"]
[node name="card" type="Control"] [node name="card" type="Control"]
layout_direction = 1 layout_direction = 1
@ -44,6 +47,9 @@ script = ExtResource("6_3e38c")
[node name="selected" type="Node" parent="state_machine"] [node name="selected" type="Node" parent="state_machine"]
script = ExtResource("7_ugr71") script = ExtResource("7_ugr71")
[node name="select_target" type="Node" parent="state_machine"]
script = ExtResource("8_kik8t")
[node name="selected_back" type="Node" parent="state_machine"] [node name="selected_back" type="Node" parent="state_machine"]
script = ExtResource("8_adb0l") script = ExtResource("8_adb0l")
@ -53,5 +59,10 @@ script = ExtResource("8_y4vrd")
[node name="exe" type="Node" parent="state_machine"] [node name="exe" type="Node" parent="state_machine"]
script = ExtResource("9_40m88") script = ExtResource("9_40m88")
[node name="discard" type="Node" parent="state_machine"]
script = ExtResource("12_sl7jh")
[node name="arrow" parent="." instance=ExtResource("11_gjfgy")]
[connection signal="mouse_entered" from="fight_card" to="." method="_on_fight_card_mouse_entered"] [connection signal="mouse_entered" from="fight_card" to="." method="_on_fight_card_mouse_entered"]
[connection signal="mouse_exited" from="fight_card" to="." method="_on_fight_card_mouse_exited"] [connection signal="mouse_exited" from="fight_card" to="." method="_on_fight_card_mouse_exited"]

View File

@ -10,6 +10,11 @@ class_name card_arrow
@export var arrowImageRotate:float=PI/2 @export var arrowImageRotate:float=PI/2
##箭头图片容器场景 ##箭头图片容器场景
@export var arrowImageScene:PackedScene @export var arrowImageScene:PackedScene
##用来检测目标的
@onready var area: Area2D = $Area2D
##是否开启 ##是否开启
@export var is_start:bool=false @export var is_start:bool=false
@export_group("缩放") @export_group("缩放")
@ -19,7 +24,19 @@ class_name card_arrow
@export var max_scale:float=2 @export var max_scale:float=2
##图片节点队列 ##图片节点队列
var texture_array:Array[arrowImage]=[] var texture_array:Array[arrowImage]=[]
##设置选择目标的对象
func set_select_queue(q:int):
match q:
0:
area.set_collision_layer(1)
area.set_collision_mask(1)
1:
area.set_collision_layer(2)
area.set_collision_mask(2)
pass
func _ready(): func _ready():
curve.bake() curve.bake()
for i in range(texture_num): for i in range(texture_num):
var new_texture=arrowImageScene.instantiate() var new_texture=arrowImageScene.instantiate()
@ -29,7 +46,8 @@ func _ready():
new_texture.hide() new_texture.hide()
texture_array[texture_num-1].set_image(texture_arrow,2) texture_array[texture_num-1].set_image(texture_arrow,2)
func replace_texture(): func replace_texture():
var mouse_pos=(get_viewport().get_mouse_position()-self.global_position) var mouse_pos=(get_global_mouse_position()-self.global_position)
area.global_position=get_global_mouse_position()
texture_array[0].rotation=texture_array[1].rotation texture_array[0].rotation=texture_array[1].rotation
for i in range(1,texture_array.size()): for i in range(1,texture_array.size()):
var t=logWithBase(float(i)/(texture_array.size()-1)+1,2) var t=logWithBase(float(i)/(texture_array.size()-1)+1,2)
@ -55,8 +73,13 @@ func logWithBase(value, base)->float:
func start(): func start():
for i in texture_array: for i in texture_array:
i.show() i.show()
area.monitoring=true
area.monitorable=true
is_start=true is_start=true
func stop(): func stop():
for i in texture_array: for i in texture_array:
i.hide() i.hide()
area.position=Vector2.ZERO
is_start=false is_start=false
area.monitoring=false
area.monitorable=false

View File

@ -1,10 +1,49 @@
[gd_scene load_steps=2 format=3 uid="uid://c7vtcaeg4nkbu"] [gd_scene load_steps=9 format=3 uid="uid://c7vtcaeg4nkbu"]
[ext_resource type="Script" path="res://scene/card_state_machine/arrow.gd" id="1_oqukl"] [ext_resource type="Script" path="res://scene/card_state_machine/arrow.gd" id="1_oqukl"]
[ext_resource type="PackedScene" uid="uid://dg27pietgq7qd" path="res://scene/card_state_machine/arrowImg.tscn" id="2_ba6kg"]
[sub_resource type="Gradient" id="Gradient_7pfi1"]
offsets = PackedFloat32Array(0, 0.466667, 0.509804)
colors = PackedColorArray(0, 0.463205, 0.823238, 1, 0, 0.462745, 0.823529, 1, 1, 1, 1, 0)
[sub_resource type="GradientTexture2D" id="GradientTexture2D_qscu6"]
gradient = SubResource("Gradient_7pfi1")
fill = 1
fill_from = Vector2(0.5, 0.5)
[sub_resource type="Gradient" id="Gradient_8a280"]
offsets = PackedFloat32Array(0, 0.278431, 0.305882)
colors = PackedColorArray(0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0)
[sub_resource type="GradientTexture2D" id="GradientTexture2D_t54e3"]
gradient = SubResource("Gradient_8a280")
fill = 2
fill_from = Vector2(0.517094, 1)
[sub_resource type="Curve" id="Curve_035f2"]
_data = [Vector2(0, 0.600293), 0.0, 0.0, 0, 0, Vector2(1e-05, 0.581259), 0.0, 0.0, 0, 0, Vector2(1, 1), 0.0, 0.0, 0, 0]
point_count = 3
[sub_resource type="CircleShape2D" id="CircleShape2D_cys1g"]
radius = 11.1803
[node name="arrow" type="Control"] [node name="arrow" type="Control"]
layout_mode = 3 layout_mode = 3
anchors_preset = 0 anchors_preset = 0
offset_right = 40.0
offset_bottom = 40.0
script = ExtResource("1_oqukl") script = ExtResource("1_oqukl")
texture_circle = SubResource("GradientTexture2D_qscu6")
texture_arrow = SubResource("GradientTexture2D_t54e3")
texture_num = 20
arrowImageScene = ExtResource("2_ba6kg")
curve = SubResource("Curve_035f2")
max_scale = 1.0
[node name="Area2D" type="Area2D" parent="."]
collision_layer = 0
collision_mask = 0
monitoring = false
monitorable = false
[node name="CollisionShape2D" type="CollisionShape2D" parent="Area2D"]
shape = SubResource("CircleShape2D_cys1g")

View File

@ -1,8 +1,11 @@
extends Control extends Control
class_name CardMachine class_name CardMachine
const CARD = preload("res://scene/card.tscn") const CARD = preload("res://scene/card.tscn")
var rand_release:float=20
@export var release_card_pos:Control
var distance:float=100 var distance:float=100
var card_arr:Array[Card]=[] var card_arr:Array[Card]=[]
var queue_card:Array[Card]=[]
func get_index_position(index:int)->Vector2: func get_index_position(index:int)->Vector2:
var center=size/2 var center=size/2
var left=center-Vector2(distance*card_arr.size()/2,0) var left=center-Vector2(distance*card_arr.size()/2,0)
@ -15,11 +18,27 @@ func get_put_pos():
return size/2 return size/2
func add_card(card_id:String,num:int): func add_card(card_id:String,num:int):
var data=Global.get_card_data(card_id)
for i in num: for i in num:
var new_card=CARD.instantiate() var new_card=CARD.instantiate() as Card
add_child(new_card) add_child(new_card)
new_card.set_data(card_id)
card_arr.append(new_card) card_arr.append(new_card)
for j in card_arr: for j in card_arr:
j.request_resize() j.request_resize()
pass pass
#获取释放位置
func get_release_pos()->Vector2:
var pos:Vector2
if release_card_pos!=null:
pos=release_card_pos.position
else:
pos=Vector2.ZERO
var rand:Vector2=Vector2(randf_range(-rand_release,rand_release),randf_range(-rand_release,rand_release))
return pos+rand
func add_to_queue(card:Card):
if queue_card.size()==0:
queue_card.append(card)
card.send("your_turn")

View File

@ -0,0 +1 @@
extends State

View File

@ -0,0 +1,30 @@
extends State
var init_position:Vector2
var target_y:float=200
func enter_state(n):
init_position=n
get_player().open_arrow()
func update_state(delta):
if Input.is_action_just_released("mouse_left"):
change_to_state("selected_back")
return
if Input.is_action_just_pressed("mouse_right"):
change_to_state("selected_back")
return
pass
var change_y=(init_position-get_player().get_parent().get_local_mouse_position()).y
if change_y<target_y:
change_to_state("selected",init_position)
return
func update_state_phy(delta):
pass
func exit_state():
get_player().close_arrow()
pass
func time_out():
pass
func process_message(type:String,n):
pass

View File

@ -1,6 +1,13 @@
extends State extends State
var init_position:Vector2=Vector2.ZERO
var target_y:float=200
var need_target:bool=false
func enter_state(n): func enter_state(n):
get_player().up() get_player().up()
need_target=get_player().need_target()
init_position=get_player().position
if n is Vector2:
init_position=n
pass pass
func update_state(delta): func update_state(delta):
get_player().position=get_player().get_parent().get_local_mouse_position() get_player().position=get_player().get_parent().get_local_mouse_position()
@ -10,6 +17,10 @@ func update_state(delta):
if Input.is_action_just_pressed("mouse_right"): if Input.is_action_just_pressed("mouse_right"):
change_to_state("selected_back") change_to_state("selected_back")
return return
var change_y=(init_position-get_player().get_parent().get_local_mouse_position()).y
if need_target and change_y>target_y:
change_to_state("select_target",init_position)
return
pass pass
func update_state_phy(delta): func update_state_phy(delta):
pass pass

View File

@ -7,9 +7,6 @@ func enter_state(n):
pass pass
func update_state(delta): func update_state(delta):
get_player().position=get_player().get_parent().get_local_mouse_position() get_player().position=get_player().get_parent().get_local_mouse_position()
if Input.is_action_just_released("mouse_left"):
change_to_state("focus")
return
pass pass
func update_state_phy(delta): func update_state_phy(delta):

View File

@ -12,5 +12,7 @@ func _process(delta: float) -> void:
func _on_tool_button_pressed() -> void: func _on_tool_button_pressed() -> void:
%card_machine.add_card("xxx",1) %card_machine.add_card("card_01",1)
%card_machine.add_card("card_02",1)
%card_machine.add_card("card_03",1)
pass # Replace with function body. pass # Replace with function body.

View File

@ -4,8 +4,8 @@ extends TextureRect
@onready var icon: TextureRect = $icon @onready var icon: TextureRect = $icon
var data:Dictionary var data:Dictionary
func set_card(id:String): func set_data(_data:Dictionary):
data=Global.get_card_data(id) data=_data
icon.texture=Global.get_texture(data["icon"]) icon.texture=Global.get_texture(_data["icon"])
n.text=data["name"] n.text=data["name"]
pass pass