]> git.rm.cloudns.org Git - xonotic/darkplaces.git/commitdiff
transform surface vertices to worldspace before calculating waterplane
authorhavoc <havoc@d7cf8633-e32d-0410-b094-e92efae38249>
Fri, 16 Sep 2011 11:09:13 +0000 (11:09 +0000)
committerRudolf Polzer <divverent@xonotic.org>
Mon, 26 Sep 2011 04:48:56 +0000 (06:48 +0200)
git-svn-id: svn://svn.icculus.org/twilight/trunk/darkplaces@11358 d7cf8633-e32d-0410-b094-e92efae38249
::stable-branch::merge=e30cc3765421b9eb971085dc809150ead69490c0

gl_rmain.c

index 5688709d4171c99bbe375f487bb29959d0e3f43c..9feccb85088a84cb0c4d2c5c8fada5cf5f843fdc 100644 (file)
@@ -5627,7 +5627,7 @@ static void R_Water_StartFrame(void)
 void R_Water_AddWaterPlane(msurface_t *surface, int entno)
 {
        int planeindex, bestplaneindex, vertexindex;
-       vec3_t mins, maxs, normal, center;
+       vec3_t mins, maxs, normal, center, v, n;
        vec_t planescore, bestplanescore;
        mplane_t plane;
        r_waterstate_waterplane_t *p;
@@ -5640,13 +5640,15 @@ void R_Water_AddWaterPlane(msurface_t *surface, int entno)
        VectorCopy(rsurface.batchvertex3f, maxs);
        for (vertexindex = 0;vertexindex < rsurface.batchnumvertices;vertexindex++)
        {
-               VectorAdd(normal, rsurface.batchnormal3f + vertexindex*3, normal);
-               mins[0] = min(mins[0], rsurface.batchvertex3f[vertexindex*3+0]);
-               mins[1] = min(mins[1], rsurface.batchvertex3f[vertexindex*3+1]);
-               mins[2] = min(mins[2], rsurface.batchvertex3f[vertexindex*3+2]);
-               maxs[0] = max(maxs[0], rsurface.batchvertex3f[vertexindex*3+0]);
-               maxs[1] = max(maxs[1], rsurface.batchvertex3f[vertexindex*3+1]);
-               maxs[2] = max(maxs[2], rsurface.batchvertex3f[vertexindex*3+2]);
+               Matrix4x4_Transform(&rsurface.matrix, rsurface.batchvertex3f + vertexindex*3, v);
+               Matrix4x4_Transform3x3(&rsurface.matrix, rsurface.batchnormal3f + vertexindex*3, n);
+               VectorAdd(normal, n, normal);
+               mins[0] = min(mins[0], v[0]);
+               mins[1] = min(mins[1], v[1]);
+               mins[2] = min(mins[2], v[2]);
+               maxs[0] = max(maxs[0], v[0]);
+               maxs[1] = max(maxs[1], v[1]);
+               maxs[2] = max(maxs[2], v[2]);
        }
        VectorNormalize(normal);
        VectorMAM(0.5f, mins, 0.5f, maxs, center);