Files
create/src/Mod/Mesh/App/MeshTexture.h
2019-09-24 17:19:15 +02:00

74 lines
3.2 KiB
C++

/***************************************************************************
* Copyright (c) 2019 Werner Mayer <wmayer[at]users.sourceforge.net> *
* *
* This file is part of the FreeCAD CAx development system. *
* *
* This library is free software; you can redistribute it and/or *
* modify it under the terms of the GNU Library General Public *
* License as published by the Free Software Foundation; either *
* version 2 of the License, or (at your option) any later version. *
* *
* This library 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 Library General Public License for more details. *
* *
* You should have received a copy of the GNU Library General Public *
* License along with this library; see the file COPYING.LIB. If not, *
* write to the Free Software Foundation, Inc., 59 Temple Place, *
* Suite 330, Boston, MA 02111-1307, USA *
* *
***************************************************************************/
#ifndef MESH_MESHTEXTURE_H
#define MESH_MESHTEXTURE_H
#include <memory>
#include "Core/Algorithm.h"
#include "Core/MeshKernel.h"
#include "Core/KDTree.h"
#include "Mesh.h"
namespace Mesh
{
/*! The MeshTexture class.
This algorithm is useful to update the material after a mesh has been modified
by removing points or facets. If the coordinates of points have changed or if
new points have been added then a pre-defined color will be set.
@author Werner Mayer
*/
class MeshExport MeshTexture
{
public:
/*!
A mesh with material. The number of points or facets must match with the number of colors.
*/
MeshTexture(const Mesh::MeshObject& mesh, const MeshCore::Material &material);
/*!
Find common points or facets of this to the original mesh. For points or facets
that don't match \a defaultColor will be used instead, otherwise the color of the
original material is used.
*/
void apply(const Mesh::MeshObject& mesh, const App::Color& defaultColor, MeshCore::Material &material);
/*!
Find common points or facets of this to the original mesh and use the color of the original material.
If for a point of \a mesh no matching point of the original mesh can be found the texture mapping will
fail.
*/
void apply(const Mesh::MeshObject& mesh, MeshCore::Material &material);
private:
const MeshCore::Material &materialRefMesh;
unsigned long countPointsRefMesh;
std::unique_ptr<MeshCore::MeshKDTree> kdTree;
std::unique_ptr<MeshCore::MeshRefPointToFacets> refPnt2Fac;
MeshCore::MeshIO::Binding binding = MeshCore::MeshIO::OVERALL;
};
} // namespace Mesh
#endif // MESH_MESHTEXTURE_H