git-svn-id: svn://db.shs.com.ru/libs@685 a8b55f48-bf90-11e4-a774-851b48703e85

This commit is contained in:
2019-12-11 23:15:21 +00:00
parent a9cabf5beb
commit 79f0676a64

View File

@@ -27,6 +27,7 @@
#include <assimp/mesh.h>
#include <assimp/material.h>
QString fromAiString (const aiString & s) {return QString::fromLocal8Bit(s.C_Str());}
QVector3D fromAiVector3D(const aiVector3D & v) {return QVector3D(v.x, v.y, v.z);}
Vector3i fromAiFace (const aiFace & v) {return Vector3i(v.mIndices[0], v.mIndices[1], v.mIndices[2]);}
QMatrix4x4 fromAiMatrix4D(const aiMatrix4x4 & v) {return QMatrix4x4(v.a1, v.a2, v.a3, v.a4,
@@ -97,17 +98,17 @@ float aiMatFloat(const aiMaterial * m, const char * key, uint s0, uint s1, float
QString aiMatString(const aiMaterial * m, const char * key, uint s0, uint s1) {
aiString p;
aiReturn r = const_cast<aiMaterial*>(m)->Get(key, s0, s1, p);
//qDebug() << "GetTexture" << key << s0 << r << p.C_Str();
//qDebug() << "GetTexture" << key << s0 << r << fromAiString(p);
if (r != aiReturn_SUCCESS) return QString();
return QString(p.C_Str());
return fromAiString(p);
}
Material * assimpMaterial(const aiMaterial * m) {
if (!m) return 0;
Material * ret = new Material();
ret->name = const_cast<aiMaterial*>(m)->GetName().C_Str();
ret->name = fromAiString(const_cast<aiMaterial*>(m)->GetName());
//qDebug() << "mat" << ret->name;
//for (int i = 0; i < m->mNumProperties; ++i)
// qDebug()<< m->mProperties[i]->mKey.C_Str();
// qDebug()<< fromAiString(m->mProperties[i]->mKey);
ret->color_diffuse = aiMatColor(m, AI_MATKEY_COLOR_DIFFUSE);
ret->color_specular = aiMatColor(m, AI_MATKEY_COLOR_SPECULAR);
ret->color_emission = aiMatColor(m, AI_MATKEY_COLOR_EMISSIVE);
@@ -125,7 +126,7 @@ Material * assimpMaterial(const aiMaterial * m) {
Light * assimpLight(const aiLight * l) {
if (!l) return 0;
Light * ret = new Light();
ret->setName(l->mName.C_Str());
ret->setName(fromAiString(l->mName));
ret->setPos(fromAiVector3D(l->mPosition));
ret->setDirection(fromAiVector3D(l->mDirection));
ret->decay_const = l->mAttenuationConstant ;
@@ -149,7 +150,7 @@ ObjectBaseList assimpObject(const aiNode * n, const QVector<Mesh * > & meshes, a
if (!n) return ObjectBaseList();
ObjectBaseList ret;
ObjectBase * obj = 0;
QString name = n->mName.C_Str();
QString name = fromAiString(n->mName);
Light * light = light_by_name.value(name, 0);
if (light) {
obj = light->clone();