From bf42d20f980c60a32e976757e4d4f510ff90835e Mon Sep 17 00:00:00 2001 From: gugus Date: Sun, 2 Oct 2011 13:05:08 +0200 Subject: [PATCH 1/2] Fixed some compilation errors on windows. Note that it works on my computer, but it *might* not work on older versions of windows. --- components/files/path.hpp | 2 +- components/files/windowspath.cpp | 5 ++++- 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/components/files/path.hpp b/components/files/path.hpp index 0788cefb1..23c702bbb 100644 --- a/components/files/path.hpp +++ b/components/files/path.hpp @@ -30,7 +30,7 @@ #include namespace Files { typedef LinuxPath TargetPathType; } -#elif defined(__WIN32) || defined(__WINDOWS__) +#elif defined(__WIN32) || defined(__WINDOWS__) || defined (_WINDOWS) #include namespace Files { typedef WindowsPath TargetPathType; } diff --git a/components/files/windowspath.cpp b/components/files/windowspath.cpp index f42f149c1..b971cbbbf 100644 --- a/components/files/windowspath.cpp +++ b/components/files/windowspath.cpp @@ -5,7 +5,10 @@ #include #include -#include +#include +#include + +#pragma comment(lib, "Shlwapi.lib") namespace Files { From 241cf2555d7f646297cbf13ac3386810e737b9a0 Mon Sep 17 00:00:00 2001 From: gugus Date: Sat, 29 Oct 2011 13:35:43 +0200 Subject: [PATCH 2/2] Fixe collision shape bug. --- components/nifbullet/bullet_nif_loader.cpp | 34 +++++----------------- 1 file changed, 8 insertions(+), 26 deletions(-) diff --git a/components/nifbullet/bullet_nif_loader.cpp b/components/nifbullet/bullet_nif_loader.cpp index 32ca8c41c..82e9d7adc 100644 --- a/components/nifbullet/bullet_nif_loader.cpp +++ b/components/nifbullet/bullet_nif_loader.cpp @@ -231,7 +231,7 @@ void ManualBulletShapeLoader::handleNode(Nif::Node *node, int flags, else if (node->recType == Nif::RC_NiTriShape && (isCollisionNode || !hasCollisionNode)) { cShape->collide = true; - handleNiTriShape(dynamic_cast(node), flags,finalRot,finalPos,finalScale,raycastingOnly); + handleNiTriShape(dynamic_cast(node), flags,finalRot,finalPos,parentScale,raycastingOnly); } else if(node->recType == Nif::RC_RootCollisionNode) { @@ -269,27 +269,6 @@ void ManualBulletShapeLoader::handleNiTriShape(Nif::NiTriShape *shape, int flags // bother setting it up. return; - btTransform tr; - tr.setRotation(getbtQuat(parentRot)); - tr.setOrigin(btVector3(parentPos.x,parentPos.y,parentPos.z)); - - // Bounding box collision isn't implemented, always use mesh for now. - /*if (bbcollide) - { - return; - std::cout << "bbcolide?"; - //TODO: check whether it's half box or not (is there a /2?) - NodeShape = new btBoxShape(btVector3(shape->boundXYZ->array[0]/2.,shape->boundXYZ->array[1]/2.,shape->boundXYZ->array[2]/2.)); - std::cout << "bbcolide12121212121"; - currentShape->addChildShape(tr,NodeShape); - std::cout << "aaaaaaaaaaaaa"; - return; - collide = true; - bbcollide = false; - }*/ - - /* Do in-place transformation.the only needed transfo is the scale. (maybe not in fact) - */ Nif::NiTriShapeData *data = shape->data.getPtr(); @@ -298,10 +277,13 @@ void ManualBulletShapeLoader::handleNiTriShape(Nif::NiTriShape *shape, int flags for(unsigned int i=0; i < data->triangles.length; i = i+3) { - btVector3 b1(vertices[triangles[i+0]*3]*parentScale,vertices[triangles[i+0]*3+1]*parentScale,vertices[triangles[i+0]*3+2]*parentScale); - btVector3 b2(vertices[triangles[i+1]*3]*parentScale,vertices[triangles[i+1]*3+1]*parentScale,vertices[triangles[i+1]*3+2]*parentScale); - btVector3 b3(vertices[triangles[i+2]*3]*parentScale,vertices[triangles[i+2]*3+1]*parentScale,vertices[triangles[i+2]*3+2]*parentScale); - mTriMesh->addTriangle(b1,b2,b3); + Ogre::Vector3 b1(vertices[triangles[i+0]*3]*parentScale,vertices[triangles[i+0]*3+1]*parentScale,vertices[triangles[i+0]*3+2]*parentScale); + Ogre::Vector3 b2(vertices[triangles[i+1]*3]*parentScale,vertices[triangles[i+1]*3+1]*parentScale,vertices[triangles[i+1]*3+2]*parentScale); + Ogre::Vector3 b3(vertices[triangles[i+2]*3]*parentScale,vertices[triangles[i+2]*3+1]*parentScale,vertices[triangles[i+2]*3+2]*parentScale); + b1 = parentRot * b1 + parentPos; + b2 = parentRot * b2 + parentPos; + b3 = parentRot * b3 + parentPos; + mTriMesh->addTriangle(btVector3(b1.x,b1.y,b1.z),btVector3(b2.x,b2.y,b2.z),btVector3(b3.x,b3.y,b3.z)); } }