diff Engine/Graphics/LightmapBuilder.cpp @ 2559:6ab1273bc507

.
author Ritor1
date Thu, 14 May 2015 19:16:08 +0600
parents b6140dfeac27
children 98057834c9a0
line wrap: on
line diff
--- a/Engine/Graphics/LightmapBuilder.cpp	Wed May 13 20:09:12 2015 +0600
+++ b/Engine/Graphics/LightmapBuilder.cpp	Thu May 14 19:16:08 2015 +0600
@@ -79,7 +79,7 @@
 }
 
 //----- (0045D0D5) --------------------------------------------------------
-bool LightmapBuilder::StackLight_TerrainFace(StationaryLight *pLight, Vec3_float_ *pNormal, float *a3, RenderVertexSoft *a1, unsigned int uStripType, int X, unsigned int *pSlot)
+bool LightmapBuilder::StackLight_TerrainFace(StationaryLight *pLight, Vec3_float_ *pNormal, float *a3, RenderVertexSoft *TerrainVertices, unsigned int uStripType, int X, unsigned int *pSlot)
 {
   //For outdoor terrain light (II)
   bool result; // eax@1
@@ -95,37 +95,49 @@
   float tY_0;
   float tY_1; // [sp+1Ch] [bp-4h]@5
 
+  //  x0,y0		  x1,y1
+  //  .____________.
+  //  |            |
+  //  |            |
+  //  |            |
+  //  .____________.
+  // x3,y3        x2,y2
+
+
   if ( pLight->uRadius <= 0 )
-    return 0;
+    return false;
   if ( uStripType == 4 )
   {
-    tX_0 = a1->vWorldPosition.x;
-    tX_1 = a1[3].vWorldPosition.x;
-    tY_0 = a1[1].vWorldPosition.y;
-    tY_1 = a1->vWorldPosition.y;
+    tX_0 = TerrainVertices[0].vWorldPosition.x;
+    tX_1 = TerrainVertices[3].vWorldPosition.x;
+
+    tY_0 = TerrainVertices[1].vWorldPosition.y;
+    tY_1 = TerrainVertices[0].vWorldPosition.y;
   }
-  else // uStripType == 3
+  else if(uStripType == 3)
   {
-    if ( uStripType != 3 )
-      MessageBoxW(nullptr, L"Uknown strip type detected!", L"E:\\WORK\\MSDEV\\MM7\\MM7\\Code\\Light.cpp:981", 0);
-    else if ((unsigned char)X)
+    if ((unsigned char)X)
     {
-      tX_0 = a1->vWorldPosition.x;
-      tX_1 = a1[2].vWorldPosition.x;
-      tY_0 = a1[1].vWorldPosition.y;
-      tY_1 = a1[2].vWorldPosition.y;
+      tX_0 = TerrainVertices[0].vWorldPosition.x;
+      tX_1 = TerrainVertices[2].vWorldPosition.x;
+
+      tY_0 = TerrainVertices[1].vWorldPosition.y;
+      tY_1 = TerrainVertices[2].vWorldPosition.y;
     }
     else
     {
-      tX_0 = a1[1].vWorldPosition.x;
-      tX_1 = a1[2].vWorldPosition.x;
-      tY_0 = a1[1].vWorldPosition.y;
-      tY_1 = a1->vWorldPosition.y;
+      tX_0 = TerrainVertices[1].vWorldPosition.x;
+      tX_1 = TerrainVertices[2].vWorldPosition.x;
+
+      tY_0 = TerrainVertices[1].vWorldPosition.y;
+      tY_1 = TerrainVertices[0].vWorldPosition.y;
     }
   }
+  else
+	MessageBoxW(nullptr, L"Uknown strip type detected!", L"E:\\WORK\\MSDEV\\MM7\\MM7\\Code\\Light.cpp:981", 0);
 
-  minz = pIndoorCameraD3D->GetPolygonMinZ(a1, uStripType);
-  maxz = pIndoorCameraD3D->GetPolygonMaxZ(a1, uStripType);
+  minz = pIndoorCameraD3D->GetPolygonMinZ(TerrainVertices, uStripType);
+  maxz = pIndoorCameraD3D->GetPolygonMaxZ(TerrainVertices, uStripType);
 
   float bounding_x1 = tX_0 - (float)pLight->uRadius; //13 976 - 128 = 13848.0
   float bounding_y1 = tY_0 - (float)pLight->uRadius; // 3 800 - 128 = 3672.0
@@ -135,16 +147,17 @@
   float bounding_y2 = (float)pLight->uRadius + tY_1; //3 792 + 128 =  3920.0
   float bounding_z2 = (float)pLight->uRadius + maxz;// 260.0
 
+  //проверяем вершины 
   if ( (float)pLight->vPosition.x <= bounding_x1 || (float)pLight->vPosition.x >= bounding_x2
     || (float)pLight->vPosition.y <= bounding_y1 || (float)pLight->vPosition.y >= bounding_y2 
     || (float)pLight->vPosition.z <= bounding_z1 || (float)pLight->vPosition.z >= bounding_z2 )
-    return 0;
+    return false;
 
-    Vec3_float_::NegDot(&a1->vWorldPosition, pNormal, a3);
-    float p_dot = (float)pLight->vPosition.x * pNormal->x 
-                + (float)pLight->vPosition.y * pNormal->y 
-                + (float)pLight->vPosition.z * pNormal->z + *a3;
-    p_dot = p_dot + 0.5f;
+  Vec3_float_::NegDot(&TerrainVertices->vWorldPosition, pNormal, a3);
+  float p_dot = (float)pLight->vPosition.x * pNormal->x 
+              + (float)pLight->vPosition.y * pNormal->y 
+              + (float)pLight->vPosition.z * pNormal->z + *a3;
+  p_dot = p_dot + 0.5f;
   if  ( (//v49 = pNormal,
         //Vec3_float_::NegDot(&a1->vWorldPosition, pNormal, a3),
         //X = v8->vPosition.y,
@@ -160,7 +173,7 @@
         //X = LODWORD(v61),
         //v52 = v63,
         p_dot > pLight->uRadius) )
-    return 0;
+    return false;
 /*
         v49 = pNormal;
         Vec3_float_::NegDot(&v11->vWorldPosition, pNormal, a3);
@@ -192,18 +205,18 @@
     v57 = _4E94D2_light_type;
   stru_F8AD28._blv_lights_types[*pSlot] = v57;
 
-  result = 4 * *pSlot;
+  int id = 4 * *pSlot;
   if ( /*pRenderer->pRenderD3D &&*/ pRenderer->bUsingSpecular )
   {
     if ( stru_F8AD28._blv_lights_types[*pSlot] & 4 )
     {
-      stru_F8AD28._blv_lights_rs[result] = stru_F8AD28._blv_lights_rs[result] * 0.3300000131130219;
-      stru_F8AD28._blv_lights_gs[result] = stru_F8AD28._blv_lights_gs[result] * 0.3300000131130219;
-      stru_F8AD28._blv_lights_bs[result] = stru_F8AD28._blv_lights_bs[result] * 0.3300000131130219;
+      stru_F8AD28._blv_lights_rs[id] = stru_F8AD28._blv_lights_rs[id] * 0.3300000131130219;
+      stru_F8AD28._blv_lights_gs[id] = stru_F8AD28._blv_lights_gs[id] * 0.3300000131130219;
+      stru_F8AD28._blv_lights_bs[id] = stru_F8AD28._blv_lights_bs[id] * 0.3300000131130219;
     }
   }
   ++*pSlot;
-  return 1;
+  return true;
 }
 
 //----- (0045CE50) --------------------------------------------------------
@@ -869,7 +882,7 @@
     }
   }
   else
-    if (for_refactoring)
+    //if (for_refactoring)
     {
     for (unsigned int i = 0; i < std__vector_000004_size; ++i)
       if ( !pRenderer->DrawLightmap(std__vector_000004 + i, &arg4, 0.0) )