]> git.rm.cloudns.org Git - xonotic/xonotic-data.pk3dir.git/commitdiff
Make things somewhat usable before venturing into ODE land
authorJakob MG <jakob_mg@hotmail.com>
Tue, 29 Mar 2011 20:18:53 +0000 (22:18 +0200)
committerJakob MG <jakob_mg@hotmail.com>
Tue, 29 Mar 2011 20:18:53 +0000 (22:18 +0200)
qcsrc/server/vehicles/collision.qc [new file with mode: 0644]
qcsrc/server/vehicles/racer.qc
qcsrc/server/vehicles/raptor.qc
qcsrc/server/vehicles/vehicles.qc
qcsrc/server/vehicles/vehicles.qh

diff --git a/qcsrc/server/vehicles/collision.qc b/qcsrc/server/vehicles/collision.qc
new file mode 100644 (file)
index 0000000..60597c0
--- /dev/null
@@ -0,0 +1,80 @@
+vector collision_force;
+vector collision_angle;
+
+vector bb1[9];
+vector bb2[9];
+
+float collision_run()
+{
+    vector vtmp, vmin, vmax, vrot, vforce;
+    float i, fvel, bcol;
+
+
+    // Extract the 8 bbox corners from mins/maxs for self
+    vmax = self.maxs;
+    vmin = self.mins;
+    bb1[0] = vmax;
+    vtmp   = vmax; vtmp_x = vmin_x; bb1[1] = vtmp;
+    vtmp   = vmax; vtmp_y = vmin_y; bb1[2] = vtmp;
+    vtmp   = vmin; vtmp_z = vmax_z; bb1[3] = vtmp;
+    bb1[4] = vmin;
+    vtmp   = vmin; vtmp_x = vmax_x; bb1[5] = vtmp;
+    vtmp   = vmin; vtmp_y = vmax_y; bb1[6] = vtmp;
+    vtmp   = vmax; vtmp_z = vmin_z; bb1[7] = vtmp;
+
+    makevectors(self.angles + '-2 0 0' * self.angles_x);
+    bcol = FALSE;
+    // Pass1: Transform by rotation, ajust points by impact/s
+    for(i = 8; i >= 0; --i)
+    {
+        vtmp = bb1[i];
+        vtmp = self.origin + vtmp_x * v_forward - vtmp_y * v_right + vtmp_z * v_up;
+        traceline(self.origin, vtmp, MOVE_WORLDONLY, self);
+        te_lightning1(world,self.origin,vtmp);
+        if(trace_fraction != 1.0)
+        {
+            //bb2[i] = trace_endpos;
+            vforce += (trace_endpos - vtmp);
+            bcol = TRUE;
+        }
+        else
+            bb2[i] = bb1[i];
+    }
+
+    if(bcol)
+    {
+        //self.angles   += vectoangles(vrot) * frametime;
+        //self.angles   -= (self.velocity - vectoangles(normalize(vforce))) * frametime;
+
+        vtmp = self.origin + self.velocity * frametime;
+        vrot = self.origin + vforce * frametime;
+        //self.angles += vectoangles(normalize(vtmp - vrot)) * frametime;
+        self.velocity += vforce * frametime;
+
+    }
+
+
+// Extract the 8 bbox corners from mins/maxs for self
+/*
+    bb1[0] = self.absmax;
+    vtmp   = self.absmax; vtmp_x = self.absmin_x; bb1[1] = vtmp;
+    vtmp   = self.absmax; vtmp_y = self.absmin_y; bb1[2] = vtmp;
+    vtmp   = self.absmin; vtmp_z = self.absmax_z; bb1[3] = vtmp;
+    bb1[4] = self.absmin;
+    vtmp   = self.absmin; vtmp_x = self.absmax_x; bb1[5] = vtmp;
+    vtmp   = self.absmin; vtmp_y = self.absmax_y; bb1[6] = vtmp;
+    vtmp   = self.absmax; vtmp_z = self.absmin_z; bb1[7] = vtmp;
+
+
+// Extract the 8 bbox corners from mins/maxs for other
+    bb1[0] = other.absmax;
+    vtmp   = other.absmax; vtmp_x = other.absmin_x; bb2[1] = vtmp;
+    vtmp   = other.absmax; vtmp_y = other.absmin_y; bb2[2] = vtmp;
+    vtmp   = other.absmin; vtmp_z = other.absmax_z; bb2[3] = vtmp;
+    bb2[4] = other.absmin;
+    vtmp   = other.absmin; vtmp_x = other.absmax_x; bb2[5] = vtmp;
+    vtmp   = other.absmin; vtmp_y = other.absmax_y; bb2[6] = vtmp;
+    vtmp   = other.absmax; vtmp_z = other.absmin_z; bb2[7] = vtmp;
+*/
+}
+
index 82748546891225ba2f5e2d4a6cf43be33e502c86..410490c0987d56150d7480b0ced3427f2de9723f 100644 (file)
@@ -561,8 +561,6 @@ void racer_touch()
     vehicles_touch();
     if(self.owner)
     {
-        //self.velocity = 0.999 * self.velocity;
-        // TO-DO Impact reaction (crush players, damage self on high speed impact etc)
         return;
     }
 
index 2a07c550575aa916a2ff9a4fdbc402b14ee6e8d4..9ea9bcf0486e0a30a410c4c173da5d8470d4bf22 100644 (file)
@@ -313,6 +313,9 @@ float raptor_frame()
         self = player;
         return 1;
     }
+
+    //collision_run();
+
     crosshair_trace(player);
 
 #if VEHICLES_VIEWROTATE_CROSSHAIR
@@ -633,7 +636,7 @@ void raptor_spawn()
     self.touch          = raptor_touch;
     self.iscreature     = TRUE;
     self.movetype       = MOVETYPE_FLY;
-    self.solid          = SOLID_SLIDEBOX;
+    self.solid          = SOLID_BBOX;
     self.takedamage     = DAMAGE_AIM;
        self.deadflag       = DEAD_NO;
     self.bot_attack     = TRUE;
index 6caf7462eedaf19be6bf1958e65f37c857ba3bfc..1cd45691c8b47e470cc3fd11f4956b1556199cb5 100644 (file)
@@ -82,13 +82,28 @@ void CSQCVehicleSetup(entity own, float vehicle_id)
 .float  lock_time;
 void vehicles_locktarget2(float incr, float decr, float _lock_time)
 {
+    if(self.lock_target && self.lock_target.deadflag != DEAD_NO)
+        self.lock_target = world;
+
+    if(trace_ent != world)
+    {
+        if(teams_matter && trace_ent.team == self.team)
+            trace_ent = world;
+
+        if(trace_ent.deadflag != DEAD_NO)
+            trace_ent = world;
+
+        if not (trace_ent.vehicle_flags & VHF_ISVEHICLE || trace_ent.turrcaps_flags & TFL_TURRCAPS_ISTURRET)
+            trace_ent = world;
+    }
+
     if(self.lock_time > time)
         return;
 
-    if not (trace_ent.vehicle_flags & VHF_ISVEHICLE || trace_ent.turrcaps_flags & TFL_TURRCAPS_ISTURRET)
+    /*if not (trace_ent.vehicle_flags & VHF_ISVEHICLE || trace_ent.turrcaps_flags & TFL_TURRCAPS_ISTURRET)
         self.lock_strength = min(self.lock_strength - decr, 1);
     else if(trace_ent.deadflag != DEAD_NO)
-        self.lock_strength = min(self.lock_strength - decr, 1);
+        self.lock_strength = min(self.lock_strength - decr, 1);*/
 
     if(self.lock_target == world && trace_ent != world)
         self.lock_target = trace_ent;
@@ -153,7 +168,7 @@ vector vehicles_force_fromtag_maglev(string tag_name, float spring_length, float
     return v_forward  * force_fromtag_power;
 }
 
-
+void vehicles_enter();
 void vehicles_touch()
 {
     // Vehicle currently
@@ -168,7 +183,7 @@ void vehicles_touch()
         {
             if(other.vehicle_flags & VHF_ISVEHICLE)
             {
-                other.velocity += self.velocity * (self.mass / other.mass);
+                //other.velocity += self.velocity * (self.mass / other.mass);
             }
         }
     }
@@ -186,7 +201,7 @@ void vehicles_touch()
     if (clienttype(other) != CLIENTTYPE_REAL)
         return;
 
-    self.vehicle_enter();
+    vehicles_enter();
 }
 
 void vehicles_enter()
@@ -426,7 +441,10 @@ void vehicles_setreturn(float retime, void() respawn_proc)
 
 float vehicles_customizeentityforclient()
 {
-    return self.deadflag == DEAD_DEAD ? FALSE : TRUE;
+    if(self.deadflag  == DEAD_DEAD)
+        return FALSE;
+    else
+        return TRUE;
 }
 
 void vehicles_configcheck(string  configname, float check_cvar)
index a932f48e1e9e12eef08d8670071e5346b84553d9..6d64a3d29e37a50f14b7fadfbf5a3ee452cfe594 100644 (file)
@@ -1,4 +1,5 @@
 #ifdef VEHICLES_ENABLED
+//#include "collision.qc"
 #include "vehicles.qc"
 #include "racer.qc"
 #include "spiderbot.qc"