mirror of
https://github.com/TES3MP/openmw-tes3mp.git
synced 2025-01-19 23:53:52 +00:00
Changing a few things around with handleshapes
This commit is contained in:
parent
5e1cc07ee8
commit
0712bba49b
5 changed files with 129 additions and 24 deletions
|
@ -97,21 +97,25 @@ namespace MWRender{
|
||||||
}
|
}
|
||||||
|
|
||||||
void Animation::handleShapes(std::vector<Nif::NiTriShapeCopy>* allshapes, Ogre::Entity* creaturemodel, Ogre::SkeletonInstance *skel){
|
void Animation::handleShapes(std::vector<Nif::NiTriShapeCopy>* allshapes, Ogre::Entity* creaturemodel, Ogre::SkeletonInstance *skel){
|
||||||
|
bool useHandles = skel == creaturemodel->getSkeleton();
|
||||||
shapeNumber = 0;
|
shapeNumber = 0;
|
||||||
|
|
||||||
std::vector<Nif::NiTriShapeCopy>::iterator allshapesiter;
|
std::vector<Nif::NiTriShapeCopy>::iterator allshapesiter;
|
||||||
for(allshapesiter = allshapes->begin(); allshapesiter != allshapes->end(); allshapesiter++)
|
for(allshapesiter = allshapes->begin(); allshapesiter != allshapes->end(); allshapesiter++)
|
||||||
|
|
||||||
{
|
{
|
||||||
|
//std::map<unsigned short, PosAndRot> vecPosRot;
|
||||||
|
|
||||||
Nif::NiTriShapeCopy& copy = *allshapesiter;
|
Nif::NiTriShapeCopy& copy = *allshapesiter;
|
||||||
std::vector<Ogre::Vector3> allvertices = copy.vertices;
|
std::vector<Ogre::Vector3>* allvertices = ©.vertices;
|
||||||
std::vector<Ogre::Vector3> allnormals = copy.normals;
|
std::vector<Ogre::Vector3>* allnormals = ©.normals;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
std::set<unsigned int> vertices;
|
//std::set<unsigned int> vertices;
|
||||||
//std::set<unsigned int> normals;
|
//std::set<unsigned int> normals;
|
||||||
std::vector<Nif::NiSkinData::BoneInfoCopy> boneinfovector = copy.boneinfo;
|
//std::vector<Nif::NiSkinData::BoneInfoCopy> boneinfovector = copy.boneinfo;
|
||||||
|
std::map<int, std::vector<Nif::NiSkinData::IndividualWeight>>* verticesToChange = ©.vertsToWeights;
|
||||||
|
|
||||||
//std::cout << "Name " << copy.sname << "\n";
|
//std::cout << "Name " << copy.sname << "\n";
|
||||||
Ogre::HardwareVertexBufferSharedPtr vbuf = creaturemodel->getMesh()->getSubMesh(copy.sname)->vertexData->vertexBufferBinding->getBuffer(0);
|
Ogre::HardwareVertexBufferSharedPtr vbuf = creaturemodel->getMesh()->getSubMesh(copy.sname)->vertexData->vertexBufferBinding->getBuffer(0);
|
||||||
|
@ -161,17 +165,91 @@ namespace MWRender{
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
allvertices = initialVertices;
|
allvertices = &initialVertices;
|
||||||
}
|
}
|
||||||
shapeNumber++;
|
shapeNumber++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if(boneinfovector.size() > 0){
|
if(verticesToChange->size() > 0){
|
||||||
|
|
||||||
|
for(std::map<int, std::vector<Nif::NiSkinData::IndividualWeight>>::iterator iter = verticesToChange->begin();
|
||||||
|
iter != verticesToChange->end(); iter++)
|
||||||
|
{
|
||||||
|
std::vector<Nif::NiSkinData::IndividualWeight> inds = iter->second;
|
||||||
|
int verIndex = iter->first;
|
||||||
|
Ogre::Vector3 currentVertex = (*allvertices)[verIndex];
|
||||||
|
Nif::NiSkinData::BoneInfoCopy* boneinfocopy = &(allshapesiter->boneinfo[inds[0].boneinfocopyindex]);
|
||||||
|
Ogre::Bone *bonePtr = 0;
|
||||||
|
if(useHandles)
|
||||||
|
{
|
||||||
|
bonePtr = skel->getBone(boneinfocopy->bonehandle);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
bonePtr = skel->getBone(boneinfocopy->bonename);
|
||||||
|
|
||||||
|
Ogre::Vector3 vecPos = bonePtr->_getDerivedPosition() + bonePtr->_getDerivedOrientation() * boneinfocopy->trafo.trans;
|
||||||
|
Ogre::Quaternion vecRot = bonePtr->_getDerivedOrientation() * boneinfocopy->trafo.rotation;
|
||||||
|
|
||||||
|
|
||||||
for (unsigned int i = 0; i < boneinfovector.size(); i++)
|
/*if(vecPosRot.find(boneinfocopy->bonehandle) == vecPosRot.end()){
|
||||||
|
vecPos = bonePtr->_getDerivedPosition() + bonePtr->_getDerivedOrientation() * boneinfocopy->trafo.trans;
|
||||||
|
vecRot = bonePtr->_getDerivedOrientation() * boneinfocopy->trafo.rotation;
|
||||||
|
|
||||||
|
if(useHandles){
|
||||||
|
PosAndRot both;
|
||||||
|
both.vecPos = vecPos;
|
||||||
|
both.vecRot = vecRot;
|
||||||
|
vecPosRot[boneinfocopy->bonehandle] = both;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
PosAndRot both = vecPosRot[boneinfocopy->bonehandle];
|
||||||
|
vecPos = both.vecPos;
|
||||||
|
vecRot = both.vecRot;
|
||||||
|
}*/
|
||||||
|
|
||||||
|
Ogre::Vector3 absVertPos = (vecPos + vecRot * currentVertex) * inds[0].weight;
|
||||||
|
|
||||||
|
|
||||||
|
for(int i = 1; i < inds.size(); i++){
|
||||||
|
boneinfocopy = &(allshapesiter->boneinfo[inds[i].boneinfocopyindex]);
|
||||||
|
if(useHandles)
|
||||||
|
bonePtr = skel->getBone(boneinfocopy->bonehandle);
|
||||||
|
else
|
||||||
|
bonePtr = skel->getBone(boneinfocopy->bonename);
|
||||||
|
vecPos = bonePtr->_getDerivedPosition() + bonePtr->_getDerivedOrientation() * boneinfocopy->trafo.trans;
|
||||||
|
vecRot = bonePtr->_getDerivedOrientation() * boneinfocopy->trafo.rotation;
|
||||||
|
|
||||||
|
/*if(vecPosRot.find(boneinfocopy->bonehandle) == vecPosRot.end()){
|
||||||
|
vecPos = bonePtr->_getDerivedPosition() + bonePtr->_getDerivedOrientation() * boneinfocopy->trafo.trans;
|
||||||
|
vecRot = bonePtr->_getDerivedOrientation() * boneinfocopy->trafo.rotation;
|
||||||
|
|
||||||
|
if(useHandles){
|
||||||
|
PosAndRot both;
|
||||||
|
both.vecPos = vecPos;
|
||||||
|
both.vecRot = vecRot;
|
||||||
|
vecPosRot[boneinfocopy->bonehandle] = both;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
PosAndRot both = vecPosRot[boneinfocopy->bonehandle];
|
||||||
|
vecPos = both.vecPos;
|
||||||
|
vecRot = both.vecRot;
|
||||||
|
}*/
|
||||||
|
|
||||||
|
|
||||||
|
absVertPos += (vecPos + vecRot * currentVertex) * inds[i].weight;
|
||||||
|
|
||||||
|
}
|
||||||
|
Ogre::Real* addr = (pReal + 3 * verIndex);
|
||||||
|
*addr = absVertPos.x;
|
||||||
|
*(addr+1) = absVertPos.y;
|
||||||
|
*(addr+2) = absVertPos.z;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*for (unsigned int i = 0; i < boneinfovector.size(); i++)
|
||||||
{
|
{
|
||||||
Nif::NiSkinData::BoneInfoCopy boneinfo = boneinfovector[i];
|
Nif::NiSkinData::BoneInfoCopy boneinfo = boneinfovector[i];
|
||||||
if(skel->hasBone(boneinfo.bonename)){
|
if(skel->hasBone(boneinfo.bonename)){
|
||||||
|
@ -234,13 +312,13 @@ namespace MWRender{
|
||||||
|
|
||||||
}*/
|
}*/
|
||||||
|
|
||||||
}
|
//}
|
||||||
}
|
//}
|
||||||
|
|
||||||
|
|
||||||
}
|
//} //Comment out
|
||||||
|
|
||||||
|
|
||||||
|
;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -293,8 +371,8 @@ namespace MWRender{
|
||||||
// Computes C = B + AxC*scale
|
// Computes C = B + AxC*scale
|
||||||
// final_vector = old_vector + old_rotation*new_vector*old_scale/
|
// final_vector = old_vector + old_rotation*new_vector*old_scale/
|
||||||
|
|
||||||
for(unsigned int i = 0; i < allvertices.size(); i++){
|
for(unsigned int i = 0; i < allvertices->size(); i++){
|
||||||
Ogre::Vector3 current = transmult + rotmult * allvertices[i];
|
Ogre::Vector3 current = transmult + rotmult * (*allvertices)[i];
|
||||||
Ogre::Real* addr = pReal + i * 3;
|
Ogre::Real* addr = pReal + i * 3;
|
||||||
*addr = current.x;
|
*addr = current.x;
|
||||||
*(addr+1) = current.y;
|
*(addr+1) = current.y;
|
||||||
|
|
|
@ -15,6 +15,11 @@
|
||||||
|
|
||||||
namespace MWRender{
|
namespace MWRender{
|
||||||
|
|
||||||
|
struct PosAndRot{
|
||||||
|
Ogre::Quaternion vecRot;
|
||||||
|
Ogre::Vector3 vecPos;
|
||||||
|
};
|
||||||
|
|
||||||
class Animation{
|
class Animation{
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
|
@ -390,9 +390,15 @@ public:
|
||||||
struct BoneInfoCopy
|
struct BoneInfoCopy
|
||||||
{
|
{
|
||||||
std::string bonename;
|
std::string bonename;
|
||||||
|
unsigned short bonehandle;
|
||||||
BoneTrafoCopy trafo;
|
BoneTrafoCopy trafo;
|
||||||
Vector4 unknown;
|
Vector4 unknown;
|
||||||
std::vector<VertWeight> weights;
|
//std::vector<VertWeight> weights;
|
||||||
|
};
|
||||||
|
struct IndividualWeight
|
||||||
|
{
|
||||||
|
float weight;
|
||||||
|
unsigned int boneinfocopyindex;
|
||||||
};
|
};
|
||||||
|
|
||||||
const BoneTrafo *trafo;
|
const BoneTrafo *trafo;
|
||||||
|
|
|
@ -103,6 +103,7 @@ struct NiTriShapeCopy
|
||||||
std::vector<Ogre::Vector3> vertices;
|
std::vector<Ogre::Vector3> vertices;
|
||||||
std::vector<Ogre::Vector3> normals;
|
std::vector<Ogre::Vector3> normals;
|
||||||
std::vector<Nif::NiSkinData::BoneInfoCopy> boneinfo;
|
std::vector<Nif::NiSkinData::BoneInfoCopy> boneinfo;
|
||||||
|
std::map<int, std::vector<Nif::NiSkinData::IndividualWeight>> vertsToWeights;
|
||||||
Nif::NiMorphData morph;
|
Nif::NiMorphData morph;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -355,7 +355,7 @@ void NIFLoader::createOgreSubMesh(NiTriShape *shape, const String &material, std
|
||||||
HardwareVertexBufferSharedPtr vbuf =
|
HardwareVertexBufferSharedPtr vbuf =
|
||||||
HardwareBufferManager::getSingleton().createVertexBuffer(
|
HardwareBufferManager::getSingleton().createVertexBuffer(
|
||||||
VertexElement::getTypeSize(VET_FLOAT3),
|
VertexElement::getTypeSize(VET_FLOAT3),
|
||||||
numVerts, HardwareBuffer::HBU_DYNAMIC);
|
numVerts, HardwareBuffer::HBU_STATIC_WRITE_ONLY, false);
|
||||||
|
|
||||||
if(flip)
|
if(flip)
|
||||||
{
|
{
|
||||||
|
@ -388,7 +388,7 @@ void NIFLoader::createOgreSubMesh(NiTriShape *shape, const String &material, std
|
||||||
decl->addElement(nextBuf, 0, VET_FLOAT3, VES_NORMAL);
|
decl->addElement(nextBuf, 0, VET_FLOAT3, VES_NORMAL);
|
||||||
vbuf = HardwareBufferManager::getSingleton().createVertexBuffer(
|
vbuf = HardwareBufferManager::getSingleton().createVertexBuffer(
|
||||||
VertexElement::getTypeSize(VET_FLOAT3),
|
VertexElement::getTypeSize(VET_FLOAT3),
|
||||||
numVerts, HardwareBuffer::HBU_DYNAMIC,true);
|
numVerts, HardwareBuffer::HBU_STATIC_WRITE_ONLY, false);
|
||||||
|
|
||||||
if(flip)
|
if(flip)
|
||||||
{
|
{
|
||||||
|
@ -751,7 +751,6 @@ void NIFLoader::handleNiTriShape(NiTriShape *shape, int flags, BoundsFinder &bou
|
||||||
if (!shape->skin.empty())
|
if (!shape->skin.empty())
|
||||||
{
|
{
|
||||||
|
|
||||||
//Bone assignments are stored in submeshes, so we don't need to copy them
|
|
||||||
|
|
||||||
|
|
||||||
// vector that stores if the position of a vertex is absolute
|
// vector that stores if the position of a vertex is absolute
|
||||||
|
@ -791,10 +790,12 @@ void NIFLoader::handleNiTriShape(NiTriShape *shape, int flags, BoundsFinder &bou
|
||||||
// final_vector = old_vector + old_rotation*new_vector*old_scale
|
// final_vector = old_vector + old_rotation*new_vector*old_scale
|
||||||
|
|
||||||
|
|
||||||
Nif::NiSkinData::BoneInfoCopy boneinfo;
|
Nif::NiSkinData::BoneInfoCopy boneinfocopy;
|
||||||
boneinfo.trafo.rotation = convertRotation(it->trafo->rotation);
|
boneinfocopy.trafo.rotation = convertRotation(it->trafo->rotation);
|
||||||
boneinfo.trafo.trans = convertVector3(it->trafo->trans);
|
boneinfocopy.trafo.trans = convertVector3(it->trafo->trans);
|
||||||
boneinfo.bonename = shape->skin->bones[boneIndex].name.toString();
|
boneinfocopy.bonename = shape->skin->bones[boneIndex].name.toString();
|
||||||
|
boneinfocopy.bonehandle = bonePtr->getHandle();
|
||||||
|
copy.boneinfo.push_back(boneinfocopy);
|
||||||
for (unsigned int i=0; i<it->weights.length; i++)
|
for (unsigned int i=0; i<it->weights.length; i++)
|
||||||
{
|
{
|
||||||
vecPos = bonePtr->_getDerivedPosition() +
|
vecPos = bonePtr->_getDerivedPosition() +
|
||||||
|
@ -802,7 +803,21 @@ void NIFLoader::handleNiTriShape(NiTriShape *shape, int flags, BoundsFinder &bou
|
||||||
|
|
||||||
vecRot = bonePtr->_getDerivedOrientation() * convertRotation(it->trafo->rotation);
|
vecRot = bonePtr->_getDerivedOrientation() * convertRotation(it->trafo->rotation);
|
||||||
unsigned int verIndex = (it->weights.ptr + i)->vertex;
|
unsigned int verIndex = (it->weights.ptr + i)->vertex;
|
||||||
boneinfo.weights.push_back(*(it->weights.ptr + i));
|
//boneinfo.weights.push_back(*(it->weights.ptr + i));
|
||||||
|
Nif::NiSkinData::IndividualWeight ind;
|
||||||
|
ind.weight = (it->weights.ptr + i)->weight;
|
||||||
|
ind.boneinfocopyindex = copy.boneinfo.size() - 1;
|
||||||
|
if(copy.vertsToWeights.find(verIndex) == copy.vertsToWeights.end())
|
||||||
|
{
|
||||||
|
std::vector<Nif::NiSkinData::IndividualWeight> blank;
|
||||||
|
blank.push_back(ind);
|
||||||
|
copy.vertsToWeights[verIndex] = blank;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
copy.vertsToWeights[verIndex].push_back(ind);
|
||||||
|
}
|
||||||
|
|
||||||
//Check if the vertex is relativ, FIXME: Is there a better solution?
|
//Check if the vertex is relativ, FIXME: Is there a better solution?
|
||||||
if (vertexPosAbsolut[verIndex] == false)
|
if (vertexPosAbsolut[verIndex] == false)
|
||||||
{
|
{
|
||||||
|
@ -865,7 +880,7 @@ void NIFLoader::handleNiTriShape(NiTriShape *shape, int flags, BoundsFinder &bou
|
||||||
|
|
||||||
vertexBoneAssignments.push_back(vba);
|
vertexBoneAssignments.push_back(vba);
|
||||||
}
|
}
|
||||||
copy.boneinfo.push_back(boneinfo);
|
|
||||||
|
|
||||||
boneIndex++;
|
boneIndex++;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue