]> git.rm.cloudns.org Git - xonotic/darkplaces.git/commitdiff
disable broken Mod_CollisionBIH_TracePoint_Mesh and
authorhavoc <havoc@d7cf8633-e32d-0410-b094-e92efae38249>
Thu, 18 Feb 2010 00:25:56 +0000 (00:25 +0000)
committerRudolf Polzer <rpolzer@grawp.div0.qc.to>
Mon, 22 Feb 2010 17:28:01 +0000 (18:28 +0100)
Mod_CollisionBIH_PointSuperContents_Mesh, they need more advanced
triangle checks to function properly

git-svn-id: svn://svn.icculus.org/twilight/trunk/darkplaces@9974 d7cf8633-e32d-0410-b094-e92efae38249
::stable-branch::merge=e1c223ca762105be0da1da573e00510759beb5e3

model_brush.c

index e9e807f1c03c2f29f37d4140dfd977d98d9dbe29..52d9fcf7748687bb9c51242a8ab336a890bc4d92 100644 (file)
@@ -6142,13 +6142,17 @@ int Mod_CollisionBIH_PointSuperContents(struct model_s *model, int frame, const
 
 void Mod_CollisionBIH_TracePoint_Mesh(dp_model_t *model, const frameblend_t *frameblend, const skeleton_t *skeleton, trace_t *trace, const vec3_t start, int hitsupercontentsmask)
 {
+#if 0
+       // broken - needs to be modified to count front faces and backfaces to figure out if it is in solid
        vec3_t end;
        int hitsupercontents;
        VectorSet(end, start[0], start[1], model->normalmins[2]);
+#endif
        memset(trace, 0, sizeof(*trace));
        trace->fraction = 1;
        trace->realfraction = 1;
        trace->hitsupercontentsmask = hitsupercontentsmask;
+#if 0
        Mod_CollisionBIH_TraceLine_RecursiveBIHNode(trace, model, model->collision_bih.rootnode, start, end, start, end);
        hitsupercontents = trace->hitsupercontents;
        memset(trace, 0, sizeof(*trace));
@@ -6156,10 +6160,13 @@ void Mod_CollisionBIH_TracePoint_Mesh(dp_model_t *model, const frameblend_t *fra
        trace->realfraction = 1;
        trace->hitsupercontentsmask = hitsupercontentsmask;
        trace->startsupercontents = hitsupercontents;
+#endif
 }
 
 int Mod_CollisionBIH_PointSuperContents_Mesh(struct model_s *model, int frame, const vec3_t start)
 {
+#if 0
+       // broken - needs to be modified to count front faces and backfaces to figure out if it is in solid
        trace_t trace;
        vec3_t end;
        VectorSet(end, start[0], start[1], model->normalmins[2]);
@@ -6169,6 +6176,9 @@ int Mod_CollisionBIH_PointSuperContents_Mesh(struct model_s *model, int frame, c
        trace.hitsupercontentsmask = 0;
        Mod_CollisionBIH_TraceLine_RecursiveBIHNode(&trace, model, model->collision_bih.rootnode, start, end, start, end);
        return trace.hitsupercontents;
+#else
+       return 0;
+#endif
 }
 
 static void Mod_Q3BSP_TracePoint_RecursiveBSPNode(trace_t *trace, dp_model_t *model, mnode_t *node, const vec3_t point, int markframe)