psu_missions: Add True Darkness. Boss gate handling. Boss partially working.
This commit is contained in:
parent
f46b276047
commit
1f9ac7b1f6
@ -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 >>}]},
|
||||
|
@ -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.
|
||||
|
||||
|
@ -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) ->
|
||||
|
@ -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;
|
||||
|
Loading…
Reference in New Issue
Block a user