X-Git-Url: https://harrygodden.com/git/?a=blobdiff_plain;f=entity.h;h=6e30ef219ec96a5b0080eec52fe2e9d7f18dec9f;hb=9d0ff08fef8507613586856de7ce25d43704db92;hp=d56d70271d043a7b239b64df174f2fc6b29a33b3;hpb=5f34184cad016aa2f8ea530b3be009703459e981;p=carveJwlIkooP6JGAAIwe30JlM.git diff --git a/entity.h b/entity.h index d56d702..6e30ef2 100644 --- a/entity.h +++ b/entity.h @@ -23,6 +23,7 @@ typedef struct ent_font_variant ent_font_variant; typedef struct ent_glyph ent_glyph; typedef struct ent_skateshop ent_skateshop; typedef struct ent_camera ent_camera; +typedef struct ent_swspreview ent_swspreview; enum entity_alias{ k_ent_none = 0, @@ -38,7 +39,9 @@ enum entity_alias{ k_ent_font_variant= 10, k_ent_traffic = 11, k_ent_skateshop = 12, - k_ent_camera = 13 + k_ent_camera = 13, + k_ent_swspreview = 14, + k_ent_menuitem = 15 }; static u32 mdl_entity_id_type( u32 entity_id ) @@ -220,6 +223,10 @@ struct ent_skateshop{ id_camera; }; +struct ent_swspreview{ + u32 id_camera, id_display, id_display1; +}; + struct ent_traffic{ mdl_transform transform; u32 submesh_start, @@ -236,6 +243,52 @@ struct ent_camera{ float fov; }; +enum ent_menuitem_type{ + k_ent_menuitem_type_visual = 0, + k_ent_menuitem_type_event_button = 1, + 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 +}; + +typedef struct ent_menuitem ent_menuitem; +struct ent_menuitem{ + u32 type, groups, + id_links[4]; /* ent_menuitem */ + + mdl_transform transform; + u32 submesh_start, submesh_count; + + union{ + struct{ + u32 id_min, /* ent_marker */ + id_max, /* . */ + id_handle, /* ent_menuitem */ + pstr_data; + } + slider; + + struct{ + u32 pstr; + } + button; + + struct{ + u32 id_check, /* ent_menuitem */ + pstr_data; + } + checkmark; + + struct{ + u32 pstr_name, + id_entrypoint, /* ent_menuitem */ + id_viewpoint; /* ent_camera */ + } + page; + }; +}; + VG_STATIC ent_marker *ent_find_marker( mdl_context *mdl, mdl_array_ptr *arr, const char *alias ) { @@ -291,6 +344,4 @@ struct ent_call{ #include "world.h" -VG_STATIC void entity_call( world_instance *world, ent_call *call ); - #endif /* ENTITY_H */