File: hudartillery.h

package info (click to toggle)
freespace2 3.7.4%2Brepack-1.1
  • links: PTS, VCS
  • area: non-free
  • in suites: bullseye
  • size: 22,268 kB
  • sloc: cpp: 393,535; ansic: 4,106; makefile: 1,091; xml: 181; sh: 137
file content (90 lines) | stat: -rwxr-xr-x 2,886 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
/*
 * Copyright (C) Volition, Inc. 1999.  All rights reserved.
 *
 * All source code herein is the property of Volition, Inc. You may not sell 
 * or otherwise commercially exploit the source or things you created based on the 
 * source.
 *
*/ 



#ifndef _FS2_HUD_ARTILLERY_HEADER_FILE
#define _FS2_HUD_ARTILLERY_HEADER_FILE

#include "globalincs/globals.h"
#include "globalincs/pstypes.h"

// -----------------------------------------------------------------------------------------------------------------------
// ARTILLERY DEFINES/VARS
//

// SSM shapes
#define SSM_SHAPE_POINT			0
#define SSM_SHAPE_CIRCLE		1
#define SSM_SHAPE_SPHERE		2

// global ssm types
typedef struct ssm_info {
	char		name[NAME_LENGTH];		// strike name
	int			count;					// # of missiles in this type of strike
	int			max_count;				// Maximum # of missiles in this type of strike (-1 for no variance)
	int			weapon_info_index;		// missile type
	float		warp_radius;			// radius of associated warp effect
	float		warp_time;				// how long the warp effect lasts
	float		radius;					// radius around the target ship
	float		max_radius;				// Maximum radius around the target ship (-1.0f for no variance)
	float		offset;					// offset in front of the target ship
	float		max_offset;				// Maximum offset in front of the target ship (-1.0f for no variance)
	char		message[NAME_LENGTH];
	bool		use_custom_message;
	bool		send_message;
	int			sound_index;
	int			shape;
} ssm_info;

// creation info for the strike (useful for multiplayer)
typedef struct ssm_firing_info {
	SCP_vector<int>		delay_stamp;	// timestamps
	SCP_vector<vec3d>	start_pos;		// start positions

	int					count;			// The ssm_info count may be variable; this stores the actual number of projectiles for this strike.
	int					ssm_index;		// index info ssm_info array
	class object*		target;			// target for the strike
	int					ssm_team;		// team that fired the ssm.
	float				duration;		// how far into the warp effect to fire
} ssm_firing_info;

// the strike itself
typedef struct ssm_strike {
	SCP_vector<int>		fireballs;		// warpin effect fireballs
	SCP_vector<bool>	done_flags;		// when we've fired off the individual missiles

	// this is the info that controls how the strike behaves (just like for beam weapons)
	ssm_firing_info		sinfo;
} ssm_strike;


extern SCP_vector<ssm_info> Ssm_info;


// -----------------------------------------------------------------------------------------------------------------------
// ARTILLERY FUNCTIONS
//

// level init
void hud_init_artillery();

// update all hud artillery related stuff
void hud_artillery_update();

// render all hud artillery related stuff
void hud_artillery_render();

// start a subspace missile effect
void ssm_create(object *target, vec3d *start, size_t ssm_index, ssm_firing_info *override, int team);

// Goober5000
extern int ssm_info_lookup(const char *name);

#endif