diff --git a/code/nel/samples/3d/cluster_viewer/main.cpp b/code/nel/samples/3d/cluster_viewer/main.cpp
index 7ca5b07a1..bc314e43a 100644
--- a/code/nel/samples/3d/cluster_viewer/main.cpp
+++ b/code/nel/samples/3d/cluster_viewer/main.cpp
@@ -15,19 +15,12 @@
// along with this program. If not, see .
-//
+// ---------------------------------------------------------------------------
// Includes
-//
-
-#include "nel/misc/types_nl.h"
+// ---------------------------------------------------------------------------
-#include
-#ifdef NL_OS_WINDOWS
-# include
-# undef min
-# undef max
-#endif
+#include "nel/misc/types_nl.h"
#include "nel/misc/file.h"
#include "nel/misc/path.h"
@@ -44,6 +37,11 @@
#include "nel/3d/transform_shape.h"
#include "nel/3d/event_mouse_listener.h"
+#ifdef NL_OS_WINDOWS
+# define NOMINMAX
+# include
+#endif // NL_OS_WINDOWS
+
#ifndef CV_DIR
# define CV_DIR "."
#endif
@@ -117,15 +115,17 @@ void LoadSceneScript (const char *ScriptName, CScene* pScene, vector &D
FILE *f = fopen (CPath::lookup(ScriptName).c_str(),"rb");
fseek (f, 0, SEEK_END);
- int file_size = ftell (f);
+ uint file_size = ftell (f);
fseek (f, 0, SEEK_SET);
char *file_buf = (char*)malloc(file_size+1);
- fread (file_buf, 1, file_size, f);
+ if (fread (file_buf, 1, file_size, f) != file_size)
+ nlwarning("Can't read %d elements", file_size);
+
file_buf[file_size] = 0;
++file_size;
fclose (f);
char *buf_ptr = file_buf;
- int nLastNbPlus = 0;
+ sint nLastNbPlus = 0;
vector pile;
pile.clear ();
pile.push_back (pScene->getGlobalInstanceGroup());
@@ -134,7 +134,7 @@ void LoadSceneScript (const char *ScriptName, CScene* pScene, vector &D
do
{
char Line[256], *line_ptr;
- int nNbPlus = 0;
+ sint nNbPlus = 0;
line_ptr = &Line[0];
buf_ptr = readLine (line_ptr, buf_ptr);
@@ -384,7 +384,6 @@ int main()
CNELU::Driver->swapBuffers ();
-
// Keys management
// ---------------
diff --git a/code/nel/src/3d/lighting_manager.cpp b/code/nel/src/3d/lighting_manager.cpp
index 95e769ee1..ecbf51dcd 100644
--- a/code/nel/src/3d/lighting_manager.cpp
+++ b/code/nel/src/3d/lighting_manager.cpp
@@ -486,7 +486,7 @@ void CLightingManager::computeModelLightContributions(NLMISC::CRGBA sunAmbient,
v= NLMISC::OptFastFloor(mergedAmbient.R); fastClamp8(v); amb.R= v;
v= NLMISC::OptFastFloor(mergedAmbient.G); fastClamp8(v); amb.G= v;
v= NLMISC::OptFastFloor(mergedAmbient.B); fastClamp8(v); amb.B= v;
- amb.R = 255;
+ amb.A = 255;
lightContrib.MergedPointLight= amb;
// Indicate we use the merged pointLight => the model must recompute lighting each frame
diff --git a/code/nel/tools/3d/cluster_viewer/view_cs.cpp b/code/nel/tools/3d/cluster_viewer/view_cs.cpp
index 15b5ebc7d..8db2208fb 100644
--- a/code/nel/tools/3d/cluster_viewer/view_cs.cpp
+++ b/code/nel/tools/3d/cluster_viewer/view_cs.cpp
@@ -21,26 +21,31 @@
#include "nel/misc/types_nl.h"
+
#include "nel/misc/file.h"
+#include "nel/misc/path.h"
#include "nel/misc/bitmap.h"
-
-#include "nel/misc/event_server.h"
-#include "nel/misc/event_listener.h"
#include "nel/misc/events.h"
-#include "nel/misc/path.h"
#include "nel/misc/time_nl.h"
-#include "nel/3d/driver.h"
+#include "nel/misc/event_server.h"
+#include "nel/misc/event_listener.h"
+
#include "nel/3d/nelu.h"
+#include "nel/3d/driver.h"
#include "nel/3d/scene_group.h"
+#include "nel/3d/text_context.h"
#include "nel/3d/transform_shape.h"
#include "nel/3d/event_mouse_listener.h"
-#include "nel/3d/text_context.h"
#ifdef NL_OS_WINDOWS
# define NOMINMAX
# include
#endif // NL_OS_WINDOWS
+#ifndef CV_DIR
+# define CV_DIR "."
+#endif
+
using namespace std;
using namespace NL3D;
using namespace NLMISC;
@@ -109,7 +114,7 @@ void LoadSceneScript (const char *ScriptName, CScene* pScene, vector &D
FILE *f = fopen (ScriptName,"rb");
fseek (f, 0, SEEK_END);
- sint file_size = ftell (f);
+ uint file_size = ftell (f);
fseek (f, 0, SEEK_SET);
char *file_buf = (char*)malloc(file_size+1);
if (fread (file_buf, 1, file_size, f) != file_size)
@@ -152,7 +157,7 @@ void LoadSceneScript (const char *ScriptName, CScene* pScene, vector &D
}
else
{
- if (nLastNbPlus >= nNbPlus)
+ if (nLastNbPlus >= nNbPlus)
for (int i = 0; i < ((nLastNbPlus-nNbPlus)+1); ++i)
if (pile.size() > 0)
pile.pop_back();
@@ -194,7 +199,6 @@ void LoadSceneScript (const char *ScriptName, CScene* pScene, vector &D
// ---------------------------------------------------------------------------
// Main
// ---------------------------------------------------------------------------
-
#ifdef NL_OS_WINDOWS
int CALLBACK WinMain (HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nShowCmd)
#else // NL_OS_WINDOWS
@@ -204,7 +208,6 @@ int main(int argc, char **argv)
double rGlobalTime = 0;
double rOldGlobalTime = 0;
double rDeltaTime = 0;
- double rMoveTime = 0;
vector DispCS;
@@ -217,18 +220,19 @@ int main(int argc, char **argv)
CNELU::init (800, 600, CViewport(), 32, true);
- CPath::addSearchPath("shapes/");
- CPath::addSearchPath("groups/");
- CPath::addSearchPath("maps/");
- CPath::addSearchPath("lightmaps/");
- CPath::addSearchPath("anims/");
- ///// CPath::addSearchPath("fonts/");
+ CNELU::Scene->enableLightingSystem(true);
+ CNELU::Scene->setAmbientGlobal(CRGBA(128,128,128));
+
+ CPath::addSearchPath(CV_DIR);
+ CPath::addSearchPath(CV_DIR"/shapes");
+ CPath::addSearchPath(CV_DIR"/groups");
+ CPath::addSearchPath(CV_DIR"/fonts");
CFontManager FontManager;
CTextContext TextContext;
TextContext.init (CNELU::Driver, &FontManager);
- TextContext.setFontGenerator ("fonts/n019003l.pfb");
+ TextContext.setFontGenerator (NLMISC::CPath::lookup("n019003l.pfb"));
TextContext.setHotSpot (CComputedString::TopLeft);
TextContext.setColor (CRGBA(255,255,255));
TextContext.setFontSize (20);
@@ -242,21 +246,18 @@ int main(int argc, char **argv)
// Force to automatically find the cluster system
CNELU::Camera->setClusterSystem ((CInstanceGroup*)-1);
-
CClipTrav *pClipTrav = &CNELU::Scene->getClipTrav();
dcsTemp.Name = "Root";
dcsTemp.pIG = NULL;
DispCS.push_back (dcsTemp);
-
// Add all instance that create the scene
// --------------------------------------
- // Begining of script reading
+ // Beginning of script reading
CVector CameraStart;
LoadSceneScript ("view_cs.txt", CNELU::Scene, DispCS, CameraStart);
- CNELU::Scene->enableLightingSystem(true);
CMatrix m = MouseListener.getViewMatrix();
m.setPos (CameraStart);
MouseListener.setMatrix (m);
@@ -352,9 +353,7 @@ int main(int argc, char **argv)
if (j < (vCluster.size()-1))
sAllClusters += ", ";
}
- TextContext.printfAt (0, 1-0.028f, sAllClusters.c_str());
-
-
+ TextContext.printfAt (0, 1-0.028f, sAllClusters.c_str());
}
// -----------------------------------------------------
@@ -362,14 +361,13 @@ int main(int argc, char **argv)
CNELU::Driver->swapBuffers ();
-
// Keys management
// ---------------
if (CNELU::AsyncListener.isKeyDown (KeySHIFT))
- MouseListener.setSpeed (10.0f);
+ MouseListener.setSpeed (50.0f);
else
- MouseListener.setSpeed (2.0f);
+ MouseListener.setSpeed (10.0f);
CNELU::Camera->setMatrix (MouseListener.getViewMatrix());
@@ -419,6 +417,7 @@ int main(int argc, char **argv)
}
}
- while (!CNELU::AsyncListener.isKeyPushed (KeyESCAPE));
- return 0;
+ while ((!CNELU::AsyncListener.isKeyPushed(KeyESCAPE)) && CNELU::Driver->isActive());
+
+ return EXIT_SUCCESS;
}
diff --git a/code/nel/tools/3d/zone_welder/zone_welder.cpp b/code/nel/tools/3d/zone_welder/zone_welder.cpp
index 028549cff..31610f68e 100644
--- a/code/nel/tools/3d/zone_welder/zone_welder.cpp
+++ b/code/nel/tools/3d/zone_welder/zone_welder.cpp
@@ -76,6 +76,13 @@ struct CWeldableVertexInfos
sint PatchIndex; // patch
uint8 PatchVertex; // 0,1,2,3
+ CWeldableVertexInfos()
+ {
+ IndexInZone = 0;
+ PatchIndex = 0;
+ PatchVertex = 0;
+ }
+
bool operator< (const CWeldableVertexInfos& wvinf) const
{
if(IndexInZone