2005-03-27 20:34:18 +00:00
|
|
|
/**
|
2005-03-28 08:17:51 +00:00
|
|
|
* $Id$
|
2005-03-27 20:34:18 +00:00
|
|
|
*
|
|
|
|
* ***** BEGIN GPL/BL DUAL 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. The Blender
|
|
|
|
* Foundation also sells licenses for use in proprietary software under
|
|
|
|
* the Blender License. See http://www.blender.org/BL/ for information
|
|
|
|
* about this.
|
|
|
|
*
|
|
|
|
* 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
|
|
*
|
|
|
|
* The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* The Original Code is: all of this file.
|
|
|
|
*
|
|
|
|
* Contributor(s): none yet.
|
|
|
|
*
|
|
|
|
* ***** END GPL/BL DUAL LICENSE BLOCK *****
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef BKE_DERIVEDMESH_H
|
|
|
|
#define BKE_DERIVEDMESH_H
|
|
|
|
|
2005-03-28 05:58:43 +00:00
|
|
|
/* TODO (Probably)
|
|
|
|
*
|
|
|
|
* o Make drawMapped* functions take a predicate function that
|
|
|
|
* determines whether to draw the edge (this predicate can
|
|
|
|
* also set color, etc). This will be slightly more general
|
|
|
|
* and allow some of the functions to be collapsed.
|
2005-03-28 08:17:51 +00:00
|
|
|
* o Once accessor functions are added then single element draw
|
|
|
|
* functions can be implemented using primitive accessors.
|
2005-03-28 21:53:26 +00:00
|
|
|
* o Add function to dispatch to renderer instead of using
|
|
|
|
* conversion to DLM.
|
2005-03-28 05:58:43 +00:00
|
|
|
*/
|
|
|
|
|
2005-03-27 20:34:18 +00:00
|
|
|
struct Object;
|
2005-03-29 16:43:39 +00:00
|
|
|
struct EditMesh;
|
2005-03-30 05:57:40 +00:00
|
|
|
struct EditVert;
|
|
|
|
struct EditEdge;
|
|
|
|
struct EditFace;
|
2005-03-27 20:34:18 +00:00
|
|
|
struct DispListMesh;
|
|
|
|
|
|
|
|
typedef struct DerivedMesh DerivedMesh;
|
|
|
|
struct DerivedMesh {
|
2005-03-27 21:27:12 +00:00
|
|
|
/* Misc. Queries */
|
|
|
|
|
|
|
|
int (*getNumVerts)(DerivedMesh *dm);
|
|
|
|
int (*getNumFaces)(DerivedMesh *dm);
|
|
|
|
|
2005-03-28 07:10:32 +00:00
|
|
|
void (*getMappedVertCoEM)(DerivedMesh *dm, void *vert, float co_r[3]);
|
|
|
|
|
2005-07-17 04:17:33 +00:00
|
|
|
/* Convert to new DispListMesh, should be free'd by caller */
|
2005-03-27 22:42:57 +00:00
|
|
|
struct DispListMesh* (*convertToDispListMesh)(DerivedMesh *dm);
|
|
|
|
|
2005-07-17 04:17:33 +00:00
|
|
|
/* Iterate over all vertex points, calling DO_MINMAX with given args */
|
|
|
|
void (*getMinMax)(DerivedMesh *dm, float min_r[3], float max_r[3]);
|
2005-07-17 01:18:59 +00:00
|
|
|
|
|
|
|
/* Direct Access Operations */
|
|
|
|
/* o Can be undefined */
|
|
|
|
/* o Must be defined for modifiers that only deform however */
|
|
|
|
|
|
|
|
/* Get vertex location, undefined if index is not valid */
|
|
|
|
void (*getVertCo)(DerivedMesh *dm, int index, float co_r[3]);
|
|
|
|
|
|
|
|
/* Get vertex normal, undefined if index is not valid */
|
|
|
|
void (*getVertNo)(DerivedMesh *dm, int index, float no_r[3]);
|
|
|
|
|
2005-03-27 20:34:18 +00:00
|
|
|
/* Drawing Operations */
|
|
|
|
|
|
|
|
/* Draw all vertices as bgl points (no options) */
|
|
|
|
void (*drawVerts)(DerivedMesh *dm);
|
|
|
|
|
|
|
|
/* Draw all edges as lines (no options) */
|
|
|
|
void (*drawEdges)(DerivedMesh *dm);
|
|
|
|
|
|
|
|
/* Draw mapped edges as lines (no options) */
|
|
|
|
void (*drawMappedEdges)(DerivedMesh *dm);
|
|
|
|
|
|
|
|
/* Draw all edges without faces as lines (no options) */
|
|
|
|
void (*drawLooseEdges)(DerivedMesh *dm);
|
|
|
|
|
|
|
|
|
|
|
|
/* Draw all faces
|
|
|
|
* o Set face normal or vertex normal based on inherited face flag
|
|
|
|
* o Use inherited face material index to call setMaterial
|
2005-07-13 20:16:35 +00:00
|
|
|
* o Only if setMaterial returns true
|
2005-03-27 20:34:18 +00:00
|
|
|
*/
|
2005-07-13 20:16:35 +00:00
|
|
|
void (*drawFacesSolid)(DerivedMesh *dm, int (*setMaterial)(int));
|
2005-03-27 20:34:18 +00:00
|
|
|
|
|
|
|
/* Draw all faces
|
|
|
|
* o If useTwoSided, draw front and back using col arrays
|
|
|
|
* o col1,col2 are arrays of length numFace*4 of 4 component colors
|
|
|
|
* in ABGR format, and should be passed as per-face vertex color.
|
|
|
|
*/
|
|
|
|
void (*drawFacesColored)(DerivedMesh *dm, int useTwoSided, unsigned char *col1, unsigned char *col2);
|
|
|
|
|
2005-03-29 07:51:00 +00:00
|
|
|
/* Draw all faces uses TFace
|
|
|
|
* o Drawing options too complicated to enumerate, look at code.
|
|
|
|
*/
|
|
|
|
void (*drawFacesTex)(DerivedMesh *dm, int (*setDrawParams)(TFace *tf, int matnr));
|
|
|
|
|
2005-03-27 20:34:18 +00:00
|
|
|
/* Draw mapped vertices as bgl points
|
2005-03-30 00:32:10 +00:00
|
|
|
* o Only if !setDrawOptions or setDrawOptions(userData, mapped-vert) returns true
|
2005-03-27 20:34:18 +00:00
|
|
|
*/
|
2005-03-30 05:57:40 +00:00
|
|
|
void (*drawMappedVertsEM)(DerivedMesh *dm, int (*setDrawOptions)(void *userData, struct EditVert *eve), void *userData);
|
2005-03-27 20:34:18 +00:00
|
|
|
|
2005-03-27 22:14:57 +00:00
|
|
|
/* Draw single mapped edge as lines (no options) */
|
|
|
|
void (*drawMappedEdgeEM)(DerivedMesh *dm, void *edge);
|
|
|
|
|
2005-03-27 20:34:18 +00:00
|
|
|
/* Draw mapped edges as lines
|
2005-03-30 00:32:10 +00:00
|
|
|
* o Only if !setDrawOptions or setDrawOptions(userData, mapped-edge) returns true
|
2005-03-27 20:34:18 +00:00
|
|
|
*/
|
2005-03-30 05:57:40 +00:00
|
|
|
void (*drawMappedEdgesEM)(DerivedMesh *dm, int (*setDrawOptions)(void *userData, struct EditEdge *eed), void *userData);
|
2005-03-27 20:34:18 +00:00
|
|
|
|
2005-03-30 00:32:10 +00:00
|
|
|
/* Draw mapped edges as lines with interpolation values
|
|
|
|
* o Only if !setDrawOptions or setDrawOptions(userData, mapped-edge, mapped-v0, mapped-v1, t) returns true
|
|
|
|
*
|
|
|
|
* NOTE: This routine is optional!
|
2005-03-28 06:46:21 +00:00
|
|
|
*/
|
2005-03-30 00:32:10 +00:00
|
|
|
void (*drawMappedEdgesInterpEM)(DerivedMesh *dm,
|
2005-03-30 05:57:40 +00:00
|
|
|
int (*setDrawOptions)(void *userData, struct EditEdge *eed),
|
|
|
|
void (*setDrawInterpOptions)(void *userData, struct EditEdge *eed, float t),
|
2005-03-30 00:32:10 +00:00
|
|
|
void *userData);
|
2005-03-28 06:46:21 +00:00
|
|
|
|
2005-03-30 00:32:10 +00:00
|
|
|
/* Draw all faces
|
|
|
|
* o Only if !setDrawOptions or setDrawOptions(userData, mapped-face) returns true
|
2005-03-28 06:46:21 +00:00
|
|
|
*/
|
2005-03-30 05:57:40 +00:00
|
|
|
void (*drawMappedFacesEM)(DerivedMesh *dm, int (*setDrawOptions)(void *userData, struct EditFace *efa), void *userData);
|
2005-03-28 06:46:21 +00:00
|
|
|
|
2005-03-27 20:34:18 +00:00
|
|
|
void (*release)(DerivedMesh *dm);
|
|
|
|
};
|
|
|
|
|
2005-03-29 16:43:39 +00:00
|
|
|
/* Internal function, just temporarily exposed */
|
2005-04-04 04:50:41 +00:00
|
|
|
DerivedMesh *derivedmesh_from_displistmesh(struct DispListMesh *dlm);
|
2005-03-29 16:43:39 +00:00
|
|
|
|
2005-03-27 20:34:18 +00:00
|
|
|
DerivedMesh *mesh_get_derived(struct Object *ob);
|
2005-07-16 21:20:44 +00:00
|
|
|
DerivedMesh *mesh_get_derived_final(struct Object *ob, int *needsFree_r);
|
2005-03-29 16:43:39 +00:00
|
|
|
DerivedMesh *mesh_get_derived_render(struct Object *ob, int *needsFree_r);
|
2005-07-17 01:18:59 +00:00
|
|
|
DerivedMesh *mesh_get_derived_deform(struct Object *ob, int *needsFree_r);
|
2005-03-29 16:43:39 +00:00
|
|
|
|
2005-04-04 04:50:41 +00:00
|
|
|
/* IMPORTANT: The functions below do not return "true" DerivedMesh
|
|
|
|
* objects, rather they are just proxies for the mesh or editmesh
|
|
|
|
* objects and are used to keep the drawing code consistent. They
|
|
|
|
* should not be used as general purpose objects (access the Mesh
|
|
|
|
* or EditMesh directly).
|
|
|
|
*/
|
|
|
|
|
2005-03-28 05:58:43 +00:00
|
|
|
/* Utility function, just chooses appropriate DerivedMesh based
|
2005-03-29 16:43:39 +00:00
|
|
|
* on mesh flags. Release result if *needsFree_r is true.
|
2005-03-28 05:58:43 +00:00
|
|
|
*/
|
2005-03-29 16:43:39 +00:00
|
|
|
DerivedMesh *mesh_get_cage_derived(struct Object *ob, int *needsFree_r);
|
2005-04-04 04:50:41 +00:00
|
|
|
DerivedMesh *mesh_get_base_derived(struct Object *ob);
|
2005-03-28 05:58:43 +00:00
|
|
|
|
2005-03-27 20:34:18 +00:00
|
|
|
#endif
|
|
|
|
|