/* * ***** BEGIN GPL LICENSE BLOCK ***** * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; either version 2 * of the License, or (at your option) any later version. * * This program 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software Foundation, * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * * Contributor(s): Esteban Tovagliari, Cedric Paille, Kevin Dietrich * * ***** END GPL LICENSE BLOCK ***** */ #ifndef __ABC_MESH_H__ #define __ABC_MESH_H__ #include "abc_customdata.h" #include "abc_object.h" struct DerivedMesh; struct Mesh; struct ModifierData; /* ************************************************************************** */ class AbcMeshWriter : public AbcObjectWriter { Alembic::AbcGeom::OPolyMeshSchema m_mesh_schema; Alembic::AbcGeom::OPolyMeshSchema::Sample m_mesh_sample; Alembic::AbcGeom::OSubDSchema m_subdiv_schema; Alembic::AbcGeom::OSubDSchema::Sample m_subdiv_sample; Alembic::Abc::OArrayProperty m_mat_indices; bool m_is_animated; ModifierData *m_subsurf_mod; CDStreamConfig m_custom_data_config; bool m_is_liquid; bool m_is_subd; public: AbcMeshWriter(Scene *scene, Object *ob, AbcTransformWriter *parent, uint32_t time_sampling, ExportSettings &settings); ~AbcMeshWriter(); private: virtual void do_write(); bool isAnimated() const; void writeMesh(DerivedMesh *dm); void writeSubD(DerivedMesh *dm); void getMeshInfo(DerivedMesh *dm, std::vector &points, std::vector &facePoints, std::vector &faceCounts, std::vector &creaseIndices, std::vector &creaseLengths, std::vector &creaseSharpness); DerivedMesh *getFinalMesh(); void freeMesh(DerivedMesh *dm); void getMaterialIndices(DerivedMesh *dm, std::vector &indices); void writeArbGeoParams(DerivedMesh *dm); void getGeoGroups(DerivedMesh *dm, std::map > &geoGroups); /* fluid surfaces support */ void getVelocities(DerivedMesh *dm, std::vector &vels); template void writeFaceSets(DerivedMesh *dm, Schema &schema); }; /* ************************************************************************** */ class AbcMeshReader : public AbcObjectReader { Alembic::AbcGeom::IPolyMeshSchema m_schema; CDStreamConfig m_mesh_data; public: AbcMeshReader(const Alembic::Abc::IObject &object, ImportSettings &settings); bool valid() const; bool accepts_object_type(const Alembic::AbcCoreAbstract::ObjectHeader &alembic_header, const Object *const ob, const char **err_str) const; void readObjectData(Main *bmain, const Alembic::Abc::ISampleSelector &sample_sel); DerivedMesh *read_derivedmesh(DerivedMesh *dm, const Alembic::Abc::ISampleSelector &sample_sel, int read_flag, const char **err_str); private: void readFaceSetsSample(Main *bmain, Mesh *mesh, size_t poly_start, const Alembic::AbcGeom::ISampleSelector &sample_sel); void assign_facesets_to_mpoly(const Alembic::Abc::ISampleSelector &sample_sel, size_t poly_start, MPoly *mpoly, int totpoly, std::map & r_mat_map); }; /* ************************************************************************** */ class AbcSubDReader : public AbcObjectReader { Alembic::AbcGeom::ISubDSchema m_schema; CDStreamConfig m_mesh_data; public: AbcSubDReader(const Alembic::Abc::IObject &object, ImportSettings &settings); bool valid() const; bool accepts_object_type(const Alembic::AbcCoreAbstract::ObjectHeader &alembic_header, const Object *const ob, const char **err_str) const; void readObjectData(Main *bmain, const Alembic::Abc::ISampleSelector &sample_sel); DerivedMesh *read_derivedmesh(DerivedMesh *dm, const Alembic::Abc::ISampleSelector &sample_sel, int read_flag, const char **err_str); }; /* ************************************************************************** */ void read_mverts(MVert *mverts, const Alembic::AbcGeom::P3fArraySamplePtr &positions, const Alembic::AbcGeom::N3fArraySamplePtr &normals); CDStreamConfig get_config(DerivedMesh *dm); #endif /* __ABC_MESH_H__ */