2012-12-18 00:51:25 +00:00
|
|
|
/*
|
|
|
|
|
* ***** 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.
|
|
|
|
|
*
|
|
|
|
|
* ***** END GPL LICENSE BLOCK *****
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#ifndef __BLENDER_FILE_LOADER_H__
|
|
|
|
|
#define __BLENDER_FILE_LOADER_H__
|
|
|
|
|
|
|
|
|
|
/** \file blender/freestyle/intern/blender_interface/BlenderFileLoader.h
|
|
|
|
|
* \ingroup freestyle
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#include <string.h>
|
|
|
|
|
#include <float.h>
|
|
|
|
|
|
|
|
|
|
#include "../geometry/BBox.h"
|
|
|
|
|
#include "../geometry/Geom.h"
|
|
|
|
|
#include "../geometry/GeomCleaner.h"
|
|
|
|
|
#include "../geometry/GeomUtils.h"
|
|
|
|
|
#include "../scene_graph/IndexedFaceSet.h"
|
|
|
|
|
#include "../scene_graph/NodeGroup.h"
|
|
|
|
|
#include "../scene_graph/NodeTransform.h"
|
|
|
|
|
#include "../scene_graph/NodeShape.h"
|
|
|
|
|
#include "../system/FreestyleConfig.h"
|
|
|
|
|
#include "../system/RenderMonitor.h"
|
|
|
|
|
|
2008-08-07 15:04:25 +00:00
|
|
|
extern "C" {
|
2012-12-18 00:51:25 +00:00
|
|
|
#include "DNA_material_types.h"
|
|
|
|
|
#include "DNA_meshdata_types.h"
|
|
|
|
|
#include "DNA_scene_types.h"
|
|
|
|
|
|
|
|
|
|
#include "renderdatabase.h"
|
|
|
|
|
#include "render_types.h"
|
|
|
|
|
|
|
|
|
|
#include "BKE_mesh.h"
|
|
|
|
|
#include "BKE_scene.h"
|
|
|
|
|
|
|
|
|
|
#include "BLI_math.h"
|
2008-08-07 15:04:25 +00:00
|
|
|
}
|
|
|
|
|
|
2013-04-09 00:46:49 +00:00
|
|
|
namespace Freestyle {
|
2008-08-07 15:04:25 +00:00
|
|
|
|
|
|
|
|
class NodeGroup;
|
|
|
|
|
|
2010-01-24 23:12:57 +00:00
|
|
|
struct LoaderState {
|
|
|
|
|
float *pv;
|
|
|
|
|
float *pn;
|
2011-10-06 02:04:43 +00:00
|
|
|
IndexedFaceSet::FaceEdgeMark *pm;
|
2010-01-24 23:12:57 +00:00
|
|
|
unsigned *pvi;
|
|
|
|
|
unsigned *pni;
|
|
|
|
|
unsigned *pmi;
|
|
|
|
|
unsigned currentIndex;
|
|
|
|
|
unsigned currentMIndex;
|
|
|
|
|
float minBBox[3];
|
|
|
|
|
float maxBBox[3];
|
|
|
|
|
};
|
|
|
|
|
|
2008-08-07 15:04:25 +00:00
|
|
|
class LIB_SCENE_GRAPH_EXPORT BlenderFileLoader
|
|
|
|
|
{
|
|
|
|
|
public:
|
2012-12-18 00:51:25 +00:00
|
|
|
/*! Builds a MaxFileLoader */
|
2013-03-07 23:17:23 +00:00
|
|
|
BlenderFileLoader(Render *re, SceneRenderLayer *srl);
|
2012-12-18 00:51:25 +00:00
|
|
|
virtual ~BlenderFileLoader();
|
2008-08-07 15:04:25 +00:00
|
|
|
|
2012-12-18 00:51:25 +00:00
|
|
|
/*! Loads the 3D scene and returns a pointer to the scene root node */
|
|
|
|
|
NodeGroup * Load();
|
2008-08-07 15:04:25 +00:00
|
|
|
|
2012-12-18 00:51:25 +00:00
|
|
|
/*! Gets the number of read faces */
|
|
|
|
|
inline unsigned int numFacesRead() {return _numFacesRead;}
|
2008-08-07 15:04:25 +00:00
|
|
|
|
2012-12-18 00:51:25 +00:00
|
|
|
/*! Gets the smallest edge size read */
|
|
|
|
|
inline real minEdgeSize() {return _minEdgeSize;}
|
2008-08-07 15:04:25 +00:00
|
|
|
|
2012-12-18 00:51:25 +00:00
|
|
|
/*! Modifiers */
|
|
|
|
|
inline void setRenderMonitor(RenderMonitor *iRenderMonitor) {_pRenderMonitor = iRenderMonitor;}
|
2012-07-16 23:29:12 +00:00
|
|
|
|
2008-08-07 15:04:25 +00:00
|
|
|
protected:
|
2010-02-19 01:10:04 +00:00
|
|
|
void insertShapeNode(ObjectInstanceRen *obi, int id);
|
2012-03-05 19:01:12 +00:00
|
|
|
int testDegenerateTriangle(float v1[3], float v2[3], float v3[3]);
|
|
|
|
|
bool testEdgeRotation(float v1[3], float v2[3], float v3[3], float v4[3]);
|
2010-02-19 01:10:04 +00:00
|
|
|
int countClippedFaces(float v1[3], float v2[3], float v3[3], int clip[3]);
|
|
|
|
|
void clipLine(float v1[3], float v2[3], float c[3], float z);
|
2010-11-27 11:23:11 +00:00
|
|
|
void clipTriangle(int numTris, float triCoords[][3], float v1[3], float v2[3], float v3[3],
|
2012-12-18 00:51:25 +00:00
|
|
|
float triNormals[][3], float n1[3], float n2[3], float n3[3],
|
|
|
|
|
bool edgeMarks[5], bool em1, bool em2, bool em3, int clip[3]);
|
2010-11-27 11:23:11 +00:00
|
|
|
void addTriangle(struct LoaderState *ls, float v1[3], float v2[3], float v3[3],
|
2012-12-18 00:51:25 +00:00
|
|
|
float n1[3], float n2[3], float n3[3], bool fm, bool em1, bool em2, bool em3);
|
2008-08-07 15:04:25 +00:00
|
|
|
|
|
|
|
|
protected:
|
2012-03-05 19:01:12 +00:00
|
|
|
struct detri_t {
|
|
|
|
|
unsigned viA, viB, viP; // 0 <= viA, viB, viP < viSize
|
|
|
|
|
Vec3r v;
|
|
|
|
|
unsigned n;
|
|
|
|
|
};
|
2012-12-18 00:51:25 +00:00
|
|
|
Render *_re;
|
|
|
|
|
SceneRenderLayer *_srl;
|
|
|
|
|
NodeGroup *_Scene;
|
2010-01-10 14:08:59 +00:00
|
|
|
unsigned _numFacesRead;
|
|
|
|
|
real _minEdgeSize;
|
2010-11-27 11:23:11 +00:00
|
|
|
bool _smooth; /* if true, face smoothness is taken into account */
|
2010-01-10 14:08:59 +00:00
|
|
|
float _viewplane_left;
|
|
|
|
|
float _viewplane_right;
|
|
|
|
|
float _viewplane_bottom;
|
|
|
|
|
float _viewplane_top;
|
|
|
|
|
float _z_near, _z_far;
|
2012-07-16 23:29:12 +00:00
|
|
|
|
|
|
|
|
RenderMonitor *_pRenderMonitor;
|
2008-08-07 15:04:25 +00:00
|
|
|
};
|
|
|
|
|
|
2013-04-09 00:46:49 +00:00
|
|
|
} /* namespace Freestyle */
|
|
|
|
|
|
2012-12-18 00:51:25 +00:00
|
|
|
#endif // __BLENDER_FILE_LOADER_H__
|