From 35b0f811f23f029110373798b19d9d0895d907f0 Mon Sep 17 00:00:00 2001 From: Daniel Weipert Date: Sun, 5 Jan 2025 16:54:36 +0100 Subject: next commit --- extractor/grf.gd | 225 ++----------------------------------------------------- 1 file changed, 8 insertions(+), 217 deletions(-) (limited to 'extractor/grf.gd') diff --git a/extractor/grf.gd b/extractor/grf.gd index 1d19046..a723fdc 100644 --- a/extractor/grf.gd +++ b/extractor/grf.gd @@ -230,186 +230,15 @@ func convert(destination: String = "res://client_data"): var sprite = SpriteFormat.from_bytes(file_entry.get_contents(file_access)) sprite.save_to_file(base_file_directory_path) - elif file_path.ends_with(".act") and file_path.contains(player_head_path_part): - continue + elif file_path.ends_with(".act") and file_path.contains(player_head_path_part): #or file_path.contains(player_body_path_part): + #continue if not FileAccess.file_exists("%s/000.png.import" % base_file_directory_path): continue - var scene := PackedScene.new() - var scene_root := Node2D.new() - scene_root.name = "Actions" - scene_root.set_script(load("res://extractor/actions.gd")) - - var animation_player := AnimationPlayer.new() - animation_player.name = "AnimationPlayer" - animation_player.unique_name_in_owner = true - scene_root.add_child(animation_player) - animation_player.owner = scene_root - - var sprite_layers := CanvasGroup.new() - sprite_layers.name = "SpriteLayers" - sprite_layers.unique_name_in_owner = true - - scene_root.add_child(sprite_layers) - sprite_layers.owner = scene_root - - var track_properties = [ - "animation", - "frame", - "speed_scale", - "position", - "self_modulate", - "scale", - "rotation_degrees", - "flip_h", - "visible", - ] - - var sprite_frames := SpriteFrames.new() - #sprite_frames.add_animation("default") - for img_file_path in DirAccess.get_files_at(base_file_directory_path): - if img_file_path.ends_with(".png"): - sprite_frames.add_frame("default", load("%s/%s" % [base_file_directory_path, img_file_path])) - - var animation_library := AnimationLibrary.new() - var action_data := ActionFormat.from_bytes(ByteStream.from_bytes(file_entry.get_contents(file_access))) - - # get max number of sprite layers for all actions - var action_sprite_layers_max_count = action_data.actions.reduce(func(accum, action: ActionFormat.ActionData): - return max(accum, action.motions.reduce(func(accum2, motion: ActionFormat.Motion): - return max(accum2, motion.sprite_layer_count) - , 0)) - , 0) + var action := ActionFormat.from_bytes(ByteStream.from_bytes(file_entry.get_contents(file_access))) + var scene_root := action.convert(file_name, base_file_directory_path) - # add Nodes for each sprite layer - for sprite_layer_idx in action_sprite_layers_max_count: - var sprite = AnimatedSprite2D.new() - sprite.centered = false # 必要!! - sprite.texture_filter = CanvasItem.TEXTURE_FILTER_NEAREST - sprite.sprite_frames = sprite_frames - sprite.name = str(sprite_layer_idx).pad_zeros(3) - sprite_layers.add_child(sprite) - sprite.owner = scene_root - - for action_idx in action_data.actions.size(): - var action: ActionFormat.ActionData = action_data.actions[action_idx] - var frame_timing_base := ((action_data.frame_times[action_idx] * 24) / 1000) - - if file_path.contains("cursors") and action_idx == 0: - frame_timing_base = ((action_data.frame_times[action_idx] * 24 * 2) / 1000) - - # add animation for each action - var animation := Animation.new() - animation.loop_mode = Animation.LOOP_LINEAR - animation.length = frame_timing_base * action.motion_count - animation_library.add_animation(str(action_idx).pad_zeros(3), animation) - - # get max number of sprite layers for current action motions - var motion_sprite_layers_max_count = action.motions.reduce(func(accum, motion: ActionFormat.Motion): - return max(accum, motion.sprite_layer_count) - , 0) - - # add animation tracks for each sprite layer - for sprite_layer_idx in motion_sprite_layers_max_count: - var sprite := sprite_layers.get_child(sprite_layer_idx) - for property_idx in track_properties.size(): - var track_idx = (sprite_layer_idx * track_properties.size()) + property_idx - animation.add_track(Animation.TYPE_VALUE, track_idx) - animation.value_track_set_update_mode(track_idx, Animation.UPDATE_DISCRETE) - animation.track_set_path( - track_idx, - "%s:%s" % ["SpriteLayers/" + sprite.name, track_properties[property_idx]] - ) - - for i in range(motion_sprite_layers_max_count, action_sprite_layers_max_count): - var sprite := sprite_layers.get_child(i) - var track_idx = animation.add_track(Animation.TYPE_VALUE) - animation.track_set_path( - track_idx, - "%s:visible" % ["SpriteLayers/" + sprite.name] - ) - animation.track_insert_key(track_idx, 0.0, false) - - # add animation tracks - for motion_idx in action.motions.size(): - var motion: ActionFormat.Motion = action.motions[motion_idx] - - # TODO: no animations to speak of available ? - if motion.event_id == -1: - continue - - var timing = motion_idx * frame_timing_base - var visible_key = 0 - - # add visible = false animation tracks to other sprite_layers - for i in motion_sprite_layers_max_count: - var track_idx = i * track_properties.size() + track_properties.find("visible") - visible_key = animation.track_insert_key(track_idx, timing, false) - - for sprite_layer_idx in motion.sprite_layers.size(): - var layer: ActionFormat.SpriteLayer = motion.sprite_layers[sprite_layer_idx] - - var track_base_idx = sprite_layer_idx * track_properties.size() - - animation.track_insert_key( - track_base_idx + track_properties.find("animation"), - timing, - "default" - ) - - animation.track_insert_key( - track_base_idx + track_properties.find("frame"), - timing, - layer.sprite_index - ) - - animation.track_insert_key( - track_base_idx + track_properties.find("speed_scale"), - timing, - 1.0 - ) - - var layer_image := sprite_frames.get_frame_texture("default", layer.sprite_index) - var position: Vector2 = layer.get_position() - ceil(layer_image.get_size() / 2) # for fixing half pixel drawing - var rotated = layer_image.get_size().rotated(deg_to_rad(layer.rotation_degrees)) - var distance = layer_image.get_size() - rotated - animation.track_insert_key( - track_base_idx + track_properties.find("position"), - timing, - position + (distance / 2) - ) - - animation.track_insert_key( - track_base_idx + track_properties.find("self_modulate"), - timing, - layer.get_color() - ) - - animation.track_insert_key( - track_base_idx + track_properties.find("scale"), - timing, - layer.get_scale() - ) - - animation.track_insert_key( - track_base_idx + track_properties.find("rotation_degrees"), - timing, - layer.rotation_degrees - ) - - animation.track_insert_key( - track_base_idx + track_properties.find("flip_h"), - timing, - layer.flip_h - ) - - animation.track_set_key_value( - track_base_idx + track_properties.find("visible"), - visible_key, - true - ) - - animation_player.add_animation_library("", animation_library) + var scene := PackedScene.new() scene.pack(scene_root) # TODO: doesn't work if png is not imported via editor focus => run game twice @@ -418,53 +247,15 @@ func convert(destination: String = "res://client_data"): # Map.rsw and .gnd and .gat - if file_path.ends_with(".rsw") and file_path.contains("pay_dun"): + if file_path.ends_with(".rsw") and (file_path.contains("pay_dun") or file_path.contains("iz_int") or file_path.contains("int_land")): var rsw = RSWFormat.from_bytes(ByteStream.from_bytes(file_entry.get_contents(file_access))) - - var gnd_file_path = "res://client_data/data/%s" % rsw.gnd_file - var gnd = GNDFormat.from_bytes(ByteStream.from_bytes(FileAccess.get_file_as_bytes(gnd_file_path))) - - var gat_file_path = "res://client_data/data/%s" % rsw.gat_file - var gat = GATFormat.from_bytes(ByteStream.from_bytes(FileAccess.get_file_as_bytes(gat_file_path))) + var scene_root := rsw.convert(file_name, "res://client_data") var scene := PackedScene.new() - var scene_root := Node3D.new() - scene_root.name = file_name - - for resource in rsw.map_resources: - if resource is RSWFormat.SpatialAudioSource: - var audio_file_path := "res://client_data/data/wav/%s" % resource.audio_file - if not FileAccess.file_exists(audio_file_path): - continue - - var audio = AudioStreamPlayer3D.new() - audio.stream = load(audio_file_path) - audio.name = resource.audio_file - audio.position = resource.get_position() - audio.volume_linear = resource.volume_gain - audio.max_distance = resource.audio_range - scene_root.add_child(audio, true) - audio.owner = scene_root - - var surfrace_tool := SurfaceTool.new() - for surface: GNDFormat.Surface in gnd.surfaces: - pass - #surfrace_tool.add_vertex() - scene.pack(scene_root) ResourceSaver.save(scene, "%s/%s/%s.tscn" % [destination, base_directory_path, file_name]) static func decode_string(bytes: PackedByteArray): + # TODO: use iconv to decode EUC-KR return bytes.get_string_from_ascii() - @warning_ignore("unreachable_code") - # TODO: check unicode codepoints and parse accordingly - var string = bytes.get_string_from_utf32() - if string == "": - string = bytes.get_string_from_utf16() - if string == "": - string = bytes.get_string_from_utf8() - if string == "": - string = bytes.get_string_from_ascii() - - return string -- cgit v1.2.3