diff --git a/include/maps.hrl b/include/maps.hrl index c3e76ed..4141554 100644 --- a/include/maps.hrl +++ b/include/maps.hrl @@ -105,6 +105,26 @@ {1001124, [{type, mission}, {file, "data/missions/seed-awakening.3.s2.quest.nbl"}, {start, [0, 113, 0]}]}, {1001125, [{type, mission}, {file, "data/missions/seed-awakening.3.s3.quest.nbl"}, {start, [0, 113, 0]}]}, + % True Darkness + + %~ {1001200, [{type, mission}, {file, "data/missions/true-darkness.1.c.quest.nbl"}, {start, [0, 130, 0]}]}, + %~ {1001201, [{type, mission}, {file, "data/missions/true-darkness.1.b.quest.nbl"}, {start, [0, 130, 0]}]}, + %~ {1001202, [{type, mission}, {file, "data/missions/true-darkness.1.a.quest.nbl"}, {start, [0, 130, 0]}]}, + %~ {1001203, [{type, mission}, {file, "data/missions/true-darkness.1.s.quest.nbl"}, {start, [0, 130, 0]}]}, + %~ {1001204, [{type, mission}, {file, "data/missions/true-darkness.1.s2.quest.nbl"}, {start, [0, 130, 0]}]}, + + {1001210, [{type, mission}, {file, "data/missions/true-darkness.2.c.quest.nbl"}, {start, [0, 131, 0]}]}, + %~ {1001211, [{type, mission}, {file, "data/missions/true-darkness.2.b.quest.nbl"}, {start, [0, 131, 0]}]}, + {1001212, [{type, mission}, {file, "data/missions/true-darkness.2.a.quest.nbl"}, {start, [0, 131, 0]}]}, + {1001213, [{type, mission}, {file, "data/missions/true-darkness.2.s.quest.nbl"}, {start, [0, 131, 0]}]}, + %~ {1001214, [{type, mission}, {file, "data/missions/true-darkness.2.s2.quest.nbl"}, {start, [0, 131, 0]}]}, + + {1001220, [{type, mission}, {file, "data/missions/true-darkness.3.c.quest.nbl"}, {start, [0, 802, 0]}]}, + {1001221, [{type, mission}, {file, "data/missions/true-darkness.3.b.quest.nbl"}, {start, [0, 802, 0]}]}, + {1001222, [{type, mission}, {file, "data/missions/true-darkness.3.a.quest.nbl"}, {start, [0, 802, 0]}]}, + %~ {1001223, [{type, mission}, {file, "data/missions/true-darkness.3.s.quest.nbl"}, {start, [0, 802, 0]}]}, + {1001224, [{type, mission}, {file, "data/missions/true-darkness.3.s2.quest.nbl"}, {start, [0, 802, 0]}]}, + % Phantom Ruins (Linear Line counter) %~ {1060300, [{type, mission}, {file, "data/missions/phantom-ruins.c.quest.nbl"}, {start, [0, 8002, 0]}]}, @@ -251,6 +271,41 @@ {[1001125, 1], [{file, "data/missions/seed-awakening.3.s3.zone-1.nbl"}]}, {[1001125, 2], [{file, "data/missions/seed-awakening.3.s3.zone-2.nbl"}]}, + % True Darkness + + %~ {[1001200, 0], [{file, "data/missions/true-darkness.1.c.zone-0.nbl"}]}, + %~ {[1001200, 1], [{file, "data/missions/true-darkness.1.c.zone-1.nbl"}]}, + %~ {[1001201, 0], [{file, "data/missions/true-darkness.1.b.zone-0.nbl"}]}, + %~ {[1001201, 1], [{file, "data/missions/true-darkness.1.b.zone-1.nbl"}]}, + %~ {[1001202, 0], [{file, "data/missions/true-darkness.1.a.zone-0.nbl"}]}, + %~ {[1001202, 1], [{file, "data/missions/true-darkness.1.a.zone-1.nbl"}]}, + %~ {[1001203, 0], [{file, "data/missions/true-darkness.1.s.zone-0.nbl"}]}, + %~ {[1001203, 1], [{file, "data/missions/true-darkness.1.s.zone-1.nbl"}]}, + %~ {[1001204, 0], [{file, "data/missions/true-darkness.1.s2.zone-0.nbl"}]}, + %~ {[1001204, 1], [{file, "data/missions/true-darkness.1.s2.zone-1.nbl"}]}, + + {[1001210, 0], [{file, "data/missions/true-darkness.2.c.zone-0.nbl"}]}, + {[1001210, 1], [{file, "data/missions/true-darkness.2.c.zone-1.nbl"}]}, + %~ {[1001211, 0], [{file, "data/missions/true-darkness.2.b.zone-0.nbl"}]}, + %~ {[1001211, 1], [{file, "data/missions/true-darkness.2.b.zone-1.nbl"}]}, + {[1001212, 0], [{file, "data/missions/true-darkness.2.a.zone-0.nbl"}]}, + {[1001212, 1], [{file, "data/missions/true-darkness.2.a.zone-1.nbl"}]}, + {[1001213, 0], [{file, "data/missions/true-darkness.2.s.zone-0.nbl"}]}, + {[1001213, 1], [{file, "data/missions/true-darkness.2.s.zone-1.nbl"}]}, + %~ {[1001214, 0], [{file, "data/missions/true-darkness.2.s2.zone-0.nbl"}]}, + %~ {[1001214, 1], [{file, "data/missions/true-darkness.2.s2.zone-1.nbl"}]}, + + {[1001220, 0], [{file, "data/missions/true-darkness.3.c.zone-0.nbl"}]}, + {[1001220, 1], [{file, "data/missions/true-darkness.3.c.zone-1.nbl"}]}, + {[1001221, 0], [{file, "data/missions/true-darkness.3.b.zone-0.nbl"}]}, + {[1001221, 1], [{file, "data/missions/true-darkness.3.b.zone-1.nbl"}]}, + {[1001222, 0], [{file, "data/missions/true-darkness.3.a.zone-0.nbl"}]}, + {[1001222, 1], [{file, "data/missions/true-darkness.3.a.zone-1.nbl"}]}, + %~ {[1001223, 0], [{file, "data/missions/true-darkness.3.s.zone-0.nbl"}]}, + %~ {[1001223, 1], [{file, "data/missions/true-darkness.3.s.zone-1.nbl"}]}, + {[1001224, 0], [{file, "data/missions/true-darkness.3.s2.zone-0.nbl"}]}, + {[1001224, 1], [{file, "data/missions/true-darkness.3.s2.zone-1.nbl"}]}, + % Phantom Ruins (Linear Line counter) %~ {[1060300, 0], [{file, "data/missions/phantom-ruins.c-0.zone.nbl"}]}, @@ -609,16 +664,26 @@ % Dallgun: Phantom Ruins, The Black Nest, True Darkness, (empty name, missing) - { 25, [{quests, "data/counters/colony.dallgun.pack"}, {bg, 255}, {options, << 16#01003c00:32, 3, 3, 3, 0, - 3, 3, 3, 3, 0, % Phantom Ruins C-S + { 25, [{quests, "data/counters/colony.dallgun.pack"}, {bg, 255}, {options, << 16#01003c00:32, 0, 3, 3, 0, + 0, 0, 0, 0, 0, % Phantom Ruins C-S 3, 3, 3, 3, 3, 0, % The Black Nest C-S2 variant 1 3, 3, 3, 3, 3, 0, % The Black Nest C-S2 variant 2 3, 3, 3, 3, 3, 0, % The Black Nest C-S2 variant 3 - 3, 3, 3, 3, 3, % True Darkness C-S2 variant 1 - 3, 3, 3, 3, 3, % True Darkness C-S2 variant 2 - 3, 3, 3, 3, 3, % True Darkness C-S2 variant 3 + 0, 0, 0, 0, 0, % True Darkness C-S2 variant 1 + 3, 0, 3, 3, 0, % True Darkness C-S2 variant 2 + 3, 3, 3, 0, 3, % True Darkness C-S2 variant 3 0:144 >>}]}, + %~ { 25, [{quests, "data/counters/colony.dallgun.pack"}, {bg, 255}, {options, << 16#01003c00:32, 3, 3, 3, 0, + %~ 3, 3, 3, 3, 0, % Phantom Ruins C-S + %~ 3, 3, 3, 3, 3, 0, % The Black Nest C-S2 variant 1 + %~ 3, 3, 3, 3, 3, 0, % The Black Nest C-S2 variant 2 + %~ 3, 3, 3, 3, 3, 0, % The Black Nest C-S2 variant 3 + %~ 3, 3, 3, 3, 3, % True Darkness C-S2 variant 1 + %~ 3, 3, 3, 3, 3, % True Darkness C-S2 variant 2 + %~ 3, 3, 3, 3, 3, % True Darkness C-S2 variant 3 + %~ 0:144 >>}]}, + % Raffon Fieldbase (entry 0) { 30, [{quests, "data/counters/parum.raffon-0.pack"}, {bg, 1}, {options, << 16#01000400:32, 0:32 >>}]}, diff --git a/src/egs_game.erl b/src/egs_game.erl index 7f6b864..73d1806 100644 --- a/src/egs_game.erl +++ b/src/egs_game.erl @@ -851,14 +851,30 @@ handle(16#0f0a, Data) -> send_1211(A, C, B, 0); 3 -> % crystal activation send_1213(ObjectID, 1); + 4 -> % enter boss gate + send_1213(ObjectID, 1); + 5 -> % leave boss gate + % probably 1213, unknown last value + ignore; + 6 -> % activate boss gate + send_1213(ObjectID, 0), + send_1215(2, 16#7008), + %% @todo Sent after warp but not necessarily, also what's 37 (should be a B1 object) and why resend the 1213(id)? + send_1213(37, 0), + send_1213(ObjectID, 0); + 9 -> % healing pad + % 0117, 0111, 0117? + ignore; 12 -> % pick/use key User = egs_db:users_select(get(gid)), [[EventID|_], BlockID] = psu_missions:key_event(User#users.instanceid, ObjectID), send_1205(EventID, BlockID, 0), send_1213(ObjectID, 1); - 13 -> % button on + 13 -> % floor_button on + % 1205 1213 ignore; - 14 -> % button off + 14 -> % floor_button off + % 1205(same, with 1 as last value) 1213(same, with 0 as last value) ignore; %~ 19 -> % @todo (somewhere in phantom ruins block 4) %~ ignore; @@ -883,6 +899,16 @@ handle(16#0f0a, Data) -> log("object event ~b", [Action]) end; +%% @todo Not sure about that one though. Probably related to 1112 still. + +handle(16#1106, Data) -> + send_110e(Data); + +%% @doc Probably asking permission to start the video (used for syncing?). + +handle(16#1112, Data) -> + send_1113(Data); + %% @doc Party information recap request. %% @todo Handle when the party already exists! And stop doing it wrong. @@ -1397,6 +1423,16 @@ send_1022(HP) -> GID = get(gid), send(<< 16#10220300:32, 0:160, 16#00011300:32, GID:32/little-unsigned-integer, 0:64, HP:32/little-unsigned-integer, 0:32 >>). +%% @todo Boss related command. + +send_110e(Data) -> + send(<< (header(16#110e))/binary, Data/binary, 0:32, 5:16/little-unsigned-integer, 12:16/little-unsigned-integer, 0:32, 260:32/little-unsigned-integer >>). + +%% @todo Boss related command. + +send_1113(Data) -> + send(<< (header(16#1113))/binary, Data/binary >>). + %% @todo Figure out what this packet does. Sane values for counter and missions for now. send_1202() -> @@ -1439,6 +1475,11 @@ send_1212() -> send_1213(A, B) -> send(<< (header(16#1213))/binary, A:32/little-unsigned-integer, B:32/little-unsigned-integer >>). +%% @todo Related to boss gates. + +send_1215(A, B) -> + send(<< (header(16#1215))/binary, A:32/little-unsigned-integer, 0:16, B:16/little-unsigned-integer >>). + %% @doc Send the player's partner card. %% @todo Find out the remaining values. diff --git a/src/psu_missions.erl b/src/psu_missions.erl index 29302cb..c811370 100644 --- a/src/psu_missions.erl +++ b/src/psu_missions.erl @@ -50,6 +50,15 @@ object_init(InstanceID, BlockID, [{box, _Model, Breakable, TrigEventID}|Tail], L egs_db:objects_insert(#objects{id=[InstanceID, ObjectID], instanceid=InstanceID, objectid=ObjectID, type=box, targetid=TargetID, blockid=BlockID, triggereventid=TrigEventID}) end, object_init(InstanceID, BlockID, Tail, ListNb, ObjectNb + 1, ObjectID + 1, TargetID + 1); +%% @todo Apparently floor_button has a TargetID. Not sure why yet. Just increment the value. +object_init(InstanceID, BlockID, [floor_button|Tail], ListNb, ObjectNb, ObjectID, TargetID) -> + object_init(InstanceID, BlockID, Tail, ListNb, ObjectNb + 1, ObjectID + 1, TargetID + 1); +%% @todo Apparently shoot_button has a TargetID. I'm sure why though. +object_init(InstanceID, BlockID, [shoot_button|Tail], ListNb, ObjectNb, ObjectID, TargetID) -> + object_init(InstanceID, BlockID, Tail, ListNb, ObjectNb + 1, ObjectID + 1, TargetID + 1); +%% @todo Not sure why but it works that way in True Darkness. +object_init(InstanceID, BlockID, [boss_gate|Tail], ListNb, ObjectNb, ObjectID, TargetID) -> + object_init(InstanceID, BlockID, Tail, ListNb, ObjectNb + 1, ObjectID + 1, TargetID + 1); %% @todo key and key_console event handling will have to be fixed. object_init(InstanceID, BlockID, [{key, _KeySet, TrigEventID, _ReqEventID}|Tail], ListNb, ObjectNb, ObjectID, TargetID) -> egs_db:objects_insert(#objects{id=[InstanceID, {key, ObjectID}], instanceid=InstanceID, objectid=ObjectID, type=key, blockid=BlockID, triggereventid=[TrigEventID]}), @@ -69,11 +78,6 @@ object_init(InstanceID, BlockID, [{warp, DestX, DestY, DestZ, DestDir}|Tail], Li %% @todo Not sure where these 2 come from yet, assuming crystal but might not be that. object_init(InstanceID, BlockID, [crystal|Tail], ListNb, ObjectNb, ObjectID, TargetID) -> object_init(InstanceID, BlockID, Tail, ListNb, ObjectNb + 1, ObjectID + 1, TargetID + 2); -%~ %% @todo Not sure where these 9 come from yet, assuming healing pad + pp cube but might not be that. -%~ object_init(InstanceID, BlockID, [healing_pad|Tail], ObjectID, TargetID) -> - %~ object_init(InstanceID, BlockID, Tail, ObjectID + 1, TargetID + 9); -%~ object_init(InstanceID, BlockID, [pp_cube|Tail], ObjectID, TargetID) -> - %~ object_init(InstanceID, BlockID, Tail, ObjectID + 1, TargetID + 1); %% A few object types don't have an ObjectID nor a TargetID. Disregard them completely. object_init(InstanceID, BlockID, [ObjType|Tail], ListNb, ObjectNb, ObjectID, TargetID) when ObjType =:= static_model; @@ -81,7 +85,10 @@ object_init(InstanceID, BlockID, [ObjType|Tail], ListNb, ObjectNb, ObjectID, Tar ObjType =:= entrance; ObjType =:= 'exit'; ObjType =:= label; - ObjType =:= hidden_minimap_section -> + ObjType =:= hidden_minimap_section; + ObjType =:= fog; + ObjType =:= pp_cube; + ObjType =:= healing_pad -> object_init(InstanceID, BlockID, Tail, ListNb, ObjectNb + 1, ObjectID, TargetID); %% Others are normal objects, we don't handle them but they have an ObjectID. object_init(InstanceID, BlockID, [_|Tail], ListNb, ObjectNb, ObjectID, TargetID) -> diff --git a/src/psu_parser.erl b/src/psu_parser.erl index 40d612f..baef08d 100644 --- a/src/psu_parser.erl +++ b/src/psu_parser.erl @@ -129,6 +129,12 @@ parse_object_args(ObjType, Params, Data, Ptr) -> parse_object_args(4, _Params, _Data) -> static_model; +parse_object_args(5, _Params, _Data) -> + floor_button; + +parse_object_args(6, _Params, _Data) -> + fog; + parse_object_args(10, _Params, _Data) -> invisible_block; @@ -196,7 +202,11 @@ parse_object_args(31, _Params, Data) -> parse_object_args(35, _Params, _Data) -> boss; -%% @todo Find out what this object number is. +parse_object_args(43, _Params, _Data) -> + shoot_button; + +parse_object_args(44, _Params, _Data) -> + trap; parse_object_args(48, _Params, _Data) -> boss_gate;