mirror of https://github.com/mosra/magnum.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
53 lines
1.9 KiB
53 lines
1.9 KiB
|
14 years ago
|
/*
|
||
|
|
Copyright © 2010, 2011, 2012 Vladimír Vondruš <mosra@centrum.cz>
|
||
|
|
|
||
|
|
This file is part of Magnum.
|
||
|
|
|
||
|
|
Magnum is free software: you can redistribute it and/or modify
|
||
|
|
it under the terms of the GNU Lesser General Public License version 3
|
||
|
|
only, as published by the Free Software Foundation.
|
||
|
|
|
||
|
|
Magnum is distributed in the hope that it will be useful,
|
||
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
|
GNU Lesser General Public License version 3 for more details.
|
||
|
|
*/
|
||
|
|
|
||
|
|
#include "GenerateFlatNormals.h"
|
||
|
|
|
||
|
|
#include "MeshTools/Clean.h"
|
||
|
|
|
||
|
|
using namespace std;
|
||
|
|
using namespace Corrade::Utility;
|
||
|
|
|
||
|
|
namespace Magnum { namespace MeshTools {
|
||
|
|
|
||
|
|
tuple<vector<unsigned int>, vector<Vector3>> generateFlatNormals(const std::vector< unsigned int >& indices, const vector< Vector4 >& vertices) {
|
||
|
|
if(indices.size()%3 != 0) {
|
||
|
|
Error() << "MeshTools::generateFlatNormals(): index count is not divisible by 3!";
|
||
|
|
return tuple<vector<unsigned int>, vector<Vector3>>();
|
||
|
|
}
|
||
|
|
|
||
|
|
/* Create normal for every triangle (assuming counterclockwise winding) */
|
||
|
|
vector<unsigned int> normalIndices;
|
||
|
|
normalIndices.reserve(indices.size());
|
||
|
|
vector<Vector3> normals;
|
||
|
|
normals.reserve(indices.size()/3);
|
||
|
|
for(size_t i = 0; i != indices.size(); i += 3) {
|
||
|
|
Vector3 normal = Vector3::cross(vertices[indices[i+2]].xyz()-vertices[indices[i+1]].xyz(),
|
||
|
|
vertices[indices[i]].xyz()-vertices[indices[i+1]].xyz()).normalized();
|
||
|
|
|
||
|
|
/* Use the same normal for all three vertices of the face */
|
||
|
|
normalIndices.push_back(normals.size());
|
||
|
|
normalIndices.push_back(normals.size());
|
||
|
|
normalIndices.push_back(normals.size());
|
||
|
|
normals.push_back(normal);
|
||
|
|
}
|
||
|
|
|
||
|
|
/* Clean duplicate normals and return */
|
||
|
|
clean(normalIndices, normals);
|
||
|
|
return make_tuple(normalIndices, normals);
|
||
|
|
}
|
||
|
|
|
||
|
|
}}
|