psu_missions: Add True Darkness. Boss gate handling. Boss partially working.

This commit is contained in:
Loïc Hoguin 2010-07-17 14:50:03 +02:00
parent f46b276047
commit 1f9ac7b1f6
4 changed files with 137 additions and 14 deletions

View File

@ -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 >>}]},

View File

@ -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.

View File

@ -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) ->

View File

@ -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;