Dev pour la béta 1

* ajout des artefacts avec la pile et l'emplacement de graine
* affichage des artefacts dans le vaisseau sur une étagère
* ajout des distributeurs d'artefacts dans les régions
* affichage des attributs de bases de plantes dans le vaisseau
* changement de l'affichage du choix des régions
* changement des icônes du détecteur
This commit is contained in:
2026-04-10 16:16:54 +02:00
parent 84a2eafe57
commit 8062c42e7b
154 changed files with 2780 additions and 1772 deletions

View File

@@ -6,7 +6,8 @@ enum State {STARTED, IN_PROGRESS, FINISHED}
const RUN_POINTS_NEXT_NUMBER : int = 2
const RUN_POINT_MAX_LEVEL = 5 # TODO
signal current_run_point_changed
signal current_run_point_changed(rp : RunPoint)
signal artefacts_changed(artefact : Array[Artefact])
var run_seed = randi()
@export var next_run_points : Array[RunPoint] = generate_next_run_points()
@@ -18,7 +19,19 @@ var run_seed = randi()
@export var last_used_modifier_name = ""
#region ------------------ Generation ------------------
@export var artefacts : Array[Artefact] = []
var plant_info = RunDataPlantInfo.new(self)
func get_state() -> State:
if not current_run_point:
return State.STARTED
elif current_run_point.level == RUN_POINT_MAX_LEVEL:
return State.FINISHED
else :
return State.IN_PROGRESS
#region ------------------ Run Points ------------------
func generate_next_run_points(level = 0) -> Array[RunPoint]:
@@ -35,13 +48,12 @@ func generate_next_run_points(level = 0) -> Array[RunPoint]:
)
return next_run_points
func generate_next_run_point(level = 0) -> RunPoint:
var region_parameter = RegionParameter.new()
region_parameter.level = level
region_parameter.region_flags = get_region_flags(region_parameter)
region_parameter.modifiers = get_region_modifiers()
region_parameter.modifiers = get_bad_region_modifiers()
region_parameter.modifiers.append_array(get_good_region_modifiers())
return RunPoint.new(
level,
@@ -51,7 +63,6 @@ func generate_next_run_point(level = 0) -> RunPoint:
func generate_borea_base_run_point() -> RunPoint:
var region_parameter = RegionParameter.new()
region_parameter.level = RUN_POINT_MAX_LEVEL
region_parameter.region_flags = get_region_flags(region_parameter)
region_parameter.region_name = tr("BOREA_BASE")
return RunPoint.new(
@@ -59,16 +70,6 @@ func generate_borea_base_run_point() -> RunPoint:
region_parameter
)
#endregion
func get_state() -> State:
if not current_run_point:
return State.STARTED
elif current_run_point.level == RUN_POINT_MAX_LEVEL:
return State.FINISHED
else :
return State.IN_PROGRESS
func get_next_run_points() -> Array[RunPoint]:
if current_run_point and current_run_point.level == RUN_POINT_MAX_LEVEL:
return []
@@ -84,15 +85,10 @@ func choose_next_run_point(run_point : RunPoint) -> RunPoint:
last_used_modifier_name = current_run_point.region_parameter.modifiers[0].get_modifier_name()
return current_run_point
func get_region_flags(region_parameter : RegionParameter) -> Array[String]:
var flags : Array[String] = []
func get_good_region_modifiers() -> Array[RegionModifier]:
return [VendingMachineModifier.new(),VendingMachineModifier.new()]
if region_parameter.level == RUN_POINT_MAX_LEVEL and GameInfo.game_data.game_mode == GameData.GameMode.STORY:
flags.append("borea")
return flags
func get_region_modifiers() -> Array[RegionModifier]:
func get_bad_region_modifiers() -> Array[RegionModifier]:
var possible_modifiers : Array[RegionModifier] = [
AridModifier.new(),
HumidModifier.new(),
@@ -109,3 +105,13 @@ func get_region_modifiers() -> Array[RegionModifier]:
last_used_modifier_name = choosen_modifier.get_modifier_name()
return [choosen_modifier]
#endregion
#region ------------------ Artefacts ------------------
func add_artefacts(a: Artefact):
artefacts.append(a)
artefacts_changed.emit(artefacts)
#endregion

View File

@@ -0,0 +1,43 @@
extends Node
class_name RunDataPlantInfo
signal updated
const DEFAULT_PLANT_AREA_RADIUS = 20
const DEFAULT_PLANT_INFLUENCE_RADIUS = 100
const DEFAULT_GROWING_TIME = 2
const DEFAULT_LIFETIME = 6
const DEFAULT_BASE_SCORE = 1
const DEFAULT_SEED_NUMBER = 2
const DEFAULT_SEED_RANDOM_LOOSE = 1
var run_data : RunData
func _init(
_run_data : RunData
):
run_data = _run_data
var region_modifiers : Array[RegionModifier]
var artefacts : Array[Artefact] = []
func get_plant_area_radius() -> int:
return DEFAULT_PLANT_AREA_RADIUS
func get_plant_influence_radius() -> int:
return DEFAULT_PLANT_INFLUENCE_RADIUS
func get_growing_time() -> int:
return DEFAULT_GROWING_TIME
func get_lifetime() -> int:
return DEFAULT_LIFETIME
func get_base_score() -> int:
return DEFAULT_BASE_SCORE
func get_seed_number() -> int:
return DEFAULT_SEED_NUMBER
func get_seed_random_loose() -> int:
return DEFAULT_SEED_RANDOM_LOOSE

View File

@@ -0,0 +1 @@
uid://cf8sn5n5u2hd6

View File

@@ -4,7 +4,7 @@ class_name RunPoint
const DANGER_ICON = preload("res://common/icons/skull.svg")
const TYPE_ICON = preload("res://common/icons/map-pin.svg")
const OBJECTIVE_ICON = preload("res://common/icons/dna.svg")
const OBJECTIVE_ICON = preload("res://common/icons/growth.svg")
const CHARGE_ICON = preload("res://common/icons/bolt.svg")
@export var level : int = 0 # X pos along the planet, and difficulty
@@ -24,15 +24,20 @@ func _init(
position = _position
func card_info() -> CardInfo:
var info = CardInfo.new(region_parameter.region_name)
info.important_stat_icon = DANGER_ICON
info.important_stat_text = "%d" % level
var info = CardInfo.new(
region_parameter.region_name,
tr("REGION_TO_VISIT")
)
info.type_icon = TYPE_ICON
info.stats.append_array([
CardStatInfo.new(str(region_parameter.objective), OBJECTIVE_ICON),
CardStatInfo.new(str(region_parameter.charges), CHARGE_ICON),
CardStatInfo.new(str(region_parameter.get_objective()), OBJECTIVE_ICON),
CardStatInfo.new(str(region_parameter.get_charge()), CHARGE_ICON),
])
for m in region_parameter.modifiers:
info.sections.append(m.card_section())
return info