-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgrenade_fix.qc
81 lines (64 loc) · 1.86 KB
/
grenade_fix.qc
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
void(vector normal) GrenadeForceBounce;
vector(vector incident, vector normal, float dampening) reflect;
// From engine
float GRENADE_BACKOFF = 1.5;
void() GrenadeHandlePhysics = {
float dot;
vector horiz_vel, horiz_normal;
// if same frame that think was called
if (self.count == framecount) {
// end our shenanigans
self.velocity = '0 0 0';
return;
}
if (self.velocity_z > 0) {
return;
}
if (self.velocity == '0 0 0') {
return;
}
traceline(
self.origin,
self.origin + self.velocity,
1,
self);
if (trace_ent != other || trace_plane_normal_z <= 0) {
return;
}
horiz_vel = self.velocity;
horiz_vel_z = 0;
horiz_normal = trace_plane_normal;
horiz_normal_z = 0;
dot = horiz_vel * horiz_normal;
// if moving down-slope, bounce
if (dot > 0) {
GrenadeForceBounce(trace_plane_normal);
// if surface slope is > 1/2
} else if (trace_plane_normal_z < 2*vlen(horiz_normal)) {
GrenadeForceBounce(trace_plane_normal);
}
};
void() GrenadeForceBounceThink = {
if (time >= self.pausetime) {
self.think1();
} else {
self.think = self.think1;
self.nextthink = self.pausetime;
self.velocity = self.pos1;
self.avelocity = '300 300 300';
self.flags = self.flags & (-1 - FL_ONGROUND);
self.count = framecount;
}
};
void(vector normal) GrenadeForceBounce = {
// bounce grenade off surface
self.velocity = reflect(-self.velocity, normal, 2-GRENADE_BACKOFF);
// cache velocity
self.pos1 = self.velocity;
// cache existing think
self.think1 = self.think;
self.pausetime = self.nextthink;
// FL_ONGROUND will get set, so clear it next frame
self.think = GrenadeForceBounceThink;
self.nextthink = time;
};