X-Git-Url: https://harrygodden.com/git/?a=blobdiff_plain;f=entity.h;h=06b2c6e19e8bfd510d18d6cae6dfab7b23eabedf;hb=53597f45307d8a2120e3a0bbe71797b216e8750b;hp=9e0424fc8704684d1abfde4bbc429e70bfca7593;hpb=188685bc8454ff40b733d9e9df8da45e3c2e2c39;p=carveJwlIkooP6JGAAIwe30JlM.git diff --git a/entity.h b/entity.h index 9e0424f..06b2c6e 100644 --- a/entity.h +++ b/entity.h @@ -26,8 +26,8 @@ typedef struct ent_camera ent_camera; typedef struct ent_swspreview ent_swspreview; typedef struct ent_worldinfo ent_worldinfo; typedef struct ent_ccmd ent_ccmd; +typedef struct ent_objective ent_objective; typedef struct ent_challenge ent_challenge; -typedef struct ent_unlock ent_unlock; typedef struct ent_relay ent_relay; typedef struct ent_cubemap ent_cubemap; @@ -50,8 +50,8 @@ enum entity_alias{ k_ent_menuitem = 15, k_ent_worldinfo = 16, k_ent_ccmd = 17, - k_ent_challenge = 18, - k_ent_unlock = 19, + k_ent_objective = 18, + k_ent_challenge = 19, k_ent_relay = 20, k_ent_cubemap = 21 }; @@ -243,7 +243,7 @@ struct ent_marker{ enum skateshop_type{ k_skateshop_type_boardshop, k_skateshop_type_charshop, - k_skateshop_type_worldshop + k_skateshop_type_worldshop, }; struct ent_skateshop{ @@ -298,7 +298,14 @@ enum ent_menuitem_type{ k_ent_menuitem_type_page_button = 2, k_ent_menuitem_type_toggle = 3, k_ent_menuitem_type_slider = 4, - k_ent_menuitem_type_page = 5 + k_ent_menuitem_type_page = 5, + k_ent_menuitem_type_binding = 6, + k_ent_menuitem_type_disabled = 90 +}; + +enum ent_menuitem_stack_behaviour{ + k_ent_menuitem_stack_append = 0, + k_ent_menuitem_stack_replace = 1 }; typedef struct ent_menuitem ent_menuitem; @@ -317,6 +324,11 @@ struct ent_menuitem{ }; union{ + struct{ + u32 pstr_name; + } + visual; + struct{ u32 id_min, /* ent_marker */ id_max, /* . */ @@ -326,7 +338,8 @@ struct ent_menuitem{ slider; struct{ - u32 pstr; + u32 pstr, + stack_behaviour; } button; @@ -343,6 +356,12 @@ struct ent_menuitem{ id_viewpoint; /* ent_camera */ } page; + + struct{ + u32 pstr_bind, + font_variant; + } + binding; }; }; @@ -401,33 +420,35 @@ struct ent_ccmd{ u32 pstr_command; }; -enum ent_challenge_filter{ - k_ent_challenge_filter_none = 0x00000000, - k_ent_challenge_filter_trick_shuvit = 0x00000001, - k_ent_challenge_filter_trick_kickflip = 0x00000002, - k_ent_challenge_filter_trick_treflip = 0x00000004, - k_ent_challenge_filter_trick_any = - k_ent_challenge_filter_trick_shuvit| - k_ent_challenge_filter_trick_treflip| - k_ent_challenge_filter_trick_kickflip, - k_ent_challenge_filter_flip_back = 0x00000008, - k_ent_challenge_filter_flip_front = 0x00000010, - k_ent_challenge_filter_flip_any = - k_ent_challenge_filter_flip_back| - k_ent_challenge_filter_flip_front, - k_ent_challenge_filter_grind_truck_any = 0x00000020, - k_ent_challenge_filter_grind_board_any = 0x00000040, - k_ent_challenge_filter_grind_any = - k_ent_challenge_filter_grind_truck_any| - k_ent_challenge_filter_grind_board_any, - k_ent_challenge_filter_footplant = 0x00000080 -}; - -enum ent_challenge_flag { - k_ent_challenge_hidden = 0x1 -}; - -struct ent_challenge{ +enum ent_objective_filter{ + k_ent_objective_filter_none = 0x00000000, + k_ent_objective_filter_trick_shuvit = 0x00000001, + k_ent_objective_filter_trick_kickflip = 0x00000002, + k_ent_objective_filter_trick_treflip = 0x00000004, + k_ent_objective_filter_trick_any = + k_ent_objective_filter_trick_shuvit| + k_ent_objective_filter_trick_treflip| + k_ent_objective_filter_trick_kickflip, + k_ent_objective_filter_flip_back = 0x00000008, + k_ent_objective_filter_flip_front = 0x00000010, + k_ent_objective_filter_flip_any = + k_ent_objective_filter_flip_back| + k_ent_objective_filter_flip_front, + k_ent_objective_filter_grind_truck_any = 0x00000020, + k_ent_objective_filter_grind_board_any = 0x00000040, + k_ent_objective_filter_grind_any = + k_ent_objective_filter_grind_truck_any| + k_ent_objective_filter_grind_board_any, + k_ent_objective_filter_footplant = 0x00000080, + k_ent_objective_filter_passthrough = 0x00000100 +}; + +enum ent_objective_flag { + k_ent_objective_hidden = 0x1, + k_ent_objective_passed = 0x2 +}; + +struct ent_objective{ mdl_transform transform; u32 submesh_start, submesh_count, @@ -439,10 +460,20 @@ struct ent_challenge{ f32 time_limit; }; -struct ent_unlock{ +enum ent_challenge_flag { + k_ent_challenge_timelimit = 0x1 +}; + +struct ent_challenge{ + mdl_transform transform; u32 pstr_alias, + flags, target, target_event, + reset, + reset_event, + first, + camera, status; };