Add properties information on assimp info command line

pull/4426/head
Sergio Acereda 2022-03-04 17:09:29 +01:00
parent a1e03e3481
commit a2543e7151
1 changed files with 18 additions and 6 deletions

View File

@ -425,19 +425,31 @@ int Assimp_Info(const char *const *params, unsigned int num) {
} }
// materials // materials
unsigned int total = 0; if (scene->mNumMaterials)
printf("\nNamed Materials:");
for (unsigned int i = 0; i < scene->mNumMaterials; ++i) { for (unsigned int i = 0; i < scene->mNumMaterials; ++i) {
aiString name; const aiMaterial *mat = scene->mMaterials[i];
if (AI_SUCCESS == aiGetMaterialString(scene->mMaterials[i], AI_MATKEY_NAME, &name)) { aiString name = mat->GetName();
printf("%s\n \'%s\'", (total++ ? "" : "\nNamed Materials:"), name.data); printf("\n \'%s\'", name.data);
if (mat->mNumProperties)
printf(" (prop) [index / bytes | texture semantic]");
for (unsigned p = 0; p < mat->mNumProperties; p++) {
const aiMaterialProperty *prop = mat->mProperties[p];
const aiTextureType textype = static_cast<aiTextureType>(prop->mSemantic);
printf("\n %d (%s): [%d / %d | %s]",
p,
prop->mKey.data,
prop->mIndex,
prop->mDataLength,
TextureTypeToString(textype));
} }
} }
if (total) { if (scene->mNumMaterials) {
printf("\n"); printf("\n");
} }
// textures // textures
total = 0; unsigned int total = 0;
for (unsigned int i = 0; i < scene->mNumMaterials; ++i) { for (unsigned int i = 0; i < scene->mNumMaterials; ++i) {
aiString name; aiString name;
static const aiTextureType types[] = { static const aiTextureType types[] = {