| 
									
										
										
										
											2011-02-23 10:52:22 +00:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +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, | 
					
						
							| 
									
										
										
										
											2010-02-12 13:34:04 +00:00
										 |  |  |  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV. | 
					
						
							|  |  |  |  * All rights reserved. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Contributor(s): Blender Foundation, full recode and added functions | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * ***** END GPL LICENSE BLOCK ***** | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-27 20:29:51 +00:00
										 |  |  | /** \file blender/editors/space_view3d/drawobject.c
 | 
					
						
							|  |  |  |  *  \ingroup spview3d | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | #include <string.h>
 | 
					
						
							|  |  |  | #include <math.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "MEM_guardedalloc.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "DNA_camera_types.h"
 | 
					
						
							|  |  |  | #include "DNA_curve_types.h"
 | 
					
						
							|  |  |  | #include "DNA_constraint_types.h" // for drawing constraint
 | 
					
						
							|  |  |  | #include "DNA_lamp_types.h"
 | 
					
						
							|  |  |  | #include "DNA_lattice_types.h"
 | 
					
						
							|  |  |  | #include "DNA_material_types.h"
 | 
					
						
							| 
									
										
										
										
											2012-02-19 22:17:30 +00:00
										 |  |  | #include "DNA_mesh_types.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | #include "DNA_meshdata_types.h"
 | 
					
						
							|  |  |  | #include "DNA_meta_types.h"
 | 
					
						
							|  |  |  | #include "DNA_scene_types.h"
 | 
					
						
							| 
									
										
										
										
											2009-07-30 15:00:26 +00:00
										 |  |  | #include "DNA_smoke_types.h"
 | 
					
						
							| 
									
										
										
										
											2011-08-01 11:44:20 +00:00
										 |  |  | #include "DNA_speaker_types.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | #include "DNA_world_types.h"
 | 
					
						
							| 
									
										
										
										
											2011-05-09 16:31:54 +00:00
										 |  |  | #include "DNA_armature_types.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-09 04:06:48 +00:00
										 |  |  | #include "BLI_utildefines.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | #include "BLI_blenlib.h"
 | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | #include "BLI_math.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | #include "BLI_edgehash.h"
 | 
					
						
							|  |  |  | #include "BLI_rand.h"
 | 
					
						
							| 
									
										
										
										
											2011-01-07 18:36:47 +00:00
										 |  |  | #include "BLI_utildefines.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "BKE_anim.h"			//for the where_on_path function
 | 
					
						
							| 
									
										
										
										
											2011-11-05 13:00:39 +00:00
										 |  |  | #include "BKE_camera.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | #include "BKE_constraint.h" // for the get_constraint_target function
 | 
					
						
							| 
									
										
										
										
											2011-09-14 00:37:27 +00:00
										 |  |  | #include "BKE_curve.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | #include "BKE_DerivedMesh.h"
 | 
					
						
							|  |  |  | #include "BKE_deform.h"
 | 
					
						
							|  |  |  | #include "BKE_displist.h"
 | 
					
						
							|  |  |  | #include "BKE_font.h"
 | 
					
						
							|  |  |  | #include "BKE_global.h"
 | 
					
						
							|  |  |  | #include "BKE_image.h"
 | 
					
						
							|  |  |  | #include "BKE_key.h"
 | 
					
						
							|  |  |  | #include "BKE_lattice.h"
 | 
					
						
							|  |  |  | #include "BKE_mesh.h"
 | 
					
						
							|  |  |  | #include "BKE_material.h"
 | 
					
						
							|  |  |  | #include "BKE_mball.h"
 | 
					
						
							|  |  |  | #include "BKE_modifier.h"
 | 
					
						
							|  |  |  | #include "BKE_object.h"
 | 
					
						
							| 
									
										
										
										
											2009-08-15 19:48:50 +00:00
										 |  |  | #include "BKE_paint.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | #include "BKE_particle.h"
 | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | #include "BKE_pointcache.h"
 | 
					
						
							| 
									
										
										
										
											2011-11-06 06:08:18 +00:00
										 |  |  | #include "BKE_scene.h"
 | 
					
						
							| 
									
										
										
										
											2009-08-16 11:16:04 +00:00
										 |  |  | #include "BKE_unit.h"
 | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | #include "BKE_movieclip.h"
 | 
					
						
							|  |  |  | #include "BKE_tracking.h"
 | 
					
						
							| 
									
										
										
										
											2011-01-07 19:18:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | #include "BKE_tessmesh.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-30 15:00:26 +00:00
										 |  |  | #include "smoke_API.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-09 16:31:54 +00:00
										 |  |  | #include "IMB_imbuf.h"
 | 
					
						
							|  |  |  | #include "IMB_imbuf_types.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | #include "BIF_gl.h"
 | 
					
						
							|  |  |  | #include "BIF_glutil.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "GPU_draw.h"
 | 
					
						
							|  |  |  | #include "GPU_extensions.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-30 13:16:14 +00:00
										 |  |  | #include "ED_mesh.h"
 | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | #include "ED_particle.h"
 | 
					
						
							|  |  |  | #include "ED_screen.h"
 | 
					
						
							| 
									
										
										
										
											2009-10-27 19:53:34 +00:00
										 |  |  | #include "ED_sculpt.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | #include "ED_types.h"
 | 
					
						
							| 
									
										
										
										
											2011-09-14 00:37:27 +00:00
										 |  |  | #include "ED_curve.h" /* for curve_editnurbs */
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "UI_resources.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "WM_api.h"
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | #include "wm_subwindow.h"
 | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | #include "BLF_api.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "view3d_intern.h"	// own include
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | /* this condition has been made more complex since editmode can draw textures */ | 
					
						
							| 
									
										
										
										
											2011-11-05 05:44:52 +00:00
										 |  |  | #define CHECK_OB_DRAWTEXTURE(vd, dt)                                          \
 | 
					
						
							| 
									
										
										
										
											2011-11-08 13:07:16 +00:00
										 |  |  | 	((ELEM(vd->drawtype, OB_TEXTURE, OB_MATERIAL) && dt>OB_SOLID) ||          \ | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | 	(vd->drawtype==OB_SOLID && vd->flag2 & V3D_SOLID_TEX)) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-25 02:35:23 +00:00
										 |  |  | typedef enum eWireDrawMode { | 
					
						
							|  |  |  | 	OBDRAW_WIRE_OFF= 0, | 
					
						
							|  |  |  | 	OBDRAW_WIRE_ON= 1, | 
					
						
							|  |  |  | 	OBDRAW_WIRE_ON_DEPTH= 2 | 
					
						
							|  |  |  | } eWireDrawMode; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-20 08:47:36 +00:00
										 |  |  | /* user data structures for derived mesh callbacks */ | 
					
						
							|  |  |  | typedef struct foreachScreenVert_userData { | 
					
						
							| 
									
										
										
										
											2011-12-20 10:59:56 +00:00
										 |  |  | 	void (*func)(void *userData, BMVert *eve, int x, int y, int index); | 
					
						
							| 
									
										
										
										
											2011-12-20 08:47:36 +00:00
										 |  |  | 	void *userData; | 
					
						
							|  |  |  | 	ViewContext vc; | 
					
						
							|  |  |  | 	eV3DClipTest clipVerts; | 
					
						
							|  |  |  | } foreachScreenVert_userData; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct foreachScreenEdge_userData { | 
					
						
							| 
									
										
										
										
											2011-12-20 10:59:56 +00:00
										 |  |  | 	void (*func)(void *userData, BMEdge *eed, int x0, int y0, int x1, int y1, int index); | 
					
						
							| 
									
										
										
										
											2011-12-20 08:47:36 +00:00
										 |  |  | 	void *userData; | 
					
						
							|  |  |  | 	ViewContext vc; | 
					
						
							|  |  |  | 	eV3DClipTest clipVerts; | 
					
						
							|  |  |  | } foreachScreenEdge_userData; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct foreachScreenFace_userData { | 
					
						
							| 
									
										
										
										
											2011-12-20 10:59:56 +00:00
										 |  |  | 	void (*func)(void *userData, BMFace *efa, int x, int y, int index); | 
					
						
							| 
									
										
										
										
											2011-12-20 08:47:36 +00:00
										 |  |  | 	void *userData; | 
					
						
							|  |  |  | 	ViewContext vc; | 
					
						
							|  |  |  | } foreachScreenFace_userData; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct drawDMVerts_userData { | 
					
						
							| 
									
										
										
										
											2011-12-20 10:59:56 +00:00
										 |  |  | 	BMEditMesh *em; /* BMESH BRANCH ONLY */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-20 08:47:36 +00:00
										 |  |  | 	int sel; | 
					
						
							| 
									
										
										
										
											2011-12-20 10:59:56 +00:00
										 |  |  | 	BMVert *eve_act; | 
					
						
							| 
									
										
										
										
											2011-12-20 08:47:36 +00:00
										 |  |  | } drawDMVerts_userData; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct drawDMEdgesSel_userData { | 
					
						
							| 
									
										
										
										
											2011-12-20 10:59:56 +00:00
										 |  |  | 	BMEditMesh *em; /* BMESH BRANCH ONLY */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-20 08:47:36 +00:00
										 |  |  | 	unsigned char *baseCol, *selCol, *actCol; | 
					
						
							| 
									
										
										
										
											2011-12-20 10:59:56 +00:00
										 |  |  | 	BMEdge *eed_act; | 
					
						
							| 
									
										
										
										
											2011-12-20 08:47:36 +00:00
										 |  |  | } drawDMEdgesSel_userData; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct drawDMFacesSel_userData { | 
					
						
							|  |  |  | 	unsigned char *cols[3]; | 
					
						
							| 
									
										
										
										
											2011-12-20 10:59:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	DerivedMesh *dm; /* BMESH BRANCH ONLY */ | 
					
						
							|  |  |  | 	BMEditMesh *em;  /* BMESH BRANCH ONLY */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	BMFace *efa_act; | 
					
						
							| 
									
										
										
										
											2011-12-20 08:47:36 +00:00
										 |  |  | 	int *orig_index; | 
					
						
							|  |  |  | } drawDMFacesSel_userData; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-24 19:57:34 +00:00
										 |  |  | typedef struct drawDMNormal_userData { | 
					
						
							| 
									
										
										
										
											2012-01-24 20:19:09 +00:00
										 |  |  | 	BMEditMesh *em; | 
					
						
							| 
									
										
										
										
											2012-01-24 19:57:34 +00:00
										 |  |  | 	float normalsize; | 
					
						
							|  |  |  | } drawDMNormal_userData; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-20 08:47:36 +00:00
										 |  |  | typedef struct bbsObmodeMeshVerts_userData { | 
					
						
							|  |  |  | 	void *offset; | 
					
						
							|  |  |  | 	MVert *mvert; | 
					
						
							|  |  |  | } bbsObmodeMeshVerts_userData; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-05 02:30:25 +00:00
										 |  |  | static void draw_bounding_volume(Scene *scene, Object *ob, char type); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static void drawcube_size(float size); | 
					
						
							|  |  |  | static void drawcircle_size(float size); | 
					
						
							|  |  |  | static void draw_empty_sphere(float size); | 
					
						
							|  |  |  | static void draw_empty_cone(float size); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-05-08 17:54:29 +00:00
										 |  |  | static int check_ob_drawface_dot(Scene *sce, View3D *vd, char dt) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if((sce->toolsettings->selectmode & SCE_SELECT_FACE) == 0) | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(G.f & G_BACKBUFSEL) | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if((vd->flag & V3D_ZBUF_SELECT) == 0) | 
					
						
							|  |  |  | 		return 1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* if its drawing textures with zbuf sel, then dont draw dots */ | 
					
						
							|  |  |  | 	if(dt==OB_TEXTURE && vd->drawtype==OB_TEXTURE) | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(vd->drawtype>=OB_SOLID && vd->flag2 & V3D_SOLID_TEX) | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return 1; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | /* ************* only use while object drawing **************
 | 
					
						
							|  |  |  |  * or after running ED_view3d_init_mats_rv3d | 
					
						
							|  |  |  |  * */ | 
					
						
							| 
									
										
										
										
											2011-11-28 16:44:17 +00:00
										 |  |  | static void view3d_project_short_clip(ARegion *ar, const float vec[3], short adr[2], int local) | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	RegionView3D *rv3d= ar->regiondata; | 
					
						
							|  |  |  | 	float fx, fy, vec4[4]; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	adr[0]= IS_CLIPPED; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* clipplanes in eye space */ | 
					
						
							|  |  |  | 	if(rv3d->rflag & RV3D_CLIPPING) { | 
					
						
							| 
									
										
										
										
											2011-05-21 08:56:37 +00:00
										 |  |  | 		if(ED_view3d_test_clipping(rv3d, vec, local)) | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 			return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 	copy_v3_v3(vec4, vec); | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 	vec4[3]= 1.0; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 	mul_m4_v4(rv3d->persmatob, vec4); | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* clipplanes in window space */ | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 	if( vec4[3] > (float)BL_NEAR_CLIP ) {	/* is the NEAR clipping cutoff for picking */ | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 		fx= (ar->winx/2)*(1 + vec4[0]/vec4[3]); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		if( fx>0 && fx<ar->winx) { | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			fy= (ar->winy/2)*(1 + vec4[1]/vec4[3]); | 
					
						
							|  |  |  | 			 | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 			if(fy > 0.0f && fy < (float)ar->winy) { | 
					
						
							|  |  |  | 				adr[0]= (short)floorf(fx); | 
					
						
							|  |  |  | 				adr[1]= (short)floorf(fy); | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-23 16:46:35 +00:00
										 |  |  | /* BMESH NOTE: this function is unused in bmesh only */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | /* only use while object drawing */ | 
					
						
							| 
									
										
										
										
											2012-01-23 16:46:35 +00:00
										 |  |  | static void UNUSED_FUNCTION(view3d_project_short_noclip)(ARegion *ar, const float vec[3], short adr[2]) | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	RegionView3D *rv3d= ar->regiondata; | 
					
						
							|  |  |  | 	float fx, fy, vec4[4]; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	adr[0]= IS_CLIPPED; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 	copy_v3_v3(vec4, vec); | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 	vec4[3]= 1.0; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 	mul_m4_v4(rv3d->persmatob, vec4); | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 	if( vec4[3] > (float)BL_NEAR_CLIP ) {	/* is the NEAR clipping cutoff for picking */ | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 		fx= (ar->winx/2)*(1 + vec4[0]/vec4[3]); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		if( fx>-32700 && fx<32700) { | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			fy= (ar->winy/2)*(1 + vec4[1]/vec4[3]); | 
					
						
							|  |  |  | 			 | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 			if(fy > -32700.0f && fy < 32700.0f) { | 
					
						
							|  |  |  | 				adr[0]= (short)floorf(fx); | 
					
						
							|  |  |  | 				adr[1]= (short)floorf(fy); | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | /* same as view3d_project_short_clip but use persmat instead of persmatob for projection */ | 
					
						
							| 
									
										
										
										
											2011-11-28 16:44:17 +00:00
										 |  |  | static void view3d_project_short_clip_persmat(ARegion *ar, float *vec, short adr[2], int local) | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	RegionView3D *rv3d= ar->regiondata; | 
					
						
							|  |  |  | 	float fx, fy, vec4[4]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	adr[0]= IS_CLIPPED; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* clipplanes in eye space */ | 
					
						
							|  |  |  | 	if(rv3d->rflag & RV3D_CLIPPING) { | 
					
						
							|  |  |  | 		if(ED_view3d_test_clipping(rv3d, vec, local)) | 
					
						
							|  |  |  | 			return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copy_v3_v3(vec4, vec); | 
					
						
							|  |  |  | 	vec4[3]= 1.0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	mul_m4_v4(rv3d->persmat, vec4); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* clipplanes in window space */ | 
					
						
							|  |  |  | 	if( vec4[3] > (float)BL_NEAR_CLIP ) {	/* is the NEAR clipping cutoff for picking */ | 
					
						
							|  |  |  | 		fx= (ar->winx/2)*(1 + vec4[0]/vec4[3]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if( fx>0 && fx<ar->winx) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			fy= (ar->winy/2)*(1 + vec4[1]/vec4[3]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			if(fy > 0.0f && fy < (float)ar->winy) { | 
					
						
							|  |  |  | 				adr[0]= (short)floorf(fx); | 
					
						
							|  |  |  | 				adr[1]= (short)floorf(fy); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | /* ************************ */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | /* check for glsl drawing */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int draw_glsl_material(Scene *scene, Object *ob, View3D *v3d, int dt) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-11-01 00:06:53 +00:00
										 |  |  | 	if(!GPU_glsl_support()) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		return 0; | 
					
						
							|  |  |  | 	if(G.f & G_PICKSEL) | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 	if(!CHECK_OB_DRAWTEXTURE(v3d, dt)) | 
					
						
							|  |  |  | 		return 0; | 
					
						
							| 
									
										
										
										
											2009-08-15 21:46:25 +00:00
										 |  |  | 	if(ob==OBACT && (ob && ob->mode & OB_MODE_WEIGHT_PAINT)) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		return 0; | 
					
						
							| 
									
										
										
										
											2011-11-08 13:07:16 +00:00
										 |  |  | 	if(scene_use_new_shading_nodes(scene)) | 
					
						
							|  |  |  | 		return 0; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2011-06-15 10:17:06 +00:00
										 |  |  | 	return (scene->gm.matmode == GAME_MAT_GLSL) && (dt > OB_SOLID); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-07 22:03:49 +00:00
										 |  |  | static int check_alpha_pass(Base *base) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	if(base->flag & OB_FROMDUPLI) | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(G.f & G_PICKSEL) | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2011-12-07 22:03:49 +00:00
										 |  |  | 	return (base->object->dtx & OB_DRAWTRANSP); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/***/ | 
					
						
							|  |  |  | static unsigned int colortab[24]= | 
					
						
							|  |  |  | 	{0x0,		0xFF88FF, 0xFFBBFF,  | 
					
						
							|  |  |  | 	 0x403000,	0xFFFF88, 0xFFFFBB,  | 
					
						
							|  |  |  | 	 0x104040,	0x66CCCC, 0x77CCCC,  | 
					
						
							|  |  |  | 	 0x104010,	0x55BB55, 0x66FF66,  | 
					
						
							|  |  |  | 	 0xFFFFFF | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static float cube[8][3] = { | 
					
						
							|  |  |  | 	{-1.0, -1.0, -1.0}, | 
					
						
							|  |  |  | 	{-1.0, -1.0,  1.0}, | 
					
						
							|  |  |  | 	{-1.0,  1.0,  1.0}, | 
					
						
							|  |  |  | 	{-1.0,  1.0, -1.0}, | 
					
						
							|  |  |  | 	{ 1.0, -1.0, -1.0}, | 
					
						
							|  |  |  | 	{ 1.0, -1.0,  1.0}, | 
					
						
							|  |  |  | 	{ 1.0,  1.0,  1.0}, | 
					
						
							|  |  |  | 	{ 1.0,  1.0, -1.0}, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ----------------- OpenGL Circle Drawing - Tables for Optimised Drawing Speed ------------------ */ | 
					
						
							|  |  |  | /* 32 values of sin function (still same result!) */ | 
					
						
							| 
									
										
										
										
											2011-09-17 05:35:55 +00:00
										 |  |  | #define CIRCLE_RESOL 32
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-17 06:18:35 +00:00
										 |  |  | static const float sinval[CIRCLE_RESOL] = { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	0.00000000, | 
					
						
							|  |  |  | 	0.20129852, | 
					
						
							|  |  |  | 	0.39435585, | 
					
						
							|  |  |  | 	0.57126821, | 
					
						
							|  |  |  | 	0.72479278, | 
					
						
							|  |  |  | 	0.84864425, | 
					
						
							|  |  |  | 	0.93775213, | 
					
						
							|  |  |  | 	0.98846832, | 
					
						
							|  |  |  | 	0.99871650, | 
					
						
							|  |  |  | 	0.96807711, | 
					
						
							|  |  |  | 	0.89780453, | 
					
						
							|  |  |  | 	0.79077573, | 
					
						
							|  |  |  | 	0.65137248, | 
					
						
							|  |  |  | 	0.48530196, | 
					
						
							|  |  |  | 	0.29936312, | 
					
						
							|  |  |  | 	0.10116832, | 
					
						
							|  |  |  | 	-0.10116832, | 
					
						
							|  |  |  | 	-0.29936312, | 
					
						
							|  |  |  | 	-0.48530196, | 
					
						
							|  |  |  | 	-0.65137248, | 
					
						
							|  |  |  | 	-0.79077573, | 
					
						
							|  |  |  | 	-0.89780453, | 
					
						
							|  |  |  | 	-0.96807711, | 
					
						
							|  |  |  | 	-0.99871650, | 
					
						
							|  |  |  | 	-0.98846832, | 
					
						
							|  |  |  | 	-0.93775213, | 
					
						
							|  |  |  | 	-0.84864425, | 
					
						
							|  |  |  | 	-0.72479278, | 
					
						
							|  |  |  | 	-0.57126821, | 
					
						
							|  |  |  | 	-0.39435585, | 
					
						
							|  |  |  | 	-0.20129852, | 
					
						
							|  |  |  | 	0.00000000 | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* 32 values of cos function (still same result!) */ | 
					
						
							| 
									
										
										
										
											2011-09-17 06:18:35 +00:00
										 |  |  | static const float cosval[CIRCLE_RESOL] = { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	1.00000000, | 
					
						
							|  |  |  | 	0.97952994, | 
					
						
							|  |  |  | 	0.91895781, | 
					
						
							|  |  |  | 	0.82076344, | 
					
						
							|  |  |  | 	0.68896691, | 
					
						
							|  |  |  | 	0.52896401, | 
					
						
							|  |  |  | 	0.34730525, | 
					
						
							|  |  |  | 	0.15142777, | 
					
						
							|  |  |  | 	-0.05064916, | 
					
						
							|  |  |  | 	-0.25065253, | 
					
						
							|  |  |  | 	-0.44039415, | 
					
						
							|  |  |  | 	-0.61210598, | 
					
						
							|  |  |  | 	-0.75875812, | 
					
						
							|  |  |  | 	-0.87434661, | 
					
						
							|  |  |  | 	-0.95413925, | 
					
						
							|  |  |  | 	-0.99486932, | 
					
						
							|  |  |  | 	-0.99486932, | 
					
						
							|  |  |  | 	-0.95413925, | 
					
						
							|  |  |  | 	-0.87434661, | 
					
						
							|  |  |  | 	-0.75875812, | 
					
						
							|  |  |  | 	-0.61210598, | 
					
						
							|  |  |  | 	-0.44039415, | 
					
						
							|  |  |  | 	-0.25065253, | 
					
						
							|  |  |  | 	-0.05064916, | 
					
						
							|  |  |  | 	0.15142777, | 
					
						
							|  |  |  | 	0.34730525, | 
					
						
							|  |  |  | 	0.52896401, | 
					
						
							|  |  |  | 	0.68896691, | 
					
						
							|  |  |  | 	0.82076344, | 
					
						
							|  |  |  | 	0.91895781, | 
					
						
							|  |  |  | 	0.97952994, | 
					
						
							|  |  |  | 	1.00000000 | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-03 23:55:10 +00:00
										 |  |  | static void draw_xyz_wire(const float c[3], float size, int axis) | 
					
						
							| 
									
										
										
										
											2010-04-02 05:05:49 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	float v1[3]= {0.f, 0.f, 0.f}, v2[3] = {0.f, 0.f, 0.f}; | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 	float dim = size * 0.1f; | 
					
						
							| 
									
										
										
										
											2010-11-03 06:31:53 +00:00
										 |  |  | 	float dx[3], dy[3], dz[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	dx[0]=dim; dx[1]=0.f; dx[2]=0.f; | 
					
						
							|  |  |  | 	dy[0]=0.f; dy[1]=dim; dy[2]=0.f; | 
					
						
							|  |  |  | 	dz[0]=0.f; dz[1]=0.f; dz[2]=dim; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-02 05:05:49 +00:00
										 |  |  | 	switch(axis) { | 
					
						
							|  |  |  | 		case 0:		/* x axis */ | 
					
						
							|  |  |  | 			glBegin(GL_LINES); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* bottom left to top right */ | 
					
						
							|  |  |  | 			sub_v3_v3v3(v1, c, dx); | 
					
						
							|  |  |  | 			sub_v3_v3(v1, dy); | 
					
						
							|  |  |  | 			add_v3_v3v3(v2, c, dx); | 
					
						
							|  |  |  | 			add_v3_v3(v2, dy); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			glVertex3fv(v1); | 
					
						
							|  |  |  | 			glVertex3fv(v2); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* top left to bottom right */ | 
					
						
							|  |  |  | 			mul_v3_fl(dy, 2.f); | 
					
						
							|  |  |  | 			add_v3_v3(v1, dy); | 
					
						
							|  |  |  | 			sub_v3_v3(v2, dy); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			glVertex3fv(v1); | 
					
						
							|  |  |  | 			glVertex3fv(v2); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			glEnd(); | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case 1:		/* y axis */ | 
					
						
							|  |  |  | 			glBegin(GL_LINES); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* bottom left to top right */ | 
					
						
							|  |  |  | 			mul_v3_fl(dx, 0.75f); | 
					
						
							|  |  |  | 			sub_v3_v3v3(v1, c, dx); | 
					
						
							|  |  |  | 			sub_v3_v3(v1, dy); | 
					
						
							|  |  |  | 			add_v3_v3v3(v2, c, dx); | 
					
						
							|  |  |  | 			add_v3_v3(v2, dy); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			glVertex3fv(v1); | 
					
						
							|  |  |  | 			glVertex3fv(v2); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* top left to center */ | 
					
						
							|  |  |  | 			mul_v3_fl(dy, 2.f); | 
					
						
							|  |  |  | 			add_v3_v3(v1, dy); | 
					
						
							|  |  |  | 			copy_v3_v3(v2, c); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			glVertex3fv(v1); | 
					
						
							|  |  |  | 			glVertex3fv(v2); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			glEnd(); | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case 2:		/* z axis */ | 
					
						
							|  |  |  | 			glBegin(GL_LINE_STRIP); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* start at top left */ | 
					
						
							|  |  |  | 			sub_v3_v3v3(v1, c, dx); | 
					
						
							| 
									
										
										
										
											2010-07-28 08:05:39 +00:00
										 |  |  | 			add_v3_v3v3(v1, c, dz); | 
					
						
							| 
									
										
										
										
											2010-04-02 05:05:49 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			glVertex3fv(v1); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			mul_v3_fl(dx, 2.f); | 
					
						
							|  |  |  | 			add_v3_v3(v1, dx); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			glVertex3fv(v1); | 
					
						
							|  |  |  | 			 | 
					
						
							| 
									
										
										
										
											2010-07-28 08:05:39 +00:00
										 |  |  | 			mul_v3_fl(dz, 2.f); | 
					
						
							| 
									
										
										
										
											2010-04-02 05:05:49 +00:00
										 |  |  | 			sub_v3_v3(v1, dx); | 
					
						
							| 
									
										
										
										
											2010-07-28 08:05:39 +00:00
										 |  |  | 			sub_v3_v3(v1, dz); | 
					
						
							| 
									
										
										
										
											2010-04-02 05:05:49 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			glVertex3fv(v1); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			add_v3_v3(v1, dx); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 			glVertex3fv(v1); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			glEnd(); | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-14 01:22:14 +00:00
										 |  |  | void drawaxes(float size, char drawtype) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int axis; | 
					
						
							|  |  |  | 	float v1[3]= {0.0, 0.0, 0.0}; | 
					
						
							|  |  |  | 	float v2[3]= {0.0, 0.0, 0.0}; | 
					
						
							|  |  |  | 	float v3[3]= {0.0, 0.0, 0.0}; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	switch(drawtype) { | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	case OB_PLAINAXES: | 
					
						
							|  |  |  | 		for (axis=0; axis<3; axis++) { | 
					
						
							|  |  |  | 			glBegin(GL_LINES); | 
					
						
							| 
									
										
										
										
											2010-03-01 09:42:39 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			v1[axis]= size; | 
					
						
							|  |  |  | 			v2[axis]= -size; | 
					
						
							|  |  |  | 			glVertex3fv(v1); | 
					
						
							|  |  |  | 			glVertex3fv(v2); | 
					
						
							| 
									
										
										
										
											2010-12-03 23:55:10 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			/* reset v1 & v2 to zero */ | 
					
						
							|  |  |  | 			v1[axis]= v2[axis]= 0.0f; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			glEnd(); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		break; | 
					
						
							|  |  |  | 	case OB_SINGLE_ARROW: | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 		glBegin(GL_LINES); | 
					
						
							|  |  |  | 		/* in positive z direction only */ | 
					
						
							|  |  |  | 		v1[2]= size; | 
					
						
							|  |  |  | 		glVertex3fv(v1); | 
					
						
							|  |  |  | 		glVertex3fv(v2); | 
					
						
							|  |  |  | 		glEnd(); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* square pyramid */ | 
					
						
							|  |  |  | 		glBegin(GL_TRIANGLES); | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 		v2[0]= size * 0.035f; v2[1] = size * 0.035f; | 
					
						
							|  |  |  | 		v3[0]= size * -0.035f; v3[1] = size * 0.035f; | 
					
						
							|  |  |  | 		v2[2]= v3[2]= size * 0.75f; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		for (axis=0; axis<4; axis++) { | 
					
						
							|  |  |  | 			if (axis % 2 == 1) { | 
					
						
							| 
									
										
										
										
											2010-07-31 10:58:10 +00:00
										 |  |  | 				v2[0] = -v2[0]; | 
					
						
							|  |  |  | 				v3[1] = -v3[1]; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			} else { | 
					
						
							| 
									
										
										
										
											2010-07-31 10:58:10 +00:00
										 |  |  | 				v2[1] = -v2[1]; | 
					
						
							|  |  |  | 				v3[0] = -v3[0]; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			glVertex3fv(v1); | 
					
						
							|  |  |  | 			glVertex3fv(v2); | 
					
						
							|  |  |  | 			glVertex3fv(v3); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		glEnd(); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		break; | 
					
						
							|  |  |  | 	case OB_CUBE: | 
					
						
							|  |  |  | 		drawcube_size(size); | 
					
						
							|  |  |  | 		break; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 	case OB_CIRCLE: | 
					
						
							|  |  |  | 		drawcircle_size(size); | 
					
						
							|  |  |  | 		break; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	case OB_EMPTY_SPHERE: | 
					
						
							| 
									
										
										
										
											2009-12-26 20:23:13 +00:00
										 |  |  | 		draw_empty_sphere(size); | 
					
						
							|  |  |  | 		break; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	case OB_EMPTY_CONE: | 
					
						
							| 
									
										
										
										
											2009-12-26 20:23:13 +00:00
										 |  |  | 		draw_empty_cone(size); | 
					
						
							|  |  |  | 		break; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	case OB_ARROWS: | 
					
						
							|  |  |  | 	default: | 
					
						
							|  |  |  | 		for (axis=0; axis<3; axis++) { | 
					
						
							| 
									
										
										
										
											2010-12-03 23:55:10 +00:00
										 |  |  | 			const int arrow_axis= (axis==0) ? 1:0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			glBegin(GL_LINES); | 
					
						
							| 
									
										
										
										
											2010-03-01 09:42:39 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			v2[axis]= size; | 
					
						
							|  |  |  | 			glVertex3fv(v1); | 
					
						
							|  |  |  | 			glVertex3fv(v2); | 
					
						
							|  |  |  | 				 | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 			v1[axis]= size*0.85f; | 
					
						
							|  |  |  | 			v1[arrow_axis]= -size*0.08f; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			glVertex3fv(v1); | 
					
						
							|  |  |  | 			glVertex3fv(v2); | 
					
						
							|  |  |  | 				 | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 			v1[arrow_axis]= size*0.08f; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			glVertex3fv(v1); | 
					
						
							|  |  |  | 			glVertex3fv(v2); | 
					
						
							| 
									
										
										
										
											2010-03-01 09:42:39 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			glEnd(); | 
					
						
							|  |  |  | 				 | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 			v2[axis]+= size*0.125f; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2010-07-28 08:05:39 +00:00
										 |  |  | 			draw_xyz_wire(v2, size, axis); | 
					
						
							| 
									
										
										
										
											2010-12-03 23:55:10 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* reset v1 & v2 to zero */ | 
					
						
							|  |  |  | 			v1[arrow_axis]= v1[axis]= v2[axis]= 0.0f; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		break; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-09 16:31:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* Function to draw an Image on a empty Object */ | 
					
						
							|  |  |  | static void draw_empty_image(Object *ob) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	Image *ima = (Image*)ob->data; | 
					
						
							|  |  |  | 	ImBuf *ibuf = ima ? BKE_image_get_ibuf(ima, NULL) : NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	float scale, ofs_x, ofs_y, sca_x, sca_y; | 
					
						
							|  |  |  | 	int ima_x, ima_y; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(ibuf && (ibuf->rect == NULL) && (ibuf->rect_float != NULL)) { | 
					
						
							|  |  |  | 		IMB_rect_from_float(ibuf); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Get the buffer dimensions so we can fallback to fake ones */ | 
					
						
							|  |  |  | 	if(ibuf && ibuf->rect) { | 
					
						
							|  |  |  | 		ima_x= ibuf->x; | 
					
						
							|  |  |  | 		ima_y= ibuf->y; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		ima_x= 1; | 
					
						
							|  |  |  | 		ima_y= 1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Get the image aspect even if the buffer is invalid */ | 
					
						
							|  |  |  | 	if(ima) { | 
					
						
							|  |  |  | 		if(ima->aspx > ima->aspy) { | 
					
						
							|  |  |  | 			sca_x= 1.0f; | 
					
						
							|  |  |  | 			sca_y= ima->aspy / ima->aspx; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else if(ima->aspx < ima->aspy) { | 
					
						
							|  |  |  | 			sca_x= ima->aspx / ima->aspy; | 
					
						
							|  |  |  | 			sca_y= 1.0f; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							|  |  |  | 			sca_x= 1.0f; | 
					
						
							|  |  |  | 			sca_y= 1.0f; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		sca_x= 1.0f; | 
					
						
							|  |  |  | 		sca_y= 1.0f; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Calculate the scale center based on objects origin */ | 
					
						
							|  |  |  | 	ofs_x= ob->ima_ofs[0] * ima_x; | 
					
						
							|  |  |  | 	ofs_y= ob->ima_ofs[1] * ima_y; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glMatrixMode(GL_MODELVIEW); | 
					
						
							|  |  |  | 	glPushMatrix(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Make sure we are drawing at the origin */ | 
					
						
							|  |  |  | 	glTranslatef(0.0f,  0.0f,  0.0f); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Calculate Image scale */ | 
					
						
							|  |  |  | 	scale= (ob->empty_drawsize / (float)MAX2(ima_x * sca_x, ima_y * sca_y)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Set the object scale */ | 
					
						
							|  |  |  | 	glScalef(scale * sca_x, scale * sca_y, 1.0f); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(ibuf && ibuf->rect) { | 
					
						
							|  |  |  | 		/* Setup GL params */ | 
					
						
							|  |  |  | 		glEnable(GL_BLEND); | 
					
						
							|  |  |  | 		glBlendFunc(GL_SRC_ALPHA,  GL_ONE_MINUS_SRC_ALPHA); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* Use the object color and alpha */ | 
					
						
							|  |  |  | 		glColor4fv(ob->col); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* Draw the Image on the screen */ | 
					
						
							|  |  |  | 		glaDrawPixelsTex(ofs_x, ofs_y, ima_x, ima_y, GL_UNSIGNED_BYTE, ibuf->rect); | 
					
						
							|  |  |  | 		glPixelTransferf(GL_ALPHA_SCALE, 1.0f); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		glDisable(GL_BLEND); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	UI_ThemeColor((ob->flag & SELECT) ? TH_SELECT : TH_WIRE); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Calculate the outline vertex positions */ | 
					
						
							|  |  |  | 	glBegin(GL_LINE_LOOP); | 
					
						
							|  |  |  | 	glVertex2f(ofs_x, ofs_y); | 
					
						
							|  |  |  | 	glVertex2f(ofs_x + ima_x, ofs_y); | 
					
						
							|  |  |  | 	glVertex2f(ofs_x + ima_x, ofs_y + ima_y); | 
					
						
							|  |  |  | 	glVertex2f(ofs_x, ofs_y + ima_y); | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Reset GL settings */ | 
					
						
							|  |  |  | 	glMatrixMode(GL_MODELVIEW); | 
					
						
							|  |  |  | 	glPopMatrix(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-17 06:18:35 +00:00
										 |  |  | static void circball_array_fill(float verts[CIRCLE_RESOL][3], const float cent[3], float rad, float tmat[][4]) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-09-17 06:18:35 +00:00
										 |  |  | 	float vx[3], vy[3]; | 
					
						
							|  |  |  | 	float *viter= (float *)verts; | 
					
						
							|  |  |  | 	unsigned int a; | 
					
						
							| 
									
										
										
										
											2010-07-31 10:58:10 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	mul_v3_v3fl(vx, tmat[0], rad); | 
					
						
							|  |  |  | 	mul_v3_v3fl(vy, tmat[1], rad); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-17 06:18:35 +00:00
										 |  |  | 	for (a=0; a < CIRCLE_RESOL; a++, viter += 3) { | 
					
						
							|  |  |  | 		viter[0]= cent[0] + sinval[a] * vx[0] + cosval[a] * vy[0]; | 
					
						
							|  |  |  | 		viter[1]= cent[1] + sinval[a] * vx[1] + cosval[a] * vy[1]; | 
					
						
							|  |  |  | 		viter[2]= cent[2] + sinval[a] * vx[2] + cosval[a] * vy[2]; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-09-17 06:18:35 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void drawcircball(int mode, const float cent[3], float rad, float tmat[][4]) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	float verts[CIRCLE_RESOL][3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	circball_array_fill(verts, cent, rad, tmat); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glEnableClientState(GL_VERTEX_ARRAY); | 
					
						
							|  |  |  | 	glVertexPointer(3, GL_FLOAT, 0, verts); | 
					
						
							|  |  |  | 	glDrawArrays(mode, 0, CIRCLE_RESOL); | 
					
						
							|  |  |  | 	glDisableClientState(GL_VERTEX_ARRAY); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* circle for object centers, special_color is for library or ob users */ | 
					
						
							| 
									
										
										
										
											2010-12-03 23:55:10 +00:00
										 |  |  | static void drawcentercircle(View3D *v3d, RegionView3D *rv3d, const float co[3], int selstate, int special_color) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-05-21 08:56:37 +00:00
										 |  |  | 	const float size= ED_view3d_pixel_size(rv3d, co) * (float)U.obcenter_dia * 0.5f; | 
					
						
							| 
									
										
										
										
											2011-09-17 06:18:35 +00:00
										 |  |  | 	float verts[CIRCLE_RESOL][3]; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-03 20:49:41 +00:00
										 |  |  | 	/* using gldepthfunc guarantees that it does write z values,
 | 
					
						
							|  |  |  | 	 * but not checks for it, so centers remain visible independt order of drawing */ | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	if(v3d->zbuf)  glDepthFunc(GL_ALWAYS); | 
					
						
							|  |  |  | 	glEnable(GL_BLEND); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if(special_color) { | 
					
						
							|  |  |  | 		if (selstate==ACTIVE || selstate==SELECT) glColor4ub(0x88, 0xFF, 0xFF, 155); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		else glColor4ub(0x55, 0xCC, 0xCC, 155); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		if (selstate == ACTIVE) UI_ThemeColorShadeAlpha(TH_ACTIVE, 0, -80); | 
					
						
							|  |  |  | 		else if (selstate == SELECT) UI_ThemeColorShadeAlpha(TH_SELECT, 0, -80); | 
					
						
							|  |  |  | 		else if (selstate == DESELECT) UI_ThemeColorShadeAlpha(TH_TRANSFORM, 0, -80); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-09-17 06:18:35 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	circball_array_fill(verts, co, size, rv3d->viewinv); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* enable vertex array */ | 
					
						
							|  |  |  | 	glEnableClientState(GL_VERTEX_ARRAY); | 
					
						
							|  |  |  | 	glVertexPointer(3, GL_FLOAT, 0, verts); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* 1. draw filled, blended polygon */ | 
					
						
							|  |  |  | 	glDrawArrays(GL_POLYGON, 0, CIRCLE_RESOL); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* 2. draw outline */ | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	UI_ThemeColorShadeAlpha(TH_WIRE, 0, -30); | 
					
						
							| 
									
										
										
										
											2011-09-17 06:18:35 +00:00
										 |  |  | 	glDrawArrays(GL_LINE_LOOP, 0, CIRCLE_RESOL); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* finishe up */ | 
					
						
							|  |  |  | 	glDisableClientState(GL_VERTEX_ARRAY); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	glDisable(GL_BLEND); | 
					
						
							| 
									
										
										
										
											2011-09-17 06:18:35 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	if(v3d->zbuf)  glDepthFunc(GL_LEQUAL); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | /* *********** text drawing for object/particles/armature ************* */ | 
					
						
							|  |  |  | static ListBase CachedText[3]; | 
					
						
							|  |  |  | static int CachedTextLevel= 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct ViewCachedString { | 
					
						
							|  |  |  | 	struct ViewCachedString *next, *prev; | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 	float vec[3]; | 
					
						
							|  |  |  | 	union { | 
					
						
							|  |  |  | 		unsigned char ub[4]; | 
					
						
							|  |  |  | 		int pack; | 
					
						
							|  |  |  | 	} col; | 
					
						
							| 
									
										
										
										
											2011-05-12 16:47:36 +00:00
										 |  |  | 	short sco[2]; | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 	short xoffs; | 
					
						
							| 
									
										
										
										
											2010-02-19 20:09:42 +00:00
										 |  |  | 	short flag; | 
					
						
							| 
									
										
										
										
											2011-03-10 12:52:18 +00:00
										 |  |  | 	int str_len, pad; | 
					
						
							| 
									
										
										
										
											2010-10-30 23:02:38 +00:00
										 |  |  | 	/* str is allocated past the end */ | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | } ViewCachedString; | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | void view3d_cached_text_draw_begin(void) | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	ListBase *strings= &CachedText[CachedTextLevel]; | 
					
						
							|  |  |  | 	strings->first= strings->last= NULL; | 
					
						
							|  |  |  | 	CachedTextLevel++; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-03 20:49:41 +00:00
										 |  |  | void view3d_cached_text_draw_add(const float co[3], | 
					
						
							|  |  |  |                                  const char *str, | 
					
						
							|  |  |  |                                  short xoffs, short flag, | 
					
						
							|  |  |  |                                  const unsigned char col[4]) | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2010-10-30 23:02:38 +00:00
										 |  |  | 	int alloc_len= strlen(str) + 1; | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 	ListBase *strings= &CachedText[CachedTextLevel-1]; | 
					
						
							| 
									
										
										
										
											2011-12-03 20:49:41 +00:00
										 |  |  | 	/* TODO, replace with more efficient malloc, perhaps memarena per draw? */ | 
					
						
							| 
									
										
										
										
											2010-10-30 23:02:38 +00:00
										 |  |  | 	ViewCachedString *vos= MEM_callocN(sizeof(ViewCachedString) + alloc_len, "ViewCachedString"); | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 	BLI_addtail(strings, vos); | 
					
						
							| 
									
										
										
										
											2010-10-19 02:41:09 +00:00
										 |  |  | 	copy_v3_v3(vos->vec, co); | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 	vos->col.pack= *((int *)col); | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 	vos->xoffs= xoffs; | 
					
						
							| 
									
										
										
										
											2010-02-19 20:09:42 +00:00
										 |  |  | 	vos->flag= flag; | 
					
						
							| 
									
										
										
										
											2011-03-10 12:52:18 +00:00
										 |  |  | 	vos->str_len= alloc_len-1; | 
					
						
							| 
									
										
										
										
											2010-10-30 23:02:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* allocate past the end */ | 
					
						
							|  |  |  | 	memcpy(++vos, str, alloc_len); | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | void view3d_cached_text_draw_end(View3D *v3d, ARegion *ar, int depth_write, float mat[][4]) | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 	RegionView3D *rv3d= ar->regiondata; | 
					
						
							|  |  |  | 	ListBase *strings= &CachedText[CachedTextLevel-1]; | 
					
						
							|  |  |  | 	ViewCachedString *vos; | 
					
						
							|  |  |  | 	int a, tot= 0; | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* project first and test */ | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 	for(vos= strings->first; vos; vos= vos->next) { | 
					
						
							| 
									
										
										
										
											2010-03-03 11:23:59 +00:00
										 |  |  | 		if(mat && !(vos->flag & V3D_CACHE_TEXT_WORLDSPACE)) | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 			mul_m4_v3(mat, vos->vec); | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		if(vos->flag&V3D_CACHE_TEXT_GLOBALSPACE) | 
					
						
							|  |  |  | 			view3d_project_short_clip_persmat(ar, vos->vec, vos->sco, 0); | 
					
						
							|  |  |  | 		else | 
					
						
							|  |  |  | 			view3d_project_short_clip(ar, vos->vec, vos->sco, 0); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-12 16:47:36 +00:00
										 |  |  | 		if(vos->sco[0]!=IS_CLIPPED) | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 			tot++; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 	if(tot) { | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 		int col_pack_prev= 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-08 11:46:52 +00:00
										 |  |  | #if 0
 | 
					
						
							| 
									
										
										
										
											2010-02-19 20:09:42 +00:00
										 |  |  | 		bglMats mats; /* ZBuffer depth vars */ | 
					
						
							|  |  |  | 		double ux, uy, uz; | 
					
						
							|  |  |  | 		float depth; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if(v3d->zbuf) | 
					
						
							|  |  |  | 			bgl_get_mats(&mats); | 
					
						
							| 
									
										
										
										
											2010-04-08 11:46:52 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 		if(rv3d->rflag & RV3D_CLIPPING) | 
					
						
							|  |  |  | 			for(a=0; a<6; a++) | 
					
						
							|  |  |  | 				glDisable(GL_CLIP_PLANE0+a); | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2010-02-01 15:32:55 +00:00
										 |  |  | 		glMatrixMode(GL_PROJECTION); | 
					
						
							|  |  |  | 		glPushMatrix(); | 
					
						
							|  |  |  | 		glMatrixMode(GL_MODELVIEW); | 
					
						
							|  |  |  | 		glPushMatrix(); | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 		ED_region_pixelspace(ar); | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 		if(depth_write) { | 
					
						
							|  |  |  | 			if(v3d->zbuf) glDisable(GL_DEPTH_TEST); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else glDepthMask(0); | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 		for(vos= strings->first; vos; vos= vos->next) { | 
					
						
							| 
									
										
										
										
											2011-12-03 20:49:41 +00:00
										 |  |  | 			/* too slow, reading opengl info while drawing is very bad,
 | 
					
						
							|  |  |  | 			 * better to see if we can use the zbuffer while in pixel space - campbell */ | 
					
						
							|  |  |  | #if 0
 | 
					
						
							| 
									
										
										
										
											2010-02-19 20:09:42 +00:00
										 |  |  | 			if(v3d->zbuf && (vos->flag & V3D_CACHE_TEXT_ZBUF)) { | 
					
						
							|  |  |  | 				gluProject(vos->vec[0], vos->vec[1], vos->vec[2], mats.modelview, mats.projection, (GLint *)mats.viewport, &ux, &uy, &uz); | 
					
						
							|  |  |  | 				glReadPixels(ar->winrct.xmin+vos->mval[0]+vos->xoffs, ar->winrct.ymin+vos->mval[1], 1, 1, GL_DEPTH_COMPONENT, GL_FLOAT, &depth); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				if(uz > depth) | 
					
						
							|  |  |  | 					continue; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2010-04-02 10:32:58 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2011-05-12 16:47:36 +00:00
										 |  |  | 			if(vos->sco[0]!=IS_CLIPPED) { | 
					
						
							| 
									
										
										
										
											2010-10-30 23:02:38 +00:00
										 |  |  | 				const char *str= (char *)(vos+1); | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				if(col_pack_prev != vos->col.pack) { | 
					
						
							|  |  |  | 					glColor3ubv(vos->col.ub); | 
					
						
							|  |  |  | 					col_pack_prev= vos->col.pack; | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2011-12-03 20:49:41 +00:00
										 |  |  | 				((vos->flag & V3D_CACHE_TEXT_ASCII) ? | 
					
						
							|  |  |  | 				            BLF_draw_default_ascii : | 
					
						
							|  |  |  | 				            BLF_draw_default | 
					
						
							|  |  |  | 				            ) ( (float)vos->sco[0] + vos->xoffs, | 
					
						
							|  |  |  | 				                (float)vos->sco[1], | 
					
						
							|  |  |  | 				                (depth_write) ? 0.0f: 2.0f, | 
					
						
							|  |  |  | 				                str, | 
					
						
							|  |  |  | 				                vos->str_len); | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 		if(depth_write) { | 
					
						
							|  |  |  | 			if(v3d->zbuf) glEnable(GL_DEPTH_TEST); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else glDepthMask(1); | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2010-02-01 15:32:55 +00:00
										 |  |  | 		glMatrixMode(GL_PROJECTION); | 
					
						
							|  |  |  | 		glPopMatrix(); | 
					
						
							|  |  |  | 		glMatrixMode(GL_MODELVIEW); | 
					
						
							|  |  |  | 		glPopMatrix(); | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		if(rv3d->rflag & RV3D_CLIPPING) | 
					
						
							|  |  |  | 			for(a=0; a<6; a++) | 
					
						
							|  |  |  | 				glEnable(GL_CLIP_PLANE0+a); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 	if(strings->first)  | 
					
						
							|  |  |  | 		BLI_freelistN(strings); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	CachedTextLevel--; | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | /* ******************** primitive drawing ******************* */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | static void drawcube(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glBegin(GL_LINE_STRIP); | 
					
						
							|  |  |  | 		glVertex3fv(cube[0]); glVertex3fv(cube[1]);glVertex3fv(cube[2]); glVertex3fv(cube[3]); | 
					
						
							|  |  |  | 		glVertex3fv(cube[0]); glVertex3fv(cube[4]);glVertex3fv(cube[5]); glVertex3fv(cube[6]); | 
					
						
							|  |  |  | 		glVertex3fv(cube[7]); glVertex3fv(cube[4]); | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glBegin(GL_LINE_STRIP); | 
					
						
							|  |  |  | 		glVertex3fv(cube[1]); glVertex3fv(cube[5]); | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glBegin(GL_LINE_STRIP); | 
					
						
							|  |  |  | 		glVertex3fv(cube[2]); glVertex3fv(cube[6]); | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glBegin(GL_LINE_STRIP); | 
					
						
							|  |  |  | 		glVertex3fv(cube[3]); glVertex3fv(cube[7]); | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* draws a cube on given the scaling of the cube, assuming that 
 | 
					
						
							|  |  |  |  * all required matrices have been set (used for drawing empties) | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | static void drawcube_size(float size) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	glBegin(GL_LINE_STRIP); | 
					
						
							| 
									
										
										
										
											2011-12-03 20:49:41 +00:00
										 |  |  | 		glVertex3f(-size,-size,-size); glVertex3f(-size,-size,size); | 
					
						
							|  |  |  | 		glVertex3f(-size,size,size); glVertex3f(-size,size,-size); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		glVertex3f(-size,-size,-size); glVertex3f(size,-size,-size); | 
					
						
							|  |  |  | 		glVertex3f(size,-size,size); glVertex3f(size,size,size); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		glVertex3f(size,size,-size); glVertex3f(size,-size,-size); | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glBegin(GL_LINE_STRIP); | 
					
						
							|  |  |  | 		glVertex3f(-size,-size,size); glVertex3f(size,-size,size); | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glBegin(GL_LINE_STRIP); | 
					
						
							|  |  |  | 		glVertex3f(-size,size,size); glVertex3f(size,size,size); | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glBegin(GL_LINE_STRIP); | 
					
						
							|  |  |  | 		glVertex3f(-size,size,-size); glVertex3f(size,size,-size); | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* this is an unused (old) cube-drawing function based on a given size */ | 
					
						
							|  |  |  | #if 0
 | 
					
						
							| 
									
										
										
										
											2011-09-11 02:50:01 +00:00
										 |  |  | static void drawcube_size(const float size[3]) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glPushMatrix(); | 
					
						
							|  |  |  | 	glScalef(size[0],  size[1],  size[2]); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glBegin(GL_LINE_STRIP); | 
					
						
							|  |  |  | 		glVertex3fv(cube[0]); glVertex3fv(cube[1]);glVertex3fv(cube[2]); glVertex3fv(cube[3]); | 
					
						
							|  |  |  | 		glVertex3fv(cube[0]); glVertex3fv(cube[4]);glVertex3fv(cube[5]); glVertex3fv(cube[6]); | 
					
						
							|  |  |  | 		glVertex3fv(cube[7]); glVertex3fv(cube[4]); | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glBegin(GL_LINE_STRIP); | 
					
						
							|  |  |  | 		glVertex3fv(cube[1]); glVertex3fv(cube[5]); | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glBegin(GL_LINE_STRIP); | 
					
						
							|  |  |  | 		glVertex3fv(cube[2]); glVertex3fv(cube[6]); | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glBegin(GL_LINE_STRIP); | 
					
						
							|  |  |  | 		glVertex3fv(cube[3]); glVertex3fv(cube[7]); | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	glPopMatrix(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void drawshadbuflimits(Lamp *la, float mat[][4]) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	float sta[3], end[3], lavec[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-10 07:57:25 +00:00
										 |  |  | 	negate_v3_v3(lavec, mat[2]); | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 	normalize_v3(lavec); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-31 10:58:10 +00:00
										 |  |  | 	madd_v3_v3v3fl(sta, mat[3], lavec, la->clipsta); | 
					
						
							|  |  |  | 	madd_v3_v3v3fl(end, mat[3], lavec, la->clipend); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	glBegin(GL_LINE_STRIP); | 
					
						
							|  |  |  | 		glVertex3fv(sta); | 
					
						
							|  |  |  | 		glVertex3fv(end); | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glPointSize(3.0); | 
					
						
							|  |  |  | 	bglBegin(GL_POINTS); | 
					
						
							|  |  |  | 	bglVertex3fv(sta); | 
					
						
							|  |  |  | 	bglVertex3fv(end); | 
					
						
							|  |  |  | 	bglEnd(); | 
					
						
							|  |  |  | 	glPointSize(1.0); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-11 02:50:01 +00:00
										 |  |  | static void spotvolume(float lvec[3], float vvec[3], const float inp) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* camera is at 0,0,0 */ | 
					
						
							|  |  |  | 	float temp[3],plane[3],mat1[3][3],mat2[3][3],mat3[3][3],mat4[3][3],q[4],co,si,angle; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 	normalize_v3(lvec); | 
					
						
							|  |  |  | 	normalize_v3(vvec);				/* is this the correct vector ? */ | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 	cross_v3_v3v3(temp,vvec,lvec);		/* equation for a plane through vvec en lvec */ | 
					
						
							|  |  |  | 	cross_v3_v3v3(plane,lvec,temp);		/* a plane perpendicular to this, parrallel with lvec */ | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-08 00:58:15 +00:00
										 |  |  | 	/* vectors are exactly aligned, use the X axis, this is arbitrary */ | 
					
						
							|  |  |  | 	if(normalize_v3(plane) == 0.0f) | 
					
						
							|  |  |  | 		plane[1]= 1.0f; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* now we've got two equations: one of a cone and one of a plane, but we have
 | 
					
						
							|  |  |  | 	three unknowns. We remove one unkown by rotating the plane to z=0 (the plane normal) */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* rotate around cross product vector of (0,0,1) and plane normal, dot product degrees */ | 
					
						
							|  |  |  | 	/* according definition, we derive cross product is (plane[1],-plane[0],0), en cos = plane[2]);*/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* translating this comment to english didnt really help me understanding the math! :-) (ton) */ | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	q[1] = plane[1] ;  | 
					
						
							|  |  |  | 	q[2] = -plane[0] ;  | 
					
						
							|  |  |  | 	q[3] = 0 ; | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 	normalize_v3(&q[1]); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 	angle = saacos(plane[2])/2.0f; | 
					
						
							| 
									
										
										
										
											2011-09-11 02:50:01 +00:00
										 |  |  | 	co = cosf(angle); | 
					
						
							|  |  |  | 	si = sqrtf(1-co*co); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	q[0] =  co; | 
					
						
							|  |  |  | 	q[1] *= si; | 
					
						
							|  |  |  | 	q[2] *= si; | 
					
						
							|  |  |  | 	q[3] =  0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 	quat_to_mat3(mat1,q); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* rotate lamp vector now over acos(inp) degrees */ | 
					
						
							| 
									
										
										
										
											2010-07-31 10:58:10 +00:00
										 |  |  | 	copy_v3_v3(vvec, lvec); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 	unit_m3(mat2); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	co = inp; | 
					
						
							| 
									
										
										
										
											2011-09-11 02:50:01 +00:00
										 |  |  | 	si = sqrtf(1.0f-inp*inp); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	mat2[0][0] =  co; | 
					
						
							|  |  |  | 	mat2[1][0] = -si; | 
					
						
							|  |  |  | 	mat2[0][1] =  si; | 
					
						
							|  |  |  | 	mat2[1][1] =  co; | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 	mul_m3_m3m3(mat3,mat2,mat1); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	mat2[1][0] =  si; | 
					
						
							|  |  |  | 	mat2[0][1] = -si; | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 	mul_m3_m3m3(mat4,mat2,mat1); | 
					
						
							|  |  |  | 	transpose_m3(mat1); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 	mul_m3_m3m3(mat2,mat1,mat3); | 
					
						
							|  |  |  | 	mul_m3_v3(mat2,lvec); | 
					
						
							|  |  |  | 	mul_m3_m3m3(mat2,mat1,mat4); | 
					
						
							|  |  |  | 	mul_m3_v3(mat2,vvec); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	return; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-25 14:47:32 +00:00
										 |  |  | static void draw_spot_cone(Lamp *la, float x, float z) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2010-01-25 14:47:32 +00:00
										 |  |  | 	z= fabs(z); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glBegin(GL_TRIANGLE_FAN); | 
					
						
							|  |  |  | 	glVertex3f(0.0f, 0.0f, -x); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(la->mode & LA_SQUARE) { | 
					
						
							| 
									
										
										
										
											2010-06-10 19:35:37 +00:00
										 |  |  | 		glVertex3f(z, z, 0); | 
					
						
							|  |  |  | 		glVertex3f(-z, z, 0); | 
					
						
							|  |  |  | 		glVertex3f(-z, -z, 0); | 
					
						
							|  |  |  | 		glVertex3f(z, -z, 0); | 
					
						
							|  |  |  | 		glVertex3f(z, z, 0); | 
					
						
							| 
									
										
										
										
											2010-01-25 14:47:32 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		float angle; | 
					
						
							|  |  |  | 		int a; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		for(a=0; a<33; a++) { | 
					
						
							|  |  |  | 			angle= a*M_PI*2/(33-1); | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 			glVertex3f(z*cosf(angle), z*sinf(angle), 0); | 
					
						
							| 
									
										
										
										
											2010-01-25 14:47:32 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void draw_transp_spot_volume(Lamp *la, float x, float z) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	glEnable(GL_CULL_FACE); | 
					
						
							|  |  |  | 	glEnable(GL_BLEND); | 
					
						
							|  |  |  | 	glDepthMask(0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* draw backside darkening */ | 
					
						
							|  |  |  | 	glCullFace(GL_FRONT); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glBlendFunc(GL_ZERO, GL_SRC_ALPHA); | 
					
						
							|  |  |  | 	glColor4f(0.0f, 0.0f, 0.0f, 0.4f); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	draw_spot_cone(la, x, z); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-20 10:41:08 +00:00
										 |  |  | 	/* draw front side lighting */ | 
					
						
							| 
									
										
										
										
											2010-01-25 14:47:32 +00:00
										 |  |  | 	glCullFace(GL_BACK); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glBlendFunc(GL_ONE,  GL_ONE);  | 
					
						
							|  |  |  | 	glColor4f(0.2f, 0.2f, 0.2f, 1.0f); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	draw_spot_cone(la, x, z); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* restore state */ | 
					
						
							|  |  |  | 	glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); | 
					
						
							|  |  |  | 	glDisable(GL_BLEND); | 
					
						
							|  |  |  | 	glDepthMask(1); | 
					
						
							|  |  |  | 	glDisable(GL_CULL_FACE); | 
					
						
							|  |  |  | 	glCullFace(GL_BACK); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void drawlamp(Scene *scene, View3D *v3d, RegionView3D *rv3d, Base *base, int dt, int flag) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2010-01-25 14:47:32 +00:00
										 |  |  | 	Object *ob= base->object; | 
					
						
							| 
									
										
										
										
											2011-05-21 08:56:37 +00:00
										 |  |  | 	const float pixsize= ED_view3d_pixel_size(rv3d, ob->obmat[3]); | 
					
						
							| 
									
										
										
										
											2010-01-25 14:47:32 +00:00
										 |  |  | 	Lamp *la= ob->data; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	float vec[3], lvec[3], vvec[3], circrad, x,y,z; | 
					
						
							| 
									
										
										
										
											2010-11-05 05:26:34 +00:00
										 |  |  | 	float lampsize; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	float imat[4][4], curcol[4]; | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 	unsigned char col[4]; | 
					
						
							| 
									
										
										
										
											2010-12-07 20:22:35 +00:00
										 |  |  | 	/* cone can't be drawn for duplicated lamps, because duplilist would be freed to */ | 
					
						
							|  |  |  | 	/* the moment of view3d_draw_transp() call */ | 
					
						
							| 
									
										
										
										
											2011-01-03 06:45:47 +00:00
										 |  |  | 	const short is_view= (rv3d->persp==RV3D_CAMOB && v3d->camera == base->object); | 
					
						
							| 
									
										
										
										
											2011-11-25 02:35:23 +00:00
										 |  |  | 	const short drawcone= ((dt > OB_WIRE) && | 
					
						
							|  |  |  | 	                       !(G.f & G_PICKSEL) && | 
					
						
							|  |  |  | 	                       (la->type == LA_SPOT) && | 
					
						
							|  |  |  | 	                       (la->mode & LA_SHOW_CONE) && | 
					
						
							|  |  |  | 	                       !(base->flag & OB_FROMDUPLI) && | 
					
						
							|  |  |  | 	                       !is_view); | 
					
						
							| 
									
										
										
										
											2010-12-07 20:22:35 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-25 14:47:32 +00:00
										 |  |  | 	if(drawcone && !v3d->transp) { | 
					
						
							|  |  |  | 		/* in this case we need to draw delayed */ | 
					
						
							| 
									
										
										
										
											2010-09-07 05:47:34 +00:00
										 |  |  | 		add_view3d_after(&v3d->afterdraw_transp, base, flag); | 
					
						
							| 
									
										
										
										
											2010-01-25 14:47:32 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* we first draw only the screen aligned & fixed scale stuff */ | 
					
						
							|  |  |  | 	glPushMatrix(); | 
					
						
							| 
									
										
										
										
											2010-02-01 15:32:55 +00:00
										 |  |  | 	glLoadMatrixf(rv3d->viewmat); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* lets calculate the scale: */ | 
					
						
							|  |  |  | 	lampsize= pixsize*((float)U.obcenter_dia*0.5f); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* and view aligned matrix: */ | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 	copy_m4_m4(imat, rv3d->viewinv); | 
					
						
							|  |  |  | 	normalize_v3(imat[0]); | 
					
						
							|  |  |  | 	normalize_v3(imat[1]); | 
					
						
							| 
									
										
										
										
											2010-10-07 10:04:07 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* lamp center */ | 
					
						
							|  |  |  | 	copy_v3_v3(vec, ob->obmat[3]); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* for AA effects */ | 
					
						
							|  |  |  | 	glGetFloatv(GL_CURRENT_COLOR, curcol); | 
					
						
							|  |  |  | 	curcol[3]= 0.6; | 
					
						
							|  |  |  | 	glColor4fv(curcol); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-01-03 01:55:20 +00:00
										 |  |  | 	if(lampsize > 0.0f) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if(ob->id.us>1) { | 
					
						
							|  |  |  | 			if (ob==OBACT || (ob->flag & SELECT)) glColor4ub(0x88, 0xFF, 0xFF, 155); | 
					
						
							|  |  |  | 			else glColor4ub(0x77, 0xCC, 0xCC, 155); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* Inner Circle */ | 
					
						
							|  |  |  | 		glEnable(GL_BLEND); | 
					
						
							|  |  |  | 		drawcircball(GL_LINE_LOOP, vec, lampsize, imat); | 
					
						
							|  |  |  | 		glDisable(GL_BLEND); | 
					
						
							|  |  |  | 		drawcircball(GL_POLYGON, vec, lampsize, imat); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2010-01-03 01:55:20 +00:00
										 |  |  | 		/* restore */ | 
					
						
							|  |  |  | 		if(ob->id.us>1) | 
					
						
							|  |  |  | 			glColor4fv(curcol); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 		/* Outer circle */ | 
					
						
							|  |  |  | 		circrad = 3.0f*lampsize; | 
					
						
							| 
									
										
										
										
											2010-05-22 11:58:21 +00:00
										 |  |  | 		setlinestyle(3); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-03 01:55:20 +00:00
										 |  |  | 		drawcircball(GL_LINE_LOOP, vec, circrad, imat); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-05-22 11:58:21 +00:00
										 |  |  | 		/* draw dashed outer circle if shadow is on. remember some lamps can't have certain shadows! */ | 
					
						
							|  |  |  | 		if(la->type!=LA_HEMI) { | 
					
						
							|  |  |  | 			if(	(la->mode & LA_SHAD_RAY) || | 
					
						
							|  |  |  | 				((la->mode & LA_SHAD_BUF) && (la->type==LA_SPOT)) | 
					
						
							|  |  |  | 			) { | 
					
						
							|  |  |  | 				drawcircball(GL_LINE_LOOP, vec, circrad + 3.0f*pixsize, imat); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-05-22 11:58:21 +00:00
										 |  |  | 	else { | 
					
						
							|  |  |  | 		setlinestyle(3); | 
					
						
							| 
									
										
										
										
											2010-01-08 17:53:17 +00:00
										 |  |  | 		circrad = 0.0f; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* draw the pretty sun rays */ | 
					
						
							|  |  |  | 	if(la->type==LA_SUN) { | 
					
						
							|  |  |  | 		float v1[3], v2[3], mat[3][3]; | 
					
						
							|  |  |  | 		short axis; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* setup a 45 degree rotation matrix */ | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 		vec_rot_to_mat3(mat, imat[2], (float)M_PI/4.0f); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		/* vectors */ | 
					
						
							| 
									
										
										
										
											2010-07-31 10:58:10 +00:00
										 |  |  | 		mul_v3_v3fl(v1, imat[0], circrad * 1.2f); | 
					
						
							|  |  |  | 		mul_v3_v3fl(v2, imat[0], circrad * 2.5f); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		/* center */ | 
					
						
							|  |  |  | 		glTranslatef(vec[0], vec[1], vec[2]); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		setlinestyle(3); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		glBegin(GL_LINES); | 
					
						
							|  |  |  | 		for (axis=0; axis<8; axis++) { | 
					
						
							|  |  |  | 			glVertex3fv(v1); | 
					
						
							|  |  |  | 			glVertex3fv(v2); | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 			mul_m3_v3(mat, v1); | 
					
						
							|  |  |  | 			mul_m3_v3(mat, v2); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		glEnd(); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		glTranslatef(-vec[0], -vec[1], -vec[2]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	}		 | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (la->type==LA_LOCAL) { | 
					
						
							|  |  |  | 		if(la->mode & LA_SPHERE) { | 
					
						
							|  |  |  | 			drawcircball(GL_LINE_LOOP, vec, la->dist, imat); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		/* yafray: for photonlight also draw lightcone as for spot */ | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	glPopMatrix();	/* back in object space */ | 
					
						
							| 
									
										
										
										
											2010-07-31 10:58:10 +00:00
										 |  |  | 	zero_v3(vec); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2011-01-03 06:45:47 +00:00
										 |  |  | 	if(is_view) { | 
					
						
							|  |  |  | 		/* skip drawing extra info */ | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else if ((la->type==LA_SPOT) || (la->type==LA_YF_PHOTON)) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		lvec[0]=lvec[1]= 0.0;  | 
					
						
							|  |  |  | 		lvec[2] = 1.0; | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | 		x = rv3d->persmat[0][2]; | 
					
						
							|  |  |  | 		y = rv3d->persmat[1][2]; | 
					
						
							|  |  |  | 		z = rv3d->persmat[2][2]; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		vvec[0]= x*ob->obmat[0][0] + y*ob->obmat[0][1] + z*ob->obmat[0][2]; | 
					
						
							|  |  |  | 		vvec[1]= x*ob->obmat[1][0] + y*ob->obmat[1][1] + z*ob->obmat[1][2]; | 
					
						
							|  |  |  | 		vvec[2]= x*ob->obmat[2][0] + y*ob->obmat[2][1] + z*ob->obmat[2][2]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 		y = cosf(la->spotsize*(float)(M_PI/360.0)); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		spotvolume(lvec, vvec, y); | 
					
						
							|  |  |  | 		x = -la->dist; | 
					
						
							| 
									
										
										
										
											2010-01-25 14:47:32 +00:00
										 |  |  | 		mul_v3_fl(lvec, x); | 
					
						
							|  |  |  | 		mul_v3_fl(vvec, x); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* draw the angled sides of the cone */ | 
					
						
							|  |  |  | 		glBegin(GL_LINE_STRIP); | 
					
						
							|  |  |  | 			glVertex3fv(vvec); | 
					
						
							|  |  |  | 			glVertex3fv(vec); | 
					
						
							|  |  |  | 			glVertex3fv(lvec); | 
					
						
							|  |  |  | 		glEnd(); | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 		z = x*sqrtf(1.0f - y*y); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		x *= y; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* draw the circle/square at the end of the cone */ | 
					
						
							|  |  |  | 		glTranslatef(0.0, 0.0 ,  x); | 
					
						
							|  |  |  | 		if(la->mode & LA_SQUARE) { | 
					
						
							| 
									
										
										
										
											2010-06-10 07:57:25 +00:00
										 |  |  | 			float tvec[3]; | 
					
						
							|  |  |  | 			float z_abs= fabs(z); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			tvec[0]= tvec[1]= z_abs; | 
					
						
							|  |  |  | 			tvec[2]= 0.0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			glBegin(GL_LINE_LOOP); | 
					
						
							| 
									
										
										
										
											2010-06-10 07:57:25 +00:00
										 |  |  | 				glVertex3fv(tvec); | 
					
						
							|  |  |  | 				tvec[1]= -z_abs; /* neg */ | 
					
						
							|  |  |  | 				glVertex3fv(tvec); | 
					
						
							|  |  |  | 				tvec[0]= -z_abs; /* neg */ | 
					
						
							|  |  |  | 				glVertex3fv(tvec); | 
					
						
							|  |  |  | 				tvec[1]= z_abs; /* pos */ | 
					
						
							|  |  |  | 				glVertex3fv(tvec); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			glEnd(); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 		else circ(0.0, 0.0, fabsf(z)); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		/* draw the circle/square representing spotbl */ | 
					
						
							|  |  |  | 		if(la->type==LA_SPOT) { | 
					
						
							|  |  |  | 			float spotblcirc = fabs(z)*(1 - pow(la->spotblend, 2)); | 
					
						
							| 
									
										
										
										
											2009-11-01 00:06:53 +00:00
										 |  |  | 			/* hide line if it is zero size or overlaps with outer border,
 | 
					
						
							|  |  |  | 			   previously it adjusted to always to show it but that seems | 
					
						
							|  |  |  | 			   confusing because it doesn't show the actual blend size */ | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 			if (spotblcirc != 0 && spotblcirc != fabsf(z)) | 
					
						
							| 
									
										
										
										
											2009-11-01 00:06:53 +00:00
										 |  |  | 				circ(0.0, 0.0, spotblcirc); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2010-01-25 14:47:32 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		if(drawcone) | 
					
						
							|  |  |  | 			draw_transp_spot_volume(la, x, z); | 
					
						
							| 
									
										
										
										
											2010-06-10 07:57:25 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* draw clip start, useful for wide cones where its not obvious where the start is */ | 
					
						
							|  |  |  | 		glTranslatef(0.0, 0.0 , -x); /* reverse translation above */ | 
					
						
							|  |  |  | 		if(la->type==LA_SPOT && (la->mode & LA_SHAD_BUF) ) { | 
					
						
							|  |  |  | 			float lvec_clip[3]; | 
					
						
							|  |  |  | 			float vvec_clip[3]; | 
					
						
							|  |  |  | 			float clipsta_fac= la->clipsta / -x; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			interp_v3_v3v3(lvec_clip, vec, lvec, clipsta_fac); | 
					
						
							|  |  |  | 			interp_v3_v3v3(vvec_clip, vec, vvec, clipsta_fac); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			glBegin(GL_LINE_STRIP); | 
					
						
							|  |  |  | 				glVertex3fv(lvec_clip); | 
					
						
							|  |  |  | 				glVertex3fv(vvec_clip); | 
					
						
							|  |  |  | 			glEnd(); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else if ELEM(la->type, LA_HEMI, LA_SUN) { | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* draw the line from the circle along the dist */ | 
					
						
							|  |  |  | 		glBegin(GL_LINE_STRIP); | 
					
						
							|  |  |  | 			vec[2] = -circrad; | 
					
						
							|  |  |  | 			glVertex3fv(vec);  | 
					
						
							|  |  |  | 			vec[2]= -la->dist;  | 
					
						
							|  |  |  | 			glVertex3fv(vec); | 
					
						
							|  |  |  | 		glEnd(); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		if(la->type==LA_HEMI) { | 
					
						
							|  |  |  | 			/* draw the hemisphere curves */ | 
					
						
							|  |  |  | 			short axis, steps, dir; | 
					
						
							|  |  |  | 			float outdist, zdist, mul; | 
					
						
							| 
									
										
										
										
											2010-07-31 10:58:10 +00:00
										 |  |  | 			zero_v3(vec); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			outdist = 0.14; mul = 1.4; dir = 1; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			setlinestyle(4); | 
					
						
							|  |  |  | 			/* loop over the 4 compass points, and draw each arc as a LINE_STRIP */ | 
					
						
							|  |  |  | 			for (axis=0; axis<4; axis++) { | 
					
						
							|  |  |  | 				float v[3]= {0.0, 0.0, 0.0}; | 
					
						
							|  |  |  | 				zdist = 0.02; | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				glBegin(GL_LINE_STRIP); | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				for (steps=0; steps<6; steps++) { | 
					
						
							|  |  |  | 					if (axis == 0 || axis == 1) { 		/* x axis up, x axis down */	 | 
					
						
							|  |  |  | 						/* make the arcs start at the edge of the energy circle */ | 
					
						
							|  |  |  | 						if (steps == 0) v[0] = dir*circrad; | 
					
						
							|  |  |  | 						else v[0] = v[0] + dir*(steps*outdist); | 
					
						
							|  |  |  | 					} else if (axis == 2 || axis == 3) { 		/* y axis up, y axis down */ | 
					
						
							|  |  |  | 						/* make the arcs start at the edge of the energy circle */ | 
					
						
							|  |  |  | 						if (steps == 0) v[1] = dir*circrad; | 
					
						
							|  |  |  | 						else v[1] = v[1] + dir*(steps*outdist);  | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 					v[2] = v[2] - steps*zdist; | 
					
						
							|  |  |  | 					 | 
					
						
							|  |  |  | 					glVertex3fv(v); | 
					
						
							|  |  |  | 					 | 
					
						
							|  |  |  | 					zdist = zdist * mul; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				glEnd(); | 
					
						
							|  |  |  | 				/* flip the direction */ | 
					
						
							|  |  |  | 				dir = -dir; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} else if(la->type==LA_AREA) { | 
					
						
							|  |  |  | 		setlinestyle(3); | 
					
						
							|  |  |  | 		if(la->area_shape==LA_AREA_SQUARE)  | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 			fdrawbox(-la->area_size*0.5f, -la->area_size*0.5f, la->area_size*0.5f, la->area_size*0.5f); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		else if(la->area_shape==LA_AREA_RECT)  | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 			fdrawbox(-la->area_size*0.5f, -la->area_sizey*0.5f, la->area_size*0.5f, la->area_sizey*0.5f); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		glBegin(GL_LINE_STRIP);  | 
					
						
							|  |  |  | 		glVertex3f(0.0,0.0,-circrad); | 
					
						
							|  |  |  | 		glVertex3f(0.0,0.0,-la->dist); | 
					
						
							|  |  |  | 		glEnd(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* and back to viewspace */ | 
					
						
							| 
									
										
										
										
											2010-02-01 15:32:55 +00:00
										 |  |  | 	glLoadMatrixf(rv3d->viewmat); | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 	copy_v3_v3(vec, ob->obmat[3]); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	setlinestyle(0); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2011-01-03 06:45:47 +00:00
										 |  |  | 	if((la->type == LA_SPOT) && (la->mode & LA_SHAD_BUF) && (is_view == FALSE)) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		drawshadbuflimits(la, ob->obmat); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	UI_GetThemeColor4ubv(TH_LAMP, col); | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 	glColor4ubv(col); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	  | 
					
						
							|  |  |  | 	glEnable(GL_BLEND); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (vec[2]>0) vec[2] -= circrad; | 
					
						
							|  |  |  | 	else vec[2] += circrad; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	glBegin(GL_LINE_STRIP); | 
					
						
							|  |  |  | 		glVertex3fv(vec);  | 
					
						
							|  |  |  | 		vec[2]= 0;  | 
					
						
							|  |  |  | 		glVertex3fv(vec); | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	glPointSize(2.0); | 
					
						
							|  |  |  | 	glBegin(GL_POINTS); | 
					
						
							|  |  |  | 		glVertex3fv(vec); | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 	glPointSize(1.0); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	glDisable(GL_BLEND); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* restore for drawing extra stuff */ | 
					
						
							|  |  |  | 	glColor3fv(curcol); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void draw_limit_line(float sta, float end, unsigned int col) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	glBegin(GL_LINES); | 
					
						
							|  |  |  | 	glVertex3f(0.0, 0.0, -sta); | 
					
						
							|  |  |  | 	glVertex3f(0.0, 0.0, -end); | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glPointSize(3.0); | 
					
						
							|  |  |  | 	glBegin(GL_POINTS); | 
					
						
							|  |  |  | 	cpack(col); | 
					
						
							|  |  |  | 	glVertex3f(0.0, 0.0, -sta); | 
					
						
							|  |  |  | 	glVertex3f(0.0, 0.0, -end); | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 	glPointSize(1.0); | 
					
						
							|  |  |  | }		 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* yafray: draw camera focus point (cross, similar to aqsis code in tuhopuu) */ | 
					
						
							|  |  |  | /* qdn: now also enabled for Blender to set focus point for defocus composit node */ | 
					
						
							|  |  |  | static void draw_focus_cross(float dist, float size) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	glBegin(GL_LINES); | 
					
						
							|  |  |  | 	glVertex3f(-size, 0.f, -dist); | 
					
						
							|  |  |  | 	glVertex3f(size, 0.f, -dist); | 
					
						
							|  |  |  | 	glVertex3f(0.f, -size, -dist); | 
					
						
							|  |  |  | 	glVertex3f(0.f, size, -dist); | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-21 01:30:26 +00:00
										 |  |  | #ifdef VIEW3D_CAMERA_BORDER_HACK
 | 
					
						
							|  |  |  | float view3d_camera_border_hack_col[4]; | 
					
						
							|  |  |  | short view3d_camera_border_hack_test= FALSE; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | /* ****************** draw clip data *************** */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void draw_bundle_sphere(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	static GLuint displist= 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (displist == 0) { | 
					
						
							|  |  |  | 		GLUquadricObj *qobj; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		displist= glGenLists(1); | 
					
						
							|  |  |  | 		glNewList(displist, GL_COMPILE); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		qobj= gluNewQuadric(); | 
					
						
							|  |  |  | 		gluQuadricDrawStyle(qobj, GLU_FILL); | 
					
						
							|  |  |  | 		glShadeModel(GL_SMOOTH); | 
					
						
							|  |  |  | 		gluSphere(qobj, 0.05, 8, 8); | 
					
						
							|  |  |  | 		glShadeModel(GL_FLAT); | 
					
						
							|  |  |  | 		gluDeleteQuadric(qobj); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		glEndList(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glCallList(displist); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-05 18:57:17 +00:00
										 |  |  | static void draw_viewport_object_reconstruction(Scene *scene, Base *base, View3D *v3d, | 
					
						
							| 
									
										
										
										
											2011-12-15 16:10:49 +00:00
										 |  |  | 			MovieClip *clip, MovieTrackingObject *tracking_object, int flag, int *global_track_index) | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	MovieTracking *tracking= &clip->tracking; | 
					
						
							|  |  |  | 	MovieTrackingTrack *track; | 
					
						
							| 
									
										
										
										
											2011-12-05 18:57:17 +00:00
										 |  |  | 	float mat[4][4], imat[4][4]; | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 	unsigned char col[4], scol[4]; | 
					
						
							| 
									
										
										
										
											2011-12-15 16:10:49 +00:00
										 |  |  | 	int tracknr= *global_track_index; | 
					
						
							| 
									
										
										
										
											2011-12-05 18:57:17 +00:00
										 |  |  | 	ListBase *tracksbase= BKE_tracking_object_tracks(tracking, tracking_object); | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	UI_GetThemeColor4ubv(TH_TEXT, col); | 
					
						
							|  |  |  | 	UI_GetThemeColor4ubv(TH_SELECT, scol); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	BKE_get_tracking_mat(scene, base->object, mat); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-05 18:57:17 +00:00
										 |  |  | 	glPushMatrix(); | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-05 18:57:17 +00:00
										 |  |  | 	if(tracking_object->flag & TRACKING_OBJECT_CAMERA) { | 
					
						
							|  |  |  | 		/* current ogl matrix is translated in camera space, bundles should
 | 
					
						
							|  |  |  | 		   be rendered in world space, so camera matrix should be "removed" | 
					
						
							|  |  |  | 		   from current ogl matrix */ | 
					
						
							|  |  |  | 		invert_m4_m4(imat, base->object->obmat); | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-05 18:57:17 +00:00
										 |  |  | 		glMultMatrixf(imat); | 
					
						
							|  |  |  | 		glMultMatrixf(mat); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		float obmat[4][4]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		BKE_tracking_get_interpolated_camera(tracking, tracking_object, scene->r.cfra, obmat); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		invert_m4_m4(imat, obmat); | 
					
						
							|  |  |  | 		glMultMatrixf(imat); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for (track= tracksbase->first; track; track= track->next) { | 
					
						
							|  |  |  | 		int selected= TRACK_SELECTED(track); | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		if((track->flag&TRACK_HAS_BUNDLE)==0) | 
					
						
							|  |  |  | 			continue; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if(flag&DRAW_PICKING) | 
					
						
							| 
									
										
										
										
											2011-12-15 16:10:49 +00:00
										 |  |  | 			glLoadName(base->selcol + (tracknr<<16)); | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		glPushMatrix(); | 
					
						
							|  |  |  | 			glTranslatef(track->bundle_pos[0], track->bundle_pos[1], track->bundle_pos[2]); | 
					
						
							| 
									
										
										
										
											2011-11-11 12:00:08 +00:00
										 |  |  | 			glScalef(v3d->bundle_size/0.05f, v3d->bundle_size/0.05f, v3d->bundle_size/0.05f); | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			if(v3d->drawtype==OB_WIRE) { | 
					
						
							|  |  |  | 				glDisable(GL_LIGHTING); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				if(selected) { | 
					
						
							|  |  |  | 					if(base==BASACT) UI_ThemeColor(TH_ACTIVE); | 
					
						
							|  |  |  | 					else UI_ThemeColor(TH_SELECT); | 
					
						
							|  |  |  | 				} else { | 
					
						
							|  |  |  | 					if(track->flag&TRACK_CUSTOMCOLOR) glColor3fv(track->color); | 
					
						
							|  |  |  | 					else UI_ThemeColor(TH_WIRE); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				drawaxes(0.05f, v3d->bundle_drawtype); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				glEnable(GL_LIGHTING); | 
					
						
							|  |  |  | 			} else if(v3d->drawtype>OB_WIRE) { | 
					
						
							|  |  |  | 				if(v3d->bundle_drawtype==OB_EMPTY_SPHERE) { | 
					
						
							|  |  |  | 					/* selection outline */ | 
					
						
							|  |  |  | 					if(selected) { | 
					
						
							|  |  |  | 						if(base==BASACT) UI_ThemeColor(TH_ACTIVE); | 
					
						
							|  |  |  | 						else UI_ThemeColor(TH_SELECT); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 						glLineWidth(2.f); | 
					
						
							|  |  |  | 						glDisable(GL_LIGHTING); | 
					
						
							|  |  |  | 						glPolygonMode(GL_FRONT_AND_BACK, GL_LINE); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 						draw_bundle_sphere(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 						glPolygonMode(GL_FRONT_AND_BACK, GL_FILL); | 
					
						
							|  |  |  | 						glEnable(GL_LIGHTING); | 
					
						
							|  |  |  | 						glLineWidth(1.f); | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					if(track->flag&TRACK_CUSTOMCOLOR) glColor3fv(track->color); | 
					
						
							|  |  |  | 					else UI_ThemeColor(TH_BUNDLE_SOLID); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					draw_bundle_sphere(); | 
					
						
							|  |  |  | 				} else { | 
					
						
							|  |  |  | 					glDisable(GL_LIGHTING); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					if(selected) { | 
					
						
							|  |  |  | 						if(base==BASACT) UI_ThemeColor(TH_ACTIVE); | 
					
						
							|  |  |  | 						else UI_ThemeColor(TH_SELECT); | 
					
						
							|  |  |  | 					} else { | 
					
						
							|  |  |  | 						if(track->flag&TRACK_CUSTOMCOLOR) glColor3fv(track->color); | 
					
						
							|  |  |  | 						else UI_ThemeColor(TH_WIRE); | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					drawaxes(0.05f, v3d->bundle_drawtype); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					glEnable(GL_LIGHTING); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		glPopMatrix(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if((flag & DRAW_PICKING)==0 && (v3d->flag2&V3D_SHOW_BUNDLENAME)) { | 
					
						
							|  |  |  | 			float pos[3]; | 
					
						
							|  |  |  | 			unsigned char tcol[4]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			if(selected) memcpy(tcol, scol, sizeof(tcol)); | 
					
						
							|  |  |  | 			else memcpy(tcol, col, sizeof(tcol)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			mul_v3_m4v3(pos, mat, track->bundle_pos); | 
					
						
							|  |  |  | 			view3d_cached_text_draw_add(pos, track->name, 10, V3D_CACHE_TEXT_GLOBALSPACE, tcol); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-15 16:10:49 +00:00
										 |  |  | 		tracknr++; | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if((flag & DRAW_PICKING)==0) { | 
					
						
							| 
									
										
										
										
											2011-12-05 18:57:17 +00:00
										 |  |  | 		if((v3d->flag2&V3D_SHOW_CAMERAPATH) && (tracking_object->flag&TRACKING_OBJECT_CAMERA)) { | 
					
						
							|  |  |  | 			MovieTrackingReconstruction *reconstruction; | 
					
						
							|  |  |  | 			reconstruction= BKE_tracking_object_reconstruction(tracking, tracking_object); | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-05 18:57:17 +00:00
										 |  |  | 			if(reconstruction->camnr) { | 
					
						
							|  |  |  | 				MovieReconstructedCamera *camera= reconstruction->cameras; | 
					
						
							|  |  |  | 				int a= 0; | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-05 18:57:17 +00:00
										 |  |  | 				glDisable(GL_LIGHTING); | 
					
						
							|  |  |  | 				UI_ThemeColor(TH_CAMERA_PATH); | 
					
						
							|  |  |  | 				glLineWidth(2.0f); | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-05 18:57:17 +00:00
										 |  |  | 				glBegin(GL_LINE_STRIP); | 
					
						
							|  |  |  | 					for(a= 0; a<reconstruction->camnr; a++, camera++) { | 
					
						
							|  |  |  | 						glVertex3fv(camera->mat[3]); | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 					glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					glLineWidth(1.0f); | 
					
						
							|  |  |  | 					glEnable(GL_LIGHTING); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glPopMatrix(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-15 16:10:49 +00:00
										 |  |  | 	*global_track_index= tracknr; | 
					
						
							| 
									
										
										
										
											2011-12-05 18:57:17 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void draw_viewport_reconstruction(Scene *scene, Base *base, View3D *v3d, MovieClip *clip, int flag) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	MovieTracking *tracking= &clip->tracking; | 
					
						
							|  |  |  | 	MovieTrackingObject *tracking_object; | 
					
						
							|  |  |  | 	float curcol[4]; | 
					
						
							| 
									
										
										
										
											2011-12-15 16:10:49 +00:00
										 |  |  | 	int global_track_index= 1; | 
					
						
							| 
									
										
										
										
											2011-12-05 18:57:17 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if((v3d->flag2&V3D_SHOW_RECONSTRUCTION)==0) | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(v3d->flag2&V3D_RENDER_OVERRIDE) | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glGetFloatv(GL_CURRENT_COLOR, curcol); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glEnable(GL_LIGHTING); | 
					
						
							|  |  |  | 	glColorMaterial(GL_FRONT_AND_BACK, GL_DIFFUSE); | 
					
						
							|  |  |  | 	glEnable(GL_COLOR_MATERIAL); | 
					
						
							|  |  |  | 	glShadeModel(GL_SMOOTH); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	tracking_object= tracking->objects.first; | 
					
						
							|  |  |  | 	while(tracking_object) { | 
					
						
							| 
									
										
										
										
											2011-12-15 16:10:49 +00:00
										 |  |  | 		draw_viewport_object_reconstruction(scene, base, v3d, clip, tracking_object, | 
					
						
							|  |  |  | 					flag, &global_track_index); | 
					
						
							| 
									
										
										
										
											2011-12-05 18:57:17 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		tracking_object= tracking_object->next; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* restore */ | 
					
						
							|  |  |  | 	glShadeModel(GL_FLAT); | 
					
						
							|  |  |  | 	glDisable(GL_COLOR_MATERIAL); | 
					
						
							|  |  |  | 	glDisable(GL_LIGHTING); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glColor4fv(curcol); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(flag&DRAW_PICKING) | 
					
						
							|  |  |  | 		glLoadName(base->selcol); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | /* flag similar to draw_object() */ | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | static void drawcamera(Scene *scene, View3D *v3d, RegionView3D *rv3d, Base *base, int flag) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* a standing up pyramid with (0,0,0) as top */ | 
					
						
							|  |  |  | 	Camera *cam; | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 	Object *ob= base->object; | 
					
						
							| 
									
										
										
										
											2011-09-29 07:59:33 +00:00
										 |  |  | 	float tvec[3]; | 
					
						
							|  |  |  | 	float vec[4][3], asp[2], shift[2], scale[3]; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	int i; | 
					
						
							| 
									
										
										
										
											2010-11-08 02:30:46 +00:00
										 |  |  | 	float drawsize; | 
					
						
							|  |  |  | 	const short is_view= (rv3d->persp==RV3D_CAMOB && ob==v3d->camera); | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 	MovieClip *clip= object_get_movieclip(scene, base->object, 0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* draw data for movie clip set as active for scene */ | 
					
						
							|  |  |  | 	if(clip) | 
					
						
							|  |  |  | 		draw_viewport_reconstruction(scene, base, v3d, clip, flag); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-21 01:30:26 +00:00
										 |  |  | #ifdef VIEW3D_CAMERA_BORDER_HACK
 | 
					
						
							|  |  |  | 	if(is_view && !(G.f & G_PICKSEL)) { | 
					
						
							|  |  |  | 		glGetFloatv(GL_CURRENT_COLOR, view3d_camera_border_hack_col); | 
					
						
							|  |  |  | 		view3d_camera_border_hack_test= TRUE; | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	cam= ob->data; | 
					
						
							| 
									
										
										
										
											2010-07-26 21:35:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-29 07:59:33 +00:00
										 |  |  | 	scale[0]= 1.0f / len_v3(ob->obmat[0]); | 
					
						
							|  |  |  | 	scale[1]= 1.0f / len_v3(ob->obmat[1]); | 
					
						
							|  |  |  | 	scale[2]= 1.0f / len_v3(ob->obmat[2]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	camera_view_frame_ex(scene, cam, cam->drawsize, is_view, scale, | 
					
						
							|  |  |  | 	                     asp, shift, &drawsize, vec); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	glDisable(GL_LIGHTING); | 
					
						
							|  |  |  | 	glDisable(GL_CULL_FACE); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-08 02:30:46 +00:00
										 |  |  | 	/* camera frame */ | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	glBegin(GL_LINE_LOOP); | 
					
						
							| 
									
										
										
										
											2011-09-29 07:59:33 +00:00
										 |  |  | 	glVertex3fv(vec[0]); | 
					
						
							|  |  |  | 	glVertex3fv(vec[1]); | 
					
						
							|  |  |  | 	glVertex3fv(vec[2]); | 
					
						
							|  |  |  | 	glVertex3fv(vec[3]); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-08 02:30:46 +00:00
										 |  |  | 	if(is_view) | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-29 07:59:33 +00:00
										 |  |  | 	zero_v3(tvec); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-08 02:30:46 +00:00
										 |  |  | 	/* center point to camera frame */ | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	glBegin(GL_LINE_STRIP); | 
					
						
							| 
									
										
										
										
											2011-09-29 07:59:33 +00:00
										 |  |  | 	glVertex3fv(vec[1]); | 
					
						
							|  |  |  | 	glVertex3fv(tvec); | 
					
						
							|  |  |  | 	glVertex3fv(vec[0]); | 
					
						
							|  |  |  | 	glVertex3fv(vec[3]); | 
					
						
							|  |  |  | 	glVertex3fv(tvec); | 
					
						
							|  |  |  | 	glVertex3fv(vec[2]); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* arrow on top */ | 
					
						
							| 
									
										
										
										
											2011-09-29 07:59:33 +00:00
										 |  |  | 	tvec[2]= vec[1][2]; /* copy the depth */ | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-08 09:38:48 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	/* draw an outline arrow for inactive cameras and filled
 | 
					
						
							|  |  |  | 	 * for active cameras. We actually draw both outline+filled | 
					
						
							|  |  |  | 	 * for active cameras so the wire can be seen side-on */	 | 
					
						
							|  |  |  | 	for (i=0;i<2;i++) { | 
					
						
							|  |  |  | 		if (i==0) glBegin(GL_LINE_LOOP); | 
					
						
							|  |  |  | 		else if (i==1 && (ob == v3d->camera)) glBegin(GL_TRIANGLES); | 
					
						
							|  |  |  | 		else break; | 
					
						
							| 
									
										
										
										
											2010-10-18 08:11:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-29 07:59:33 +00:00
										 |  |  | 		tvec[0]= shift[0] + ((-0.7f * drawsize) * scale[0]); | 
					
						
							|  |  |  | 		tvec[1]= shift[1] + ((drawsize * (asp[1] + 0.1f)) * scale[1]); | 
					
						
							|  |  |  | 		glVertex3fv(tvec); /* left */ | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2011-09-29 07:59:33 +00:00
										 |  |  | 		tvec[0]= shift[0] + ((0.7f * drawsize) * scale[0]); | 
					
						
							|  |  |  | 		glVertex3fv(tvec); /* right */ | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2011-09-29 07:59:33 +00:00
										 |  |  | 		tvec[0]= shift[0]; | 
					
						
							|  |  |  | 		tvec[1]= shift[1] + ((1.1f * drawsize * (asp[1] + 0.7f)) * scale[1]); | 
					
						
							|  |  |  | 		glVertex3fv(tvec); /* top */ | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 		glEnd(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(flag==0) { | 
					
						
							|  |  |  | 		if(cam->flag & (CAM_SHOWLIMITS+CAM_SHOWMIST)) { | 
					
						
							| 
									
										
										
										
											2010-11-08 02:30:46 +00:00
										 |  |  | 			float nobmat[4][4]; | 
					
						
							|  |  |  | 			World *wrld; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-02-01 15:32:55 +00:00
										 |  |  | 			/* draw in normalized object matrix space */ | 
					
						
							|  |  |  | 			copy_m4_m4(nobmat, ob->obmat); | 
					
						
							|  |  |  | 			normalize_m4(nobmat); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-01 15:32:55 +00:00
										 |  |  | 			glPushMatrix(); | 
					
						
							|  |  |  | 			glLoadMatrixf(rv3d->viewmat); | 
					
						
							|  |  |  | 			glMultMatrixf(nobmat); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			if(cam->flag & CAM_SHOWLIMITS) { | 
					
						
							|  |  |  | 				draw_limit_line(cam->clipsta, cam->clipend, 0x77FFFF); | 
					
						
							|  |  |  | 				/* qdn: was yafray only, now also enabled for Blender to be used with defocus composit node */ | 
					
						
							| 
									
										
										
										
											2011-11-18 15:52:00 +00:00
										 |  |  | 				draw_focus_cross(object_camera_dof_distance(ob), cam->drawsize); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			wrld= scene->world; | 
					
						
							|  |  |  | 			if(cam->flag & CAM_SHOWMIST)  | 
					
						
							|  |  |  | 				if(wrld) draw_limit_line(wrld->miststa, wrld->miststa+wrld->mistdist, 0xFFFFFF); | 
					
						
							|  |  |  | 				 | 
					
						
							| 
									
										
										
										
											2010-02-01 15:32:55 +00:00
										 |  |  | 			glPopMatrix(); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-01 11:44:20 +00:00
										 |  |  | /* flag similar to draw_object() */ | 
					
						
							| 
									
										
										
										
											2011-12-03 20:49:41 +00:00
										 |  |  | static void drawspeaker(Scene *UNUSED(scene), View3D *UNUSED(v3d), RegionView3D *UNUSED(rv3d), | 
					
						
							|  |  |  |                         Object *UNUSED(ob), int UNUSED(flag)) | 
					
						
							| 
									
										
										
										
											2011-08-01 11:44:20 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	//Speaker *spk = ob->data;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	float vec[3]; | 
					
						
							|  |  |  | 	int i, j; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glEnable(GL_BLEND); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-30 09:50:31 +00:00
										 |  |  | 	for(j = 0; j < 3; j++) { | 
					
						
							|  |  |  | 		vec[2] = 0.25f * j -0.125f; | 
					
						
							| 
									
										
										
										
											2011-08-01 11:44:20 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		glBegin(GL_LINE_LOOP); | 
					
						
							| 
									
										
										
										
											2011-08-30 09:50:31 +00:00
										 |  |  | 		for(i = 0; i < 16; i++) { | 
					
						
							| 
									
										
										
										
											2011-11-11 12:00:08 +00:00
										 |  |  | 			vec[0] = cosf((float)M_PI * i / 8.0f) * (j == 0 ? 0.5f : 0.25f); | 
					
						
							|  |  |  | 			vec[1] = sinf((float)M_PI * i / 8.0f) * (j == 0 ? 0.5f : 0.25f); | 
					
						
							| 
									
										
										
										
											2011-08-01 11:44:20 +00:00
										 |  |  | 			glVertex3fv(vec); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		glEnd(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-30 09:50:31 +00:00
										 |  |  | 	for(j = 0; j < 4; j++) { | 
					
						
							|  |  |  | 		vec[0] = (((j + 1) % 2) * (j - 1)) * 0.5f; | 
					
						
							|  |  |  | 		vec[1] = ((j % 2) * (j - 2)) * 0.5f; | 
					
						
							| 
									
										
										
										
											2011-08-01 11:44:20 +00:00
										 |  |  | 		glBegin(GL_LINE_STRIP); | 
					
						
							| 
									
										
										
										
											2011-08-30 09:50:31 +00:00
										 |  |  | 		for(i = 0; i < 3; i++) { | 
					
						
							|  |  |  | 			if(i == 1) { | 
					
						
							|  |  |  | 				vec[0] *= 0.5f; | 
					
						
							|  |  |  | 				vec[1] *= 0.5f; | 
					
						
							| 
									
										
										
										
											2011-08-01 11:44:20 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-30 09:50:31 +00:00
										 |  |  | 			vec[2] = 0.25f * i -0.125f; | 
					
						
							| 
									
										
										
										
											2011-08-01 11:44:20 +00:00
										 |  |  | 			glVertex3fv(vec); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		glEnd(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glDisable(GL_BLEND); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | static void lattice_draw_verts(Lattice *lt, DispList *dl, short sel) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	BPoint *bp = lt->def; | 
					
						
							|  |  |  | 	float *co = dl?dl->verts:NULL; | 
					
						
							|  |  |  | 	int u, v, w; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	UI_ThemeColor(sel?TH_VERTEX_SELECT:TH_VERTEX); | 
					
						
							|  |  |  | 	glPointSize(UI_GetThemeValuef(TH_VERTEX_SIZE)); | 
					
						
							|  |  |  | 	bglBegin(GL_POINTS); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for(w=0; w<lt->pntsw; w++) { | 
					
						
							|  |  |  | 		int wxt = (w==0 || w==lt->pntsw-1); | 
					
						
							|  |  |  | 		for(v=0; v<lt->pntsv; v++) { | 
					
						
							|  |  |  | 			int vxt = (v==0 || v==lt->pntsv-1); | 
					
						
							|  |  |  | 			for(u=0; u<lt->pntsu; u++, bp++, co+=3) { | 
					
						
							|  |  |  | 				int uxt = (u==0 || u==lt->pntsu-1); | 
					
						
							|  |  |  | 				if(!(lt->flag & LT_OUTSIDE) || uxt || vxt || wxt) { | 
					
						
							|  |  |  | 					if(bp->hide==0) { | 
					
						
							|  |  |  | 						if((bp->f1 & SELECT)==sel) { | 
					
						
							|  |  |  | 							bglVertex3fv(dl?co:bp->vec); | 
					
						
							|  |  |  | 						} | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	glPointSize(1.0); | 
					
						
							|  |  |  | 	bglEnd();	 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-30 16:03:29 +00:00
										 |  |  | void lattice_foreachScreenVert(ViewContext *vc, void (*func)(void *userData, BPoint *bp, int x, int y), void *userData) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 	Object *obedit= vc->obedit; | 
					
						
							|  |  |  | 	Lattice *lt= obedit->data; | 
					
						
							| 
									
										
										
										
											2010-08-10 06:36:42 +00:00
										 |  |  | 	BPoint *bp = lt->editlatt->latt->def; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 	DispList *dl = find_displist(&obedit->disp, DL_VERTS); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	float *co = dl?dl->verts:NULL; | 
					
						
							| 
									
										
										
										
											2010-08-10 06:36:42 +00:00
										 |  |  | 	int i, N = lt->editlatt->latt->pntsu*lt->editlatt->latt->pntsv*lt->editlatt->latt->pntsw; | 
					
						
							| 
									
										
										
										
											2009-02-18 05:49:51 +00:00
										 |  |  | 	short s[2] = {IS_CLIPPED, 0}; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-21 16:44:05 +00:00
										 |  |  | 	ED_view3d_local_clipping(vc->rv3d, obedit->obmat); /* for local clipping lookups */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	for (i=0; i<N; i++, bp++, co+=3) { | 
					
						
							|  |  |  | 		if (bp->hide==0) { | 
					
						
							| 
									
										
										
										
											2009-11-21 16:44:05 +00:00
										 |  |  | 			view3d_project_short_clip(vc->ar, dl?co:bp->vec, s, 1); | 
					
						
							| 
									
										
										
										
											2009-02-18 05:49:51 +00:00
										 |  |  | 			if (s[0] != IS_CLIPPED) | 
					
						
							|  |  |  | 				func(userData, bp, s[0], s[1]); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void drawlattice__point(Lattice *lt, DispList *dl, int u, int v, int w, int use_wcol) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	int index = ((w*lt->pntsv + v)*lt->pntsu) + u; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(use_wcol) { | 
					
						
							|  |  |  | 		float col[3]; | 
					
						
							| 
									
										
										
										
											2010-01-26 17:07:47 +00:00
										 |  |  | 		MDeformWeight *mdw= defvert_find_index (lt->dvert+index, use_wcol-1); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2011-11-26 03:13:54 +00:00
										 |  |  | 		weight_to_rgb(col, mdw?mdw->weight:0.0f); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		glColor3fv(col); | 
					
						
							| 
									
										
										
										
											2009-01-24 13:45:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (dl) { | 
					
						
							|  |  |  | 		glVertex3fv(&dl->verts[index*3]); | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		glVertex3fv(lt->def[index].vec); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* lattice color is hardcoded, now also shows weightgroup values in edit mode */ | 
					
						
							| 
									
										
										
										
											2009-01-04 14:14:06 +00:00
										 |  |  | static void drawlattice(Scene *scene, View3D *v3d, Object *ob) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-01-02 19:10:35 +00:00
										 |  |  | 	Lattice *lt= ob->data; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	DispList *dl; | 
					
						
							|  |  |  | 	int u, v, w; | 
					
						
							| 
									
										
										
										
											2010-04-21 14:46:32 +00:00
										 |  |  | 	int use_wcol= 0, is_edit= (lt->editlatt != NULL); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* now we default make displist, this will modifiers work for non animated case */ | 
					
						
							|  |  |  | 	if(ob->disp.first==NULL) | 
					
						
							| 
									
										
										
										
											2009-01-04 14:14:06 +00:00
										 |  |  | 		lattice_calc_modifiers(scene, ob); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	dl= find_displist(&ob->disp, DL_VERTS); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-04-21 14:46:32 +00:00
										 |  |  | 	if(is_edit) { | 
					
						
							| 
									
										
										
										
											2010-08-10 06:36:42 +00:00
										 |  |  | 		lt= lt->editlatt->latt; | 
					
						
							| 
									
										
										
										
											2010-04-21 14:46:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		cpack(0x004000); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		if(ob->defbase.first && lt->dvert) { | 
					
						
							|  |  |  | 			use_wcol= ob->actdef; | 
					
						
							|  |  |  | 			glShadeModel(GL_SMOOTH); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	glBegin(GL_LINES); | 
					
						
							|  |  |  | 	for(w=0; w<lt->pntsw; w++) { | 
					
						
							|  |  |  | 		int wxt = (w==0 || w==lt->pntsw-1); | 
					
						
							|  |  |  | 		for(v=0; v<lt->pntsv; v++) { | 
					
						
							|  |  |  | 			int vxt = (v==0 || v==lt->pntsv-1); | 
					
						
							|  |  |  | 			for(u=0; u<lt->pntsu; u++) { | 
					
						
							|  |  |  | 				int uxt = (u==0 || u==lt->pntsu-1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				if(w && ((uxt || vxt) || !(lt->flag & LT_OUTSIDE))) { | 
					
						
							|  |  |  | 					drawlattice__point(lt, dl, u, v, w-1, use_wcol); | 
					
						
							|  |  |  | 					drawlattice__point(lt, dl, u, v, w, use_wcol); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				if(v && ((uxt || wxt) || !(lt->flag & LT_OUTSIDE))) { | 
					
						
							|  |  |  | 					drawlattice__point(lt, dl, u, v-1, w, use_wcol); | 
					
						
							|  |  |  | 					drawlattice__point(lt, dl, u, v, w, use_wcol); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				if(u && ((vxt || wxt) || !(lt->flag & LT_OUTSIDE))) { | 
					
						
							|  |  |  | 					drawlattice__point(lt, dl, u-1, v, w, use_wcol); | 
					
						
							|  |  |  | 					drawlattice__point(lt, dl, u, v, w, use_wcol); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	}		 | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* restoration for weight colors */ | 
					
						
							|  |  |  | 	if(use_wcol) | 
					
						
							|  |  |  | 		glShadeModel(GL_FLAT); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-21 14:46:32 +00:00
										 |  |  | 	if(is_edit) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		if(v3d->zbuf) glDisable(GL_DEPTH_TEST); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		lattice_draw_verts(lt, dl, 0); | 
					
						
							|  |  |  | 		lattice_draw_verts(lt, dl, 1); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		if(v3d->zbuf) glEnable(GL_DEPTH_TEST);  | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ***************** ******************** */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | /* Note! - foreach funcs should be called while drawing or directly after
 | 
					
						
							|  |  |  |  * if not, ED_view3d_init_mats_rv3d() can be used for selection tools | 
					
						
							|  |  |  |  * but would not give correct results with dupli's for eg. which dont | 
					
						
							|  |  |  |  * use the object matrix in the useual way */ | 
					
						
							| 
									
										
										
										
											2010-10-14 01:22:14 +00:00
										 |  |  | static void mesh_foreachScreenVert__mapFunc(void *userData, int index, float *co, float *UNUSED(no_f), short *UNUSED(no_s)) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-12-20 08:47:36 +00:00
										 |  |  | 	foreachScreenVert_userData *data = userData; | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	BMVert *eve = EDBM_get_vert_for_index(data->vc.em, index); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 	if (!BM_elem_flag_test(eve, BM_ELEM_HIDDEN)) { | 
					
						
							| 
									
										
										
										
											2009-02-18 04:43:12 +00:00
										 |  |  | 		short s[2]= {IS_CLIPPED, 0}; | 
					
						
							| 
									
										
										
										
											2009-03-17 21:44:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-28 16:44:17 +00:00
										 |  |  | 		if (data->clipVerts != V3D_CLIP_TEST_OFF) { | 
					
						
							| 
									
										
										
										
											2009-11-21 16:44:05 +00:00
										 |  |  | 			view3d_project_short_clip(data->vc.ar, co, s, 1); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} else { | 
					
						
							| 
									
										
										
										
											2011-08-16 20:00:56 +00:00
										 |  |  | 			float co2[2]; | 
					
						
							|  |  |  | 			mul_v3_m4v3(co2, data->vc.obedit->obmat, co); | 
					
						
							| 
									
										
										
										
											2009-08-06 21:22:42 +00:00
										 |  |  | 			project_short_noclip(data->vc.ar, co2, s); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-17 21:44:58 +00:00
										 |  |  | 		if (s[0]!=IS_CLIPPED) | 
					
						
							|  |  |  | 			data->func(data->userData, eve, s[0], s[1], index); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2008-12-19 17:14:02 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-03 20:49:41 +00:00
										 |  |  | void mesh_foreachScreenVert( | 
					
						
							|  |  |  |         ViewContext *vc, | 
					
						
							| 
									
										
										
										
											2011-12-03 21:01:26 +00:00
										 |  |  |         void (*func)(void *userData, BMVert *eve, int x, int y, int index), | 
					
						
							| 
									
										
										
										
											2011-12-03 20:49:41 +00:00
										 |  |  |         void *userData, eV3DClipTest clipVerts) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-12-20 08:47:36 +00:00
										 |  |  | 	foreachScreenVert_userData data; | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	DerivedMesh *dm = editbmesh_get_derived_cage(vc->scene, vc->obedit, vc->em, CD_MASK_BAREMESH); | 
					
						
							| 
									
										
										
										
											2008-12-30 13:16:14 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2008-12-30 16:03:29 +00:00
										 |  |  | 	data.vc= *vc; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	data.func = func; | 
					
						
							|  |  |  | 	data.userData = userData; | 
					
						
							|  |  |  | 	data.clipVerts = clipVerts; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-28 16:44:17 +00:00
										 |  |  | 	if(clipVerts != V3D_CLIP_TEST_OFF) | 
					
						
							| 
									
										
										
										
											2009-11-21 16:44:05 +00:00
										 |  |  | 		ED_view3d_local_clipping(vc->rv3d, vc->obedit->obmat); /* for local clipping lookups */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-04 23:13:28 +00:00
										 |  |  | 	EDBM_init_index_arrays(vc->em, 1, 0, 0); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	dm->foreachMappedVert(dm, mesh_foreachScreenVert__mapFunc, &data); | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	EDBM_free_index_arrays(vc->em); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	dm->release(dm); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-18 17:10:28 +00:00
										 |  |  | /*  draw callback */ | 
					
						
							| 
									
										
										
										
											2011-09-19 02:43:03 +00:00
										 |  |  | static void drawSelectedVertices__mapFunc(void *userData, int index, float *co, float *UNUSED(no_f), short *UNUSED(no_s)) | 
					
						
							| 
									
										
										
										
											2011-09-18 01:09:18 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-09-19 02:43:03 +00:00
										 |  |  | 	MVert *mv = &((MVert *)userData)[index]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-18 01:09:18 +00:00
										 |  |  | 	if(!(mv->flag & ME_HIDE)) { | 
					
						
							| 
									
										
										
										
											2011-09-19 02:43:03 +00:00
										 |  |  | 		const char sel= mv->flag & SELECT; | 
					
						
							| 
									
										
										
										
											2011-09-18 01:09:18 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		// TODO define selected color
 | 
					
						
							|  |  |  | 		if(sel) { | 
					
						
							|  |  |  | 			glColor3f(1.0f, 1.0f, 0.0f); | 
					
						
							| 
									
										
										
										
											2011-09-19 02:43:03 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2011-09-18 01:09:18 +00:00
										 |  |  | 			glColor3f(0.0f, 0.0f, 0.0f); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		glVertex3fv(co); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2011-09-18 17:10:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-28 05:53:40 +00:00
										 |  |  | static void drawSelectedVertices(DerivedMesh *dm, Mesh *me) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-09-18 01:09:18 +00:00
										 |  |  | 	glBegin(GL_POINTS); | 
					
						
							|  |  |  | 	dm->foreachMappedVert(dm, drawSelectedVertices__mapFunc, me->mvert); | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2011-11-28 16:44:17 +00:00
										 |  |  | static int is_co_in_region(ARegion *ar, const short co[2]) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return ( (co[0] != IS_CLIPPED) && /* may be the only initialized value, check first */ | 
					
						
							|  |  |  | 	         (co[0] >= 0)          && | 
					
						
							|  |  |  | 	         (co[0] <  ar->winx)   && | 
					
						
							|  |  |  | 	         (co[1] >= 0)          && | 
					
						
							|  |  |  | 	         (co[1] <  ar->winy)); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | static void mesh_foreachScreenEdge__mapFunc(void *userData, int index, float *v0co, float *v1co) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-12-20 08:47:36 +00:00
										 |  |  | 	foreachScreenEdge_userData *data = userData; | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	BMEdge *eed = EDBM_get_edge_for_index(data->vc.em, index); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 	if (!BM_elem_flag_test(eed, BM_ELEM_HIDDEN)) { | 
					
						
							| 
									
										
										
										
											2011-08-16 20:00:56 +00:00
										 |  |  | 		short s[2][2]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-28 16:44:17 +00:00
										 |  |  | 		if (data->clipVerts == V3D_CLIP_TEST_RV3D_CLIPPING) { | 
					
						
							| 
									
										
										
										
											2009-11-21 16:44:05 +00:00
										 |  |  | 			view3d_project_short_clip(data->vc.ar, v0co, s[0], 1); | 
					
						
							|  |  |  | 			view3d_project_short_clip(data->vc.ar, v1co, s[1], 1); | 
					
						
							| 
									
										
										
										
											2011-11-28 16:44:17 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2011-08-16 20:00:56 +00:00
										 |  |  | 			float v1_co[3], v2_co[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			mul_v3_m4v3(v1_co, data->vc.obedit->obmat, v0co); | 
					
						
							|  |  |  | 			mul_v3_m4v3(v2_co, data->vc.obedit->obmat, v1co); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-06 21:22:42 +00:00
										 |  |  | 			project_short_noclip(data->vc.ar, v1_co, s[0]); | 
					
						
							|  |  |  | 			project_short_noclip(data->vc.ar, v2_co, s[1]); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-28 16:44:17 +00:00
										 |  |  | 			if (data->clipVerts == V3D_CLIP_TEST_REGION) { | 
					
						
							|  |  |  | 				if ( !is_co_in_region(data->vc.ar, s[0]) && | 
					
						
							|  |  |  | 				     !is_co_in_region(data->vc.ar, s[1])) | 
					
						
							|  |  |  | 				{ | 
					
						
							|  |  |  | 					return; | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		data->func(data->userData, eed, s[0][0], s[0][1], s[1][0], s[1][1], index); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2008-12-20 18:43:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-03 20:49:41 +00:00
										 |  |  | void mesh_foreachScreenEdge( | 
					
						
							|  |  |  |         ViewContext *vc, | 
					
						
							| 
									
										
										
										
											2011-12-03 21:01:26 +00:00
										 |  |  |         void (*func)(void *userData, BMEdge *eed, int x0, int y0, int x1, int y1, int index), | 
					
						
							| 
									
										
										
										
											2011-12-03 20:49:41 +00:00
										 |  |  |         void *userData, eV3DClipTest clipVerts) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-12-20 08:47:36 +00:00
										 |  |  | 	foreachScreenEdge_userData data; | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	DerivedMesh *dm = editbmesh_get_derived_cage(vc->scene, vc->obedit, vc->em, CD_MASK_BAREMESH); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-30 16:03:29 +00:00
										 |  |  | 	data.vc= *vc; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	data.func = func; | 
					
						
							|  |  |  | 	data.userData = userData; | 
					
						
							|  |  |  | 	data.clipVerts = clipVerts; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-28 16:44:17 +00:00
										 |  |  | 	if(clipVerts != V3D_CLIP_TEST_OFF) | 
					
						
							| 
									
										
										
										
											2009-11-21 16:44:05 +00:00
										 |  |  | 		ED_view3d_local_clipping(vc->rv3d, vc->obedit->obmat); /* for local clipping lookups */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-04 23:13:28 +00:00
										 |  |  | 	EDBM_init_index_arrays(vc->em, 0, 1, 0); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	dm->foreachMappedEdge(dm, mesh_foreachScreenEdge__mapFunc, &data); | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	EDBM_free_index_arrays(vc->em); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	dm->release(dm); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-14 01:22:14 +00:00
										 |  |  | static void mesh_foreachScreenFace__mapFunc(void *userData, int index, float *cent, float *UNUSED(no)) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-12-20 08:47:36 +00:00
										 |  |  | 	foreachScreenFace_userData *data = userData; | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	BMFace *efa = EDBM_get_face_for_index(data->vc.em, index); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 	if (efa && !BM_elem_flag_test(efa, BM_ELEM_HIDDEN)) { | 
					
						
							| 
									
										
										
										
											2011-08-16 20:00:56 +00:00
										 |  |  | 		float cent2[3]; | 
					
						
							|  |  |  | 		short s[2]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		mul_v3_m4v3(cent2, data->vc.obedit->obmat, cent); | 
					
						
							| 
									
										
										
										
											2009-08-15 17:31:28 +00:00
										 |  |  | 		project_short(data->vc.ar, cent2, s); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-16 20:00:56 +00:00
										 |  |  | 		if (s[0] != IS_CLIPPED) { | 
					
						
							|  |  |  | 			data->func(data->userData, efa, s[0], s[1], index); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2008-12-20 18:43:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-03 20:49:41 +00:00
										 |  |  | void mesh_foreachScreenFace( | 
					
						
							|  |  |  |         ViewContext *vc, | 
					
						
							| 
									
										
										
										
											2011-12-03 21:01:26 +00:00
										 |  |  |         void (*func)(void *userData, BMFace *efa, int x, int y, int index), | 
					
						
							| 
									
										
										
										
											2011-12-03 20:49:41 +00:00
										 |  |  |         void *userData) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-12-20 08:47:36 +00:00
										 |  |  | 	foreachScreenFace_userData data; | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	DerivedMesh *dm = editbmesh_get_derived_cage(vc->scene, vc->obedit, vc->em, CD_MASK_BAREMESH); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-30 16:03:29 +00:00
										 |  |  | 	data.vc= *vc; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	data.func = func; | 
					
						
							|  |  |  | 	data.userData = userData; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-21 16:44:05 +00:00
										 |  |  | 	//if(clipVerts)
 | 
					
						
							|  |  |  | 	ED_view3d_local_clipping(vc->rv3d, vc->obedit->obmat); /* for local clipping lookups */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-04 23:13:28 +00:00
										 |  |  | 	EDBM_init_index_arrays(vc->em, 0, 0, 1); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	dm->foreachMappedFaceCenter(dm, mesh_foreachScreenFace__mapFunc, &data); | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	EDBM_free_index_arrays(vc->em); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	dm->release(dm); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-03 20:49:41 +00:00
										 |  |  | void nurbs_foreachScreenVert( | 
					
						
							|  |  |  |         ViewContext *vc, | 
					
						
							|  |  |  |         void (*func)(void *userData, Nurb *nu, BPoint *bp, BezTriple *bezt, int beztindex, int x, int y), | 
					
						
							|  |  |  |         void *userData) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-01-14 12:26:45 +00:00
										 |  |  | 	Curve *cu= vc->obedit->data; | 
					
						
							| 
									
										
										
										
											2009-02-18 05:49:51 +00:00
										 |  |  | 	short s[2] = {IS_CLIPPED, 0}; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	Nurb *nu; | 
					
						
							|  |  |  | 	int i; | 
					
						
							| 
									
										
										
										
											2011-09-14 00:37:27 +00:00
										 |  |  | 	ListBase *nurbs= curve_editnurbs(cu); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-21 16:44:05 +00:00
										 |  |  | 	ED_view3d_local_clipping(vc->rv3d, vc->obedit->obmat); /* for local clipping lookups */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-25 11:57:36 +00:00
										 |  |  | 	for (nu= nurbs->first; nu; nu=nu->next) { | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 		if(nu->type == CU_BEZIER) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			for (i=0; i<nu->pntsu; i++) { | 
					
						
							|  |  |  | 				BezTriple *bezt = &nu->bezt[i]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				if(bezt->hide==0) { | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 					 | 
					
						
							|  |  |  | 					if(cu->drawflag & CU_HIDE_HANDLES) { | 
					
						
							| 
									
										
										
										
											2009-11-21 16:44:05 +00:00
										 |  |  | 						view3d_project_short_clip(vc->ar, bezt->vec[1], s, 1); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 						if (s[0] != IS_CLIPPED) | 
					
						
							|  |  |  | 							func(userData, nu, NULL, bezt, 1, s[0], s[1]); | 
					
						
							|  |  |  | 					} else { | 
					
						
							| 
									
										
										
										
											2009-11-21 16:44:05 +00:00
										 |  |  | 						view3d_project_short_clip(vc->ar, bezt->vec[0], s, 1); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 						if (s[0] != IS_CLIPPED) | 
					
						
							|  |  |  | 							func(userData, nu, NULL, bezt, 0, s[0], s[1]); | 
					
						
							| 
									
										
										
										
											2009-11-21 16:44:05 +00:00
										 |  |  | 						view3d_project_short_clip(vc->ar, bezt->vec[1], s, 1); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 						if (s[0] != IS_CLIPPED) | 
					
						
							|  |  |  | 							func(userData, nu, NULL, bezt, 1, s[0], s[1]); | 
					
						
							| 
									
										
										
										
											2009-11-21 16:44:05 +00:00
										 |  |  | 						view3d_project_short_clip(vc->ar, bezt->vec[2], s, 1); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 						if (s[0] != IS_CLIPPED) | 
					
						
							|  |  |  | 							func(userData, nu, NULL, bezt, 2, s[0], s[1]); | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							|  |  |  | 			for (i=0; i<nu->pntsu*nu->pntsv; i++) { | 
					
						
							|  |  |  | 				BPoint *bp = &nu->bp[i]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				if(bp->hide==0) { | 
					
						
							| 
									
										
										
										
											2009-11-21 16:44:05 +00:00
										 |  |  | 					view3d_project_short_clip(vc->ar, bp->vec, s, 1); | 
					
						
							| 
									
										
										
										
											2009-02-18 05:49:51 +00:00
										 |  |  | 					if (s[0] != IS_CLIPPED) | 
					
						
							|  |  |  | 						func(userData, nu, bp, NULL, -1, s[0], s[1]); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************** DRAW MESH ****************** */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* First section is all the "simple" draw routines, 
 | 
					
						
							|  |  |  |  * ones that just pass some sort of primitive to GL, | 
					
						
							|  |  |  |  * with perhaps various options to control lighting, | 
					
						
							|  |  |  |  * color, etc. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * These routines should not have user interface related | 
					
						
							|  |  |  |  * logic!!! | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void draw_dm_face_normals__mapFunc(void *userData, int index, float *cent, float *no) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-01-24 19:57:34 +00:00
										 |  |  | 	drawDMNormal_userData *data = userData; | 
					
						
							| 
									
										
										
										
											2012-01-24 20:19:09 +00:00
										 |  |  | 	BMFace *efa = EDBM_get_face_for_index(data->em, index); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 	if (!BM_elem_flag_test(efa, BM_ELEM_HIDDEN)) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		glVertex3fv(cent); | 
					
						
							| 
									
										
										
										
											2012-01-24 19:57:34 +00:00
										 |  |  | 		glVertex3f(cent[0] + no[0] * data->normalsize, | 
					
						
							|  |  |  | 		           cent[1] + no[1] * data->normalsize, | 
					
						
							|  |  |  | 		           cent[2] + no[2] * data->normalsize); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-09-04 02:16:08 +00:00
										 |  |  | static void draw_dm_face_normals(BMEditMesh *em, Scene *scene, DerivedMesh *dm)  | 
					
						
							| 
									
										
										
										
											2008-12-19 17:14:02 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-01-24 19:57:34 +00:00
										 |  |  | 	drawDMNormal_userData data; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-24 20:19:09 +00:00
										 |  |  | 	data.em = em; | 
					
						
							| 
									
										
										
										
											2012-01-24 19:57:34 +00:00
										 |  |  | 	data.normalsize = scene->toolsettings->normalsize; | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	glBegin(GL_LINES); | 
					
						
							| 
									
										
										
										
											2012-01-24 19:57:34 +00:00
										 |  |  | 	dm->foreachMappedFaceCenter(dm, draw_dm_face_normals__mapFunc, &data); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	glEnd(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-14 01:22:14 +00:00
										 |  |  | static void draw_dm_face_centers__mapFunc(void *userData, int index, float *cent, float *UNUSED(no)) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	BMFace *efa = EDBM_get_face_for_index(((void **)userData)[0], index); | 
					
						
							|  |  |  | 	int sel = *(((int **)userData)[1]); | 
					
						
							| 
									
										
										
										
											2011-06-01 19:30:19 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 	if (efa && !BM_elem_flag_test(efa, BM_ELEM_HIDDEN) && BM_elem_flag_test(efa, BM_ELEM_SELECT)==sel) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		bglVertex3fv(cent); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-05-18 08:46:04 +00:00
										 |  |  | static void draw_dm_face_centers(BMEditMesh *em, DerivedMesh *dm, int sel) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	void *ptrs[2] = {em, &sel}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	bglBegin(GL_POINTS); | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	dm->foreachMappedFaceCenter(dm, draw_dm_face_centers__mapFunc, ptrs); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	bglEnd(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void draw_dm_vert_normals__mapFunc(void *userData, int index, float *co, float *no_f, short *no_s) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-01-24 19:57:34 +00:00
										 |  |  | 	drawDMNormal_userData *data = userData; | 
					
						
							| 
									
										
										
										
											2012-01-24 20:19:09 +00:00
										 |  |  | 	BMVert *eve = EDBM_get_vert_for_index(data->em, index); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 	if (!BM_elem_flag_test(eve, BM_ELEM_HIDDEN)) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		glVertex3fv(co); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (no_f) { | 
					
						
							| 
									
										
										
										
											2012-01-24 19:57:34 +00:00
										 |  |  | 			glVertex3f(co[0] + no_f[0] * data->normalsize, | 
					
						
							|  |  |  | 			           co[1] + no_f[1] * data->normalsize, | 
					
						
							|  |  |  | 			           co[2] + no_f[2] * data->normalsize); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							|  |  |  | 			glVertex3f(co[0] + no_s[0] * (data->normalsize / 32767.0f), | 
					
						
							|  |  |  | 			           co[1] + no_s[1] * (data->normalsize / 32767.0f), | 
					
						
							|  |  |  | 			           co[2] + no_s[2] * (data->normalsize / 32767.0f)); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-05-18 08:46:04 +00:00
										 |  |  | static void draw_dm_vert_normals(BMEditMesh *em, Scene *scene, DerivedMesh *dm)  | 
					
						
							| 
									
										
										
										
											2008-12-19 17:14:02 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-01-24 19:57:34 +00:00
										 |  |  | 	drawDMNormal_userData data; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-24 20:19:09 +00:00
										 |  |  | 	data.em = em; | 
					
						
							| 
									
										
										
										
											2012-01-24 19:57:34 +00:00
										 |  |  | 	data.normalsize = scene->toolsettings->normalsize; | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	glBegin(GL_LINES); | 
					
						
							| 
									
										
										
										
											2012-01-24 19:57:34 +00:00
										 |  |  | 	dm->foreachMappedVert(dm, draw_dm_vert_normals__mapFunc, &data); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	glEnd(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-12 01:55:08 +00:00
										 |  |  | /* Draw verts with color set based on selection */ | 
					
						
							| 
									
										
										
										
											2010-10-14 01:22:14 +00:00
										 |  |  | static void draw_dm_verts__mapFunc(void *userData, int index, float *co, float *UNUSED(no_f), short *UNUSED(no_s)) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-12-20 08:47:36 +00:00
										 |  |  | 	drawDMVerts_userData * data = userData; | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	BMVert *eve = EDBM_get_vert_for_index(data->em, index); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 	if (!BM_elem_flag_test(eve, BM_ELEM_HIDDEN) && BM_elem_flag_test(eve, BM_ELEM_SELECT)==data->sel) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		/* draw active larger - need to stop/start point drawing for this :/ */ | 
					
						
							|  |  |  | 		if (eve==data->eve_act) { | 
					
						
							|  |  |  | 			float size = UI_GetThemeValuef(TH_VERTEX_SIZE); | 
					
						
							|  |  |  | 			UI_ThemeColor4(TH_EDITMESH_ACTIVE); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			bglEnd(); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			glPointSize(size); | 
					
						
							|  |  |  | 			bglBegin(GL_POINTS); | 
					
						
							|  |  |  | 			bglVertex3fv(co); | 
					
						
							|  |  |  | 			bglEnd(); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			UI_ThemeColor4(data->sel?TH_VERTEX_SELECT:TH_VERTEX); | 
					
						
							|  |  |  | 			glPointSize(size); | 
					
						
							|  |  |  | 			bglBegin(GL_POINTS); | 
					
						
							|  |  |  | 		} else { | 
					
						
							|  |  |  | 			bglVertex3fv(co); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-18 08:46:04 +00:00
										 |  |  | static void draw_dm_verts(BMEditMesh *em, DerivedMesh *dm, int sel, BMVert *eve_act) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-12-20 08:47:36 +00:00
										 |  |  | 	drawDMVerts_userData data; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	data.sel = sel; | 
					
						
							|  |  |  | 	data.eve_act = eve_act; | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	data.em = em; | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-08 17:53:17 +00:00
										 |  |  | 	bglBegin(GL_POINTS); | 
					
						
							|  |  |  | 	dm->foreachMappedVert(dm, draw_dm_verts__mapFunc, &data); | 
					
						
							|  |  |  | 	bglEnd(); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Draw edges with color set based on selection */ | 
					
						
							|  |  |  | static int draw_dm_edges_sel__setDrawOptions(void *userData, int index) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	BMEdge *eed; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	//unsigned char **cols = userData, *col;
 | 
					
						
							| 
									
										
										
										
											2011-12-20 08:47:36 +00:00
										 |  |  | 	drawDMEdgesSel_userData * data = userData; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	unsigned char *col; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	eed = EDBM_get_edge_for_index(data->em, index); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 	if (!BM_elem_flag_test(eed, BM_ELEM_HIDDEN)) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		if (eed==data->eed_act) { | 
					
						
							|  |  |  | 			glColor4ubv(data->actCol); | 
					
						
							|  |  |  | 		} else { | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 			if (BM_elem_flag_test(eed, BM_ELEM_SELECT)) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				col = data->selCol; | 
					
						
							|  |  |  | 			} else { | 
					
						
							|  |  |  | 				col = data->baseCol; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			/* no alpha, this is used so a transparent color can disable drawing unselected edges in editmode  */ | 
					
						
							|  |  |  | 			if (col[3]==0) return 0; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			glColor4ubv(col); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		return 1; | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-05-18 08:46:04 +00:00
										 |  |  | static void draw_dm_edges_sel(BMEditMesh *em, DerivedMesh *dm, unsigned char *baseCol,  | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 			      unsigned char *selCol, unsigned char *actCol, BMEdge *eed_act)  | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-12-20 08:47:36 +00:00
										 |  |  | 	drawDMEdgesSel_userData data; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	data.baseCol = baseCol; | 
					
						
							|  |  |  | 	data.selCol = selCol; | 
					
						
							|  |  |  | 	data.actCol = actCol; | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	data.em = em; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	data.eed_act = eed_act; | 
					
						
							|  |  |  | 	dm->drawMappedEdges(dm, draw_dm_edges_sel__setDrawOptions, &data); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Draw edges */ | 
					
						
							|  |  |  | static int draw_dm_edges__setDrawOptions(void *userData, int index) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 	return !BM_elem_flag_test(EDBM_get_edge_for_index(userData, index), BM_ELEM_HIDDEN); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2009-05-18 08:46:04 +00:00
										 |  |  | static void draw_dm_edges(BMEditMesh *em, DerivedMesh *dm)  | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	dm->drawMappedEdges(dm, draw_dm_edges__setDrawOptions, em); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Draw edges with color interpolated based on selection */ | 
					
						
							|  |  |  | static int draw_dm_edges_sel_interp__setDrawOptions(void *userData, int index) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 	return !BM_elem_flag_test(EDBM_get_edge_for_index(((void**)userData)[0], index), BM_ELEM_HIDDEN); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | } | 
					
						
							|  |  |  | static void draw_dm_edges_sel_interp__setDrawInterpOptions(void *userData, int index, float t) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 	BMEdge *eed = EDBM_get_edge_for_index(((void**)userData)[0], index); | 
					
						
							|  |  |  | 	unsigned char **cols = userData; | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 	unsigned char *col0 = cols[(BM_elem_flag_test(eed->v1, BM_ELEM_SELECT))?2:1]; | 
					
						
							|  |  |  | 	unsigned char *col1 = cols[(BM_elem_flag_test(eed->v2, BM_ELEM_SELECT))?2:1]; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	glColor4ub(	col0[0] + (col1[0]-col0[0])*t, | 
					
						
							|  |  |  | 				col0[1] + (col1[1]-col0[1])*t, | 
					
						
							|  |  |  | 				col0[2] + (col1[2]-col0[2])*t, | 
					
						
							|  |  |  | 				col0[3] + (col1[3]-col0[3])*t); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | static void draw_dm_edges_sel_interp(BMEditMesh *em, DerivedMesh *dm, unsigned char *baseCol, unsigned char *selCol) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-04-13 22:30:25 +00:00
										 |  |  | 	void *cols[3] = {em, baseCol, selCol}; | 
					
						
							| 
									
										
										
										
											2010-01-08 17:53:17 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	dm->drawMappedEdgesInterp(dm, draw_dm_edges_sel_interp__setDrawOptions, draw_dm_edges_sel_interp__setDrawInterpOptions, cols); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Draw only seam edges */ | 
					
						
							|  |  |  | static int draw_dm_edges_seams__setDrawOptions(void *userData, int index) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	BMEdge *eed = EDBM_get_edge_for_index(userData, index); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 	return !BM_elem_flag_test(eed, BM_ELEM_HIDDEN) && BM_elem_flag_test(eed, BM_ELEM_SEAM); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-18 08:46:04 +00:00
										 |  |  | static void draw_dm_edges_seams(BMEditMesh *em, DerivedMesh *dm) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	dm->drawMappedEdges(dm, draw_dm_edges_seams__setDrawOptions, em); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Draw only sharp edges */ | 
					
						
							|  |  |  | static int draw_dm_edges_sharp__setDrawOptions(void *userData, int index) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	BMEdge *eed = EDBM_get_edge_for_index(userData, index); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-18 11:44:30 +00:00
										 |  |  | 	return !BM_elem_flag_test(eed, BM_ELEM_HIDDEN) && !BM_elem_flag_test(eed, BM_ELEM_SMOOTH); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2009-05-18 08:46:04 +00:00
										 |  |  | static void draw_dm_edges_sharp(BMEditMesh *em, DerivedMesh *dm) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	dm->drawMappedEdges(dm, draw_dm_edges_sharp__setDrawOptions, em); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Draw faces with color set based on selection
 | 
					
						
							|  |  |  | 	 * return 2 for the active face so it renders with stipple enabled */ | 
					
						
							| 
									
										
										
										
											2010-10-14 01:22:14 +00:00
										 |  |  | static int draw_dm_faces_sel__setDrawOptions(void *userData, int index, int *UNUSED(drawSmooth_r)) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-12-20 08:47:36 +00:00
										 |  |  | 	drawDMFacesSel_userData * data = userData; | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	BMFace *efa = EDBM_get_face_for_index(data->em, index); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	unsigned char *col; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2011-02-23 00:01:50 +00:00
										 |  |  | 	if (!efa) | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 	if (!BM_elem_flag_test(efa, BM_ELEM_HIDDEN)) { | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 		if (efa == data->efa_act) { | 
					
						
							| 
									
										
										
										
											2011-05-12 01:55:08 +00:00
										 |  |  | 			glColor4ubv(data->cols[2]); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			return 2; /* stipple */ | 
					
						
							|  |  |  | 		} else { | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 			col = data->cols[BM_elem_flag_test(efa, BM_ELEM_SELECT)?1:0]; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			if (col[3]==0) return 0; | 
					
						
							| 
									
										
										
										
											2011-05-12 01:55:08 +00:00
										 |  |  | 			glColor4ubv(col); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			return 1; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-29 16:07:44 +00:00
										 |  |  | static int draw_dm_faces_sel__compareDrawOptions(void *userData, int index, int next_index) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-12-10 05:38:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-20 08:47:36 +00:00
										 |  |  | 	drawDMFacesSel_userData *data = userData; | 
					
						
							| 
									
										
										
										
											2011-12-02 01:01:07 +00:00
										 |  |  | 	BMFace *efa; | 
					
						
							|  |  |  | 	BMFace *next_efa; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-29 16:07:44 +00:00
										 |  |  | 	unsigned char *col, *next_col; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-09 11:46:48 +00:00
										 |  |  | 	if(!data->orig_index) | 
					
						
							| 
									
										
										
										
											2011-12-01 18:26:48 +00:00
										 |  |  | 		return 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-10 05:38:00 +00:00
										 |  |  | 	efa= EDBM_get_face_for_index(data->em, data->orig_index[index]); | 
					
						
							|  |  |  | 	next_efa= EDBM_get_face_for_index(data->em, data->orig_index[next_index]); | 
					
						
							| 
									
										
										
										
											2011-12-01 18:26:48 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-29 16:07:44 +00:00
										 |  |  | 	if(efa == next_efa) | 
					
						
							|  |  |  | 		return 1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(efa == data->efa_act || next_efa == data->efa_act) | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 	col = data->cols[BM_elem_flag_test(efa, BM_ELEM_SELECT)?1:0]; | 
					
						
							|  |  |  | 	next_col = data->cols[BM_elem_flag_test(next_efa, BM_ELEM_SELECT)?1:0]; | 
					
						
							| 
									
										
										
										
											2011-08-29 16:07:44 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if(col[3]==0 || next_col[3]==0) | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return col == next_col; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | /* also draws the active face */ | 
					
						
							| 
									
										
										
										
											2009-05-18 08:46:04 +00:00
										 |  |  | static void draw_dm_faces_sel(BMEditMesh *em, DerivedMesh *dm, unsigned char *baseCol,  | 
					
						
							| 
									
										
										
										
											2011-12-10 05:38:00 +00:00
										 |  |  | 			      unsigned char *selCol, unsigned char *actCol, BMFace *efa_act) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-12-20 08:47:36 +00:00
										 |  |  | 	drawDMFacesSel_userData data; | 
					
						
							| 
									
										
										
										
											2011-12-01 18:26:48 +00:00
										 |  |  | 	data.dm= dm; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	data.cols[0] = baseCol; | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	data.em = em; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	data.cols[1] = selCol; | 
					
						
							|  |  |  | 	data.cols[2] = actCol; | 
					
						
							|  |  |  | 	data.efa_act = efa_act; | 
					
						
							| 
									
										
										
										
											2011-12-10 05:38:00 +00:00
										 |  |  | 	data.orig_index = DM_get_tessface_data_layer(dm, CD_ORIGINDEX); | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-01 12:12:39 +00:00
										 |  |  | 	dm->drawMappedFaces(dm, draw_dm_faces_sel__setDrawOptions, GPU_enable_material, draw_dm_faces_sel__compareDrawOptions, &data, 0); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int draw_dm_creases__setDrawOptions(void *userData, int index) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2010-07-14 22:06:10 +00:00
										 |  |  | 	BMEditMesh *em = userData; | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	BMEdge *eed = EDBM_get_edge_for_index(userData, index); | 
					
						
							| 
									
										
										
										
											2012-02-12 18:49:56 +00:00
										 |  |  | 	float *crease = eed ? (float *)CustomData_bmesh_get(&em->bm->edata, eed->head.data, CD_CREASE) : NULL; | 
					
						
							| 
									
										
										
										
											2010-07-14 22:06:10 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	if (!crease) | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 	if (!BM_elem_flag_test(eed, BM_ELEM_HIDDEN) && *crease!=0.0f) { | 
					
						
							| 
									
										
										
										
											2010-07-19 04:44:37 +00:00
										 |  |  | 		UI_ThemeColorBlend(TH_WIRE, TH_EDGE_CREASE, *crease); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		return 1; | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-05-18 08:46:04 +00:00
										 |  |  | static void draw_dm_creases(BMEditMesh *em, DerivedMesh *dm) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	glLineWidth(3.0); | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	dm->drawMappedEdges(dm, draw_dm_creases__setDrawOptions, em); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	glLineWidth(1.0); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int draw_dm_bweights__setDrawOptions(void *userData, int index) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2010-07-14 22:06:10 +00:00
										 |  |  | 	BMEditMesh *em = userData; | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	BMEdge *eed = EDBM_get_edge_for_index(userData, index); | 
					
						
							| 
									
										
										
										
											2012-02-12 18:49:56 +00:00
										 |  |  | 	float *bweight = (float *)CustomData_bmesh_get(&em->bm->edata, eed->head.data, CD_BWEIGHT); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-14 22:06:10 +00:00
										 |  |  | 	if (!bweight) | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 	if (!BM_elem_flag_test(eed, BM_ELEM_HIDDEN) && *bweight!=0.0f) { | 
					
						
							| 
									
										
										
										
											2010-07-14 22:06:10 +00:00
										 |  |  | 		UI_ThemeColorBlend(TH_WIRE, TH_EDGE_SELECT, *bweight); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		return 1; | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2011-02-27 06:19:40 +00:00
										 |  |  | static void draw_dm_bweights__mapFunc(void *userData, int index, float *co, float *UNUSED(no_f), short *UNUSED(no_s)) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2010-07-14 22:06:10 +00:00
										 |  |  | 	BMEditMesh *em = userData; | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	BMVert *eve = EDBM_get_vert_for_index(userData, index); | 
					
						
							| 
									
										
										
										
											2012-02-12 18:49:56 +00:00
										 |  |  | 	float *bweight = (float *)CustomData_bmesh_get(&em->bm->vdata, eve->head.data, CD_BWEIGHT); | 
					
						
							| 
									
										
										
										
											2010-07-14 22:06:10 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	if (!bweight) | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 	if (!BM_elem_flag_test(eve, BM_ELEM_HIDDEN) && *bweight!=0.0f) { | 
					
						
							| 
									
										
										
										
											2010-07-14 22:06:10 +00:00
										 |  |  | 		UI_ThemeColorBlend(TH_VERTEX, TH_VERTEX_SELECT, *bweight); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		bglVertex3fv(co); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-05-18 08:46:04 +00:00
										 |  |  | static void draw_dm_bweights(BMEditMesh *em, Scene *scene, DerivedMesh *dm) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-06-23 00:41:55 +00:00
										 |  |  | 	ToolSettings *ts= scene->toolsettings; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (ts->selectmode & SCE_SELECT_VERTEX) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		glPointSize(UI_GetThemeValuef(TH_VERTEX_SIZE) + 2); | 
					
						
							|  |  |  | 		bglBegin(GL_POINTS); | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 		dm->foreachMappedVert(dm, draw_dm_bweights__mapFunc, em); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		bglEnd(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		glLineWidth(3.0); | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 		dm->drawMappedEdges(dm, draw_dm_bweights__setDrawOptions, em); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		glLineWidth(1.0); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Second section of routines: Combine first sets to form fancy
 | 
					
						
							|  |  |  |  * drawing routines (for example rendering twice to get overlays). | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Also includes routines that are basic drawing but are too | 
					
						
							|  |  |  |  * specialized to be split out (like drawing creases or measurements). | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* EditMesh drawing routines*/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | static void draw_em_fancy_verts(Scene *scene, View3D *v3d, Object *obedit,  | 
					
						
							| 
									
										
										
										
											2011-12-04 23:13:28 +00:00
										 |  |  |                                 BMEditMesh *em, DerivedMesh *cageDM, BMVert *eve_act) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-06-23 00:41:55 +00:00
										 |  |  | 	ToolSettings *ts= scene->toolsettings; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	int sel; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(v3d->zbuf) glDepthMask(0);		// disable write in zbuffer, zbuf select
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for (sel=0; sel<2; sel++) { | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 		unsigned char col[4], fcol[4]; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		int pass; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		UI_GetThemeColor3ubv(sel?TH_VERTEX_SELECT:TH_VERTEX, col); | 
					
						
							|  |  |  | 		UI_GetThemeColor3ubv(sel?TH_FACE_DOT:TH_WIRE, fcol); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		for (pass=0; pass<2; pass++) { | 
					
						
							|  |  |  | 			float size = UI_GetThemeValuef(TH_VERTEX_SIZE); | 
					
						
							|  |  |  | 			float fsize = UI_GetThemeValuef(TH_FACEDOT_SIZE); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			if (pass==0) { | 
					
						
							|  |  |  | 				if(v3d->zbuf && !(v3d->flag&V3D_ZBUF_SELECT)) { | 
					
						
							|  |  |  | 					glDisable(GL_DEPTH_TEST); | 
					
						
							|  |  |  | 						 | 
					
						
							|  |  |  | 					glEnable(GL_BLEND); | 
					
						
							|  |  |  | 				} else { | 
					
						
							|  |  |  | 					continue; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 				size = (size > 2.1f ? size/2.0f:size); | 
					
						
							|  |  |  | 				fsize = (fsize > 2.1f ? fsize/2.0f:fsize); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				col[3] = fcol[3] = 100; | 
					
						
							|  |  |  | 			} else { | 
					
						
							|  |  |  | 				col[3] = fcol[3] = 255; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 				 | 
					
						
							| 
									
										
										
										
											2009-06-23 00:41:55 +00:00
										 |  |  | 			if(ts->selectmode & SCE_SELECT_VERTEX) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				glPointSize(size); | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 				glColor4ubv(col); | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 				draw_dm_verts(em, cageDM, sel, eve_act); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			 | 
					
						
							| 
									
										
										
										
											2010-05-08 17:54:29 +00:00
										 |  |  | 			if(check_ob_drawface_dot(scene, v3d, obedit->dt)) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				glPointSize(fsize); | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 				glColor4ubv(fcol); | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 				draw_dm_face_centers(em, cageDM, sel); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if (pass==0) { | 
					
						
							|  |  |  | 				glDisable(GL_BLEND); | 
					
						
							|  |  |  | 				glEnable(GL_DEPTH_TEST); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(v3d->zbuf) glDepthMask(1); | 
					
						
							|  |  |  | 	glPointSize(1.0); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-04 23:13:28 +00:00
										 |  |  | static void draw_em_fancy_edges(BMEditMesh *em, Scene *scene, View3D *v3d, | 
					
						
							|  |  |  |                                 Mesh *me, DerivedMesh *cageDM, short sel_only, | 
					
						
							|  |  |  |                                 BMEdge *eed_act) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-06-23 00:41:55 +00:00
										 |  |  | 	ToolSettings *ts= scene->toolsettings; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	int pass; | 
					
						
							|  |  |  | 	unsigned char wireCol[4], selCol[4], actCol[4]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* since this function does transparant... */ | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 	UI_GetThemeColor4ubv(TH_EDGE_SELECT, selCol); | 
					
						
							|  |  |  | 	UI_GetThemeColor4ubv(TH_WIRE, wireCol); | 
					
						
							|  |  |  | 	UI_GetThemeColor4ubv(TH_EDITMESH_ACTIVE, actCol); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* when sel only is used, dont render wire, only selected, this is used for
 | 
					
						
							|  |  |  | 	 * textured draw mode when the 'edges' option is disabled */ | 
					
						
							|  |  |  | 	if (sel_only) | 
					
						
							|  |  |  | 		wireCol[3] = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for (pass=0; pass<2; pass++) { | 
					
						
							|  |  |  | 			/* show wires in transparant when no zbuf clipping for select */ | 
					
						
							|  |  |  | 		if (pass==0) { | 
					
						
							|  |  |  | 			if (v3d->zbuf && (v3d->flag & V3D_ZBUF_SELECT)==0) { | 
					
						
							|  |  |  | 				glEnable(GL_BLEND); | 
					
						
							|  |  |  | 				glDisable(GL_DEPTH_TEST); | 
					
						
							|  |  |  | 				selCol[3] = 85; | 
					
						
							|  |  |  | 				if (!sel_only) wireCol[3] = 85; | 
					
						
							|  |  |  | 			} else { | 
					
						
							|  |  |  | 				continue; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} else { | 
					
						
							|  |  |  | 			selCol[3] = 255; | 
					
						
							|  |  |  | 			if (!sel_only) wireCol[3] = 255; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-23 00:41:55 +00:00
										 |  |  | 		if(ts->selectmode == SCE_SELECT_FACE) { | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 			draw_dm_edges_sel(em, cageDM, wireCol, selCol, actCol, eed_act); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		}	 | 
					
						
							| 
									
										
										
										
											2009-06-23 00:41:55 +00:00
										 |  |  | 		else if( (me->drawflag & ME_DRAWEDGES) || (ts->selectmode & SCE_SELECT_EDGE) ) {	 | 
					
						
							|  |  |  | 			if(cageDM->drawMappedEdgesInterp && (ts->selectmode & SCE_SELECT_VERTEX)) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				glShadeModel(GL_SMOOTH); | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 				draw_dm_edges_sel_interp(em, cageDM, wireCol, selCol); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				glShadeModel(GL_FLAT); | 
					
						
							|  |  |  | 			} else { | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 				draw_dm_edges_sel(em, cageDM, wireCol, selCol, actCol, eed_act); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							|  |  |  | 			if (!sel_only) { | 
					
						
							|  |  |  | 				glColor4ubv(wireCol); | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 				draw_dm_edges(em, cageDM); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (pass==0) { | 
					
						
							|  |  |  | 			glDisable(GL_BLEND); | 
					
						
							|  |  |  | 			glEnable(GL_DEPTH_TEST); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | }	 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-23 08:41:53 +00:00
										 |  |  | static void draw_em_measure_stats(View3D *v3d, Object *ob, BMEditMesh *em, UnitSettings *unit) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-01-31 13:30:56 +00:00
										 |  |  | 	Mesh *me= ob->data; | 
					
						
							| 
									
										
										
										
											2011-06-24 00:55:14 +00:00
										 |  |  | 	float v1[3], v2[3], v3[3], vmid[3], fvec[3]; | 
					
						
							| 
									
										
										
										
											2012-01-11 09:33:44 +00:00
										 |  |  | 	char numstr[32]; /* Stores the measurement display text here */ | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 	const char *conv_float; /* Use a float conversion matching the grid size */ | 
					
						
							| 
									
										
										
										
											2011-03-10 13:49:46 +00:00
										 |  |  | 	unsigned char col[4]= {0, 0, 0, 255}; /* color of the text to draw */ | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 	float area; /* area of the face */ | 
					
						
							| 
									
										
										
										
											2009-08-16 11:16:04 +00:00
										 |  |  | 	float grid= unit->system ? unit->scale_length : v3d->grid; | 
					
						
							| 
									
										
										
										
											2010-07-26 18:20:20 +00:00
										 |  |  | 	const int do_split= unit->flag & USER_UNIT_OPT_SPLIT; | 
					
						
							|  |  |  | 	const int do_global= v3d->flag & V3D_GLOBAL_STATS; | 
					
						
							|  |  |  | 	const int do_moving= G.moving; | 
					
						
							| 
									
										
										
										
											2010-03-16 17:49:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-06-24 00:55:14 +00:00
										 |  |  | 	BMIter iter; | 
					
						
							|  |  |  | 	int i; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-18 20:01:35 +00:00
										 |  |  | 	/* make the precision of the pronted value proportionate to the gridsize */ | 
					
						
							| 
									
										
										
										
											2009-08-16 11:16:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 	if (grid < 0.01f)		conv_float= "%.6g"; | 
					
						
							|  |  |  | 	else if (grid < 0.1f)	conv_float= "%.5g"; | 
					
						
							|  |  |  | 	else if (grid < 1.0f)	conv_float= "%.4g"; | 
					
						
							|  |  |  | 	else if (grid < 10.0f)	conv_float= "%.3g"; | 
					
						
							|  |  |  | 	else					conv_float= "%.2g"; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 	if(me->drawflag & ME_DRAWEXTRA_EDGELEN) { | 
					
						
							| 
									
										
										
										
											2011-06-24 00:55:14 +00:00
										 |  |  | 		BMEdge *eed; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 		UI_GetThemeColor3ubv(TH_DRAWEXTRA_EDGELEN, col); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 		eed = BM_iter_new(&iter, em->bm, BM_EDGES_OF_MESH, NULL); | 
					
						
							|  |  |  | 		for(; eed; eed=BM_iter_step(&iter)) { | 
					
						
							| 
									
										
										
										
											2011-06-24 00:55:14 +00:00
										 |  |  | 			/* draw selected edges, or edges next to selected verts while draging */ | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 			if(BM_elem_flag_test(eed, BM_ELEM_SELECT) || | 
					
						
							|  |  |  | 			        (do_moving && (BM_elem_flag_test(eed->v1, BM_ELEM_SELECT) || BM_elem_flag_test(eed->v2, BM_ELEM_SELECT) ))) { | 
					
						
							| 
									
										
										
										
											2011-06-24 00:55:14 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-26 18:20:20 +00:00
										 |  |  | 				copy_v3_v3(v1, eed->v1->co); | 
					
						
							|  |  |  | 				copy_v3_v3(v2, eed->v2->co); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-08 09:02:47 +00:00
										 |  |  | 				mid_v3_v3v3(vmid, v1, v2); | 
					
						
							| 
									
										
										
										
											2010-07-26 18:20:20 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				if(do_global) { | 
					
						
							|  |  |  | 					mul_mat3_m4_v3(ob->obmat, v1); | 
					
						
							|  |  |  | 					mul_mat3_m4_v3(ob->obmat, v2); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2012-01-19 16:04:44 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				if(unit->system) { | 
					
						
							|  |  |  | 					bUnit_AsString(numstr, sizeof(numstr), len_v3v3(v1, v2) * unit->scale_length, 3, | 
					
						
							|  |  |  | 					               unit->system, B_UNIT_LENGTH, do_split, FALSE); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				else { | 
					
						
							| 
									
										
										
										
											2012-01-11 09:33:44 +00:00
										 |  |  | 					sprintf(numstr, conv_float, len_v3v3(v1, v2)); | 
					
						
							| 
									
										
										
										
											2012-01-19 16:04:44 +00:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-11 09:33:44 +00:00
										 |  |  | 				view3d_cached_text_draw_add(vmid, numstr, 0, V3D_CACHE_TEXT_ASCII, col); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 	if(me->drawflag & ME_DRAWEXTRA_FACEAREA) { | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 		/* would be nice to use BM_face_area_calc, but that is for 2d faces
 | 
					
						
							| 
									
										
										
										
											2011-06-24 00:55:14 +00:00
										 |  |  | 		so instead add up tessalation triangle areas */ | 
					
						
							|  |  |  | 		BMFace *f; | 
					
						
							|  |  |  | 		int n; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-11 15:04:54 +00:00
										 |  |  | #define DRAW_EM_MEASURE_STATS_FACEAREA()                                             \
 | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 		if (BM_elem_flag_test(f, BM_ELEM_SELECT)) {                                            \ | 
					
						
							| 
									
										
										
										
											2012-01-11 15:04:54 +00:00
										 |  |  | 			mul_v3_fl(vmid, 1.0/n);                                                  \ | 
					
						
							|  |  |  | 			if(unit->system)                                                         \ | 
					
						
							|  |  |  | 				bUnit_AsString(numstr, sizeof(numstr), area*unit->scale_length,      \ | 
					
						
							|  |  |  | 					3, unit->system, B_UNIT_LENGTH, do_split, FALSE);                \ | 
					
						
							|  |  |  | 			else                                                                     \ | 
					
						
							|  |  |  | 				BLI_snprintf(numstr, sizeof(numstr), conv_float, area);              \ | 
					
						
							|  |  |  | 			view3d_cached_text_draw_add(vmid, numstr, 0, V3D_CACHE_TEXT_ASCII, col); \ | 
					
						
							| 
									
										
										
										
											2011-06-24 00:55:14 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 		UI_GetThemeColor3ubv(TH_DRAWEXTRA_FACEAREA, col); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2011-06-24 00:55:14 +00:00
										 |  |  | 		f = NULL; | 
					
						
							|  |  |  | 		area = 0.0; | 
					
						
							|  |  |  | 		zero_v3(vmid); | 
					
						
							|  |  |  | 		n = 0; | 
					
						
							|  |  |  | 		for(i = 0; i < em->tottri; i++) { | 
					
						
							|  |  |  | 			BMLoop **l = em->looptris[i]; | 
					
						
							|  |  |  | 			if(f && l[0]->f != f) { | 
					
						
							|  |  |  | 				DRAW_EM_MEASURE_STATS_FACEAREA(); | 
					
						
							|  |  |  | 				zero_v3(vmid); | 
					
						
							|  |  |  | 				area = 0.0; | 
					
						
							|  |  |  | 				n = 0; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-06-24 00:55:14 +00:00
										 |  |  | 			f = l[0]->f; | 
					
						
							|  |  |  | 			copy_v3_v3(v1, l[0]->v->co); | 
					
						
							|  |  |  | 			copy_v3_v3(v2, l[1]->v->co); | 
					
						
							|  |  |  | 			copy_v3_v3(v3, l[2]->v->co); | 
					
						
							| 
									
										
										
										
											2010-07-26 18:20:20 +00:00
										 |  |  | 			if(do_global) { | 
					
						
							|  |  |  | 				mul_mat3_m4_v3(ob->obmat, v1); | 
					
						
							|  |  |  | 				mul_mat3_m4_v3(ob->obmat, v2); | 
					
						
							|  |  |  | 				mul_mat3_m4_v3(ob->obmat, v3); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2011-06-24 00:55:14 +00:00
										 |  |  | 			area += area_tri_v3(v1, v2, v3); | 
					
						
							|  |  |  | 			add_v3_v3(vmid, v1); | 
					
						
							|  |  |  | 			add_v3_v3(vmid, v2); | 
					
						
							|  |  |  | 			add_v3_v3(vmid, v3); | 
					
						
							|  |  |  | 			n += 3; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if(f){ | 
					
						
							|  |  |  | 			DRAW_EM_MEASURE_STATS_FACEAREA(); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | #undef DRAW_EM_MEASURE_STATS_FACEAREA
 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(me->drawflag & ME_DRAWEXTRA_FACEANG) { | 
					
						
							|  |  |  | 		BMFace *efa; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		UI_GetThemeColor3ubv(TH_DRAWEXTRA_FACEANG, col); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 		for(efa = BM_iter_new(&iter, em->bm, BM_FACES_OF_MESH, NULL); | 
					
						
							|  |  |  | 		    efa; efa=BM_iter_step(&iter)) { | 
					
						
							| 
									
										
										
										
											2011-06-24 00:55:14 +00:00
										 |  |  | 			BMIter liter; | 
					
						
							|  |  |  | 			BMLoop *loop; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 			BM_face_center_bounds_calc(em->bm, efa, vmid); | 
					
						
							| 
									
										
										
										
											2011-06-24 00:55:14 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 			for(loop = BM_iter_new(&liter, em->bm, BM_LOOPS_OF_FACE, efa); | 
					
						
							|  |  |  | 			    loop; loop = BM_iter_step(&liter)) { | 
					
						
							| 
									
										
										
										
											2011-06-24 00:55:14 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				float v1[3], v2[3], v3[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				copy_v3_v3(v1, loop->prev->v->co); | 
					
						
							|  |  |  | 				copy_v3_v3(v2, loop->v->co); | 
					
						
							|  |  |  | 				copy_v3_v3(v3, loop->next->v->co); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				if(do_global){ | 
					
						
							|  |  |  | 					mul_mat3_m4_v3(ob->obmat, v1); | 
					
						
							|  |  |  | 					mul_mat3_m4_v3(ob->obmat, v2); | 
					
						
							|  |  |  | 					mul_mat3_m4_v3(ob->obmat, v3); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 				if ( (BM_elem_flag_test(efa, BM_ELEM_SELECT)) || | 
					
						
							|  |  |  | 				     (do_moving && BM_elem_flag_test(loop->v, BM_ELEM_SELECT))) | 
					
						
							| 
									
										
										
										
											2012-01-11 15:04:54 +00:00
										 |  |  | 				{ | 
					
						
							|  |  |  | 					BLI_snprintf(numstr, sizeof(numstr), "%.3g", RAD2DEGF(angle_v3v3v3(v1, v2, v3))); | 
					
						
							| 
									
										
										
										
											2011-06-24 00:55:14 +00:00
										 |  |  | 					interp_v3_v3v3(fvec, vmid, v2, 0.8f); | 
					
						
							| 
									
										
										
										
											2012-01-11 09:33:44 +00:00
										 |  |  | 					view3d_cached_text_draw_add(fvec, numstr, 0, V3D_CACHE_TEXT_ASCII, col); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-12-26 20:23:13 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2011-06-24 00:55:14 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-23 08:41:53 +00:00
										 |  |  | static void draw_em_indices(BMEditMesh *em) | 
					
						
							| 
									
										
										
										
											2011-12-22 05:39:23 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-12-23 08:41:53 +00:00
										 |  |  | 	BMEdge *e; | 
					
						
							|  |  |  | 	BMFace *f; | 
					
						
							|  |  |  | 	BMVert *v; | 
					
						
							| 
									
										
										
										
											2011-12-22 05:39:23 +00:00
										 |  |  | 	int i; | 
					
						
							| 
									
										
										
										
											2012-01-11 09:33:44 +00:00
										 |  |  | 	char numstr[32]; | 
					
						
							| 
									
										
										
										
											2011-12-22 05:39:23 +00:00
										 |  |  | 	float pos[3]; | 
					
						
							|  |  |  | 	unsigned char col[4]; | 
					
						
							| 
									
										
										
										
											2011-09-07 00:46:11 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-23 08:41:53 +00:00
										 |  |  | 	BMIter iter; | 
					
						
							|  |  |  | 	BMesh *bm= em->bm; | 
					
						
							| 
									
										
										
										
											2011-09-07 00:46:11 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-23 08:41:53 +00:00
										 |  |  | 	/* For now, reuse appropriate theme colors from stats text colors */ | 
					
						
							|  |  |  | 	i= 0; | 
					
						
							| 
									
										
										
										
											2011-12-27 12:50:23 +00:00
										 |  |  | 	if (em->selectmode & SCE_SELECT_VERTEX) { | 
					
						
							|  |  |  | 		UI_GetThemeColor3ubv(TH_DRAWEXTRA_FACEANG, col); | 
					
						
							| 
									
										
										
										
											2011-12-27 13:28:30 +00:00
										 |  |  | 		BM_ITER(v, &iter, bm, BM_VERTS_OF_MESH, NULL) { | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 			if (BM_elem_flag_test(v, BM_ELEM_SELECT)) { | 
					
						
							| 
									
										
										
										
											2012-01-11 09:33:44 +00:00
										 |  |  | 				sprintf(numstr, "%d", i); | 
					
						
							|  |  |  | 				view3d_cached_text_draw_add(v->co, numstr, 0, V3D_CACHE_TEXT_ASCII, col); | 
					
						
							| 
									
										
										
										
											2011-12-27 12:50:23 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2011-12-27 13:28:30 +00:00
										 |  |  | 			i++; | 
					
						
							| 
									
										
										
										
											2011-09-07 00:46:11 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2011-12-22 05:39:23 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-27 12:50:23 +00:00
										 |  |  | 	if (em->selectmode & SCE_SELECT_EDGE) { | 
					
						
							| 
									
										
										
										
											2011-12-27 13:28:30 +00:00
										 |  |  | 		i= 0; | 
					
						
							| 
									
										
										
										
											2011-12-27 12:50:23 +00:00
										 |  |  | 		UI_GetThemeColor3ubv(TH_DRAWEXTRA_EDGELEN, col); | 
					
						
							| 
									
										
										
										
											2011-12-27 13:28:30 +00:00
										 |  |  | 		BM_ITER(e, &iter, bm, BM_EDGES_OF_MESH, NULL) { | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 			if (BM_elem_flag_test(e, BM_ELEM_SELECT)) { | 
					
						
							| 
									
										
										
										
											2012-01-11 09:33:44 +00:00
										 |  |  | 				sprintf(numstr, "%d", i); | 
					
						
							| 
									
										
										
										
											2011-12-27 12:50:23 +00:00
										 |  |  | 				mid_v3_v3v3(pos, e->v1->co, e->v2->co); | 
					
						
							| 
									
										
										
										
											2012-01-11 09:33:44 +00:00
										 |  |  | 				view3d_cached_text_draw_add(pos, numstr, 0, V3D_CACHE_TEXT_ASCII, col); | 
					
						
							| 
									
										
										
										
											2011-12-27 12:50:23 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2011-12-27 13:28:30 +00:00
										 |  |  | 			i++; | 
					
						
							| 
									
										
										
										
											2011-08-18 19:07:37 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-27 12:50:23 +00:00
										 |  |  | 	if (em->selectmode & SCE_SELECT_FACE) { | 
					
						
							| 
									
										
										
										
											2011-12-27 13:28:30 +00:00
										 |  |  | 		i= 0; | 
					
						
							| 
									
										
										
										
											2011-12-27 12:50:23 +00:00
										 |  |  | 		UI_GetThemeColor3ubv(TH_DRAWEXTRA_FACEAREA, col); | 
					
						
							| 
									
										
										
										
											2011-12-27 13:28:30 +00:00
										 |  |  | 		BM_ITER(f, &iter, bm, BM_FACES_OF_MESH, NULL) { | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 			if (BM_elem_flag_test(f, BM_ELEM_SELECT)) { | 
					
						
							|  |  |  | 				BM_face_center_mean_calc(bm, f, pos); | 
					
						
							| 
									
										
										
										
											2012-01-11 09:33:44 +00:00
										 |  |  | 				sprintf(numstr, "%d", i); | 
					
						
							| 
									
										
										
										
											2012-01-11 15:04:54 +00:00
										 |  |  | 				view3d_cached_text_draw_add(pos, numstr, 0, V3D_CACHE_TEXT_ASCII, col); | 
					
						
							| 
									
										
										
										
											2011-12-27 12:50:23 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2011-12-27 13:28:30 +00:00
										 |  |  | 			i++; | 
					
						
							| 
									
										
										
										
											2011-12-22 05:39:23 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-27 06:19:40 +00:00
										 |  |  | static int draw_em_fancy__setFaceOpts(void *userData, int index, int *UNUSED(drawSmooth_r)) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	BMFace *efa = EDBM_get_face_for_index(userData, index); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 	if (efa && !BM_elem_flag_test(efa, BM_ELEM_HIDDEN)) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		GPU_enable_material(efa->mat_nr+1, NULL); | 
					
						
							|  |  |  | 		return 1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int draw_em_fancy__setGLSLFaceOpts(void *userData, int index) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	BMFace *efa = EDBM_get_face_for_index(userData, index); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 	return !BM_elem_flag_test(efa, BM_ELEM_HIDDEN); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-03 20:49:41 +00:00
										 |  |  | static void draw_em_fancy(Scene *scene, View3D *v3d, RegionView3D *rv3d, | 
					
						
							| 
									
										
										
										
											2011-12-03 21:01:26 +00:00
										 |  |  |                           Object *ob, BMEditMesh *em, DerivedMesh *cageDM, DerivedMesh *finalDM, int dt) | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	Mesh *me = ob->data; | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 	BMFace *efa_act = BM_active_face_get(em->bm, FALSE); /* annoying but active faces is stored differently */ | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	BMEdge *eed_act = NULL; | 
					
						
							|  |  |  | 	BMVert *eve_act = NULL; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-17 10:54:00 +00:00
										 |  |  | 	if (em->bm->selected.last) { | 
					
						
							| 
									
										
										
										
											2011-11-01 14:36:23 +00:00
										 |  |  | 		BMEditSelection *ese= em->bm->selected.last; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		/* face is handeled above */ | 
					
						
							| 
									
										
										
										
											2011-09-13 13:41:20 +00:00
										 |  |  | 		/*if (ese->type == BM_FACE ) {
 | 
					
						
							|  |  |  | 			efa_act = (BMFace *)ese->data; | 
					
						
							| 
									
										
										
										
											2011-11-01 14:36:23 +00:00
										 |  |  | 		} else */ if ( ese->htype == BM_EDGE ) { | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 			eed_act = (BMEdge *)ese->data; | 
					
						
							| 
									
										
										
										
											2011-11-01 14:36:23 +00:00
										 |  |  | 		} else if ( ese->htype == BM_VERT ) { | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 			eve_act = (BMVert *)ese->data; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	EDBM_init_index_arrays(em, 1, 1, 1); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if(dt>OB_WIRE) { | 
					
						
							|  |  |  | 		if(CHECK_OB_DRAWTEXTURE(v3d, dt)) { | 
					
						
							|  |  |  | 			if(draw_glsl_material(scene, ob, v3d, dt)) { | 
					
						
							| 
									
										
										
										
											2011-11-21 11:46:05 +00:00
										 |  |  | 				glFrontFace((ob->transflag&OB_NEG_SCALE)?GL_CW:GL_CCW); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-21 11:46:05 +00:00
										 |  |  | 				finalDM->drawMappedFacesGLSL(finalDM, GPU_enable_material, | 
					
						
							| 
									
										
										
										
											2011-11-22 11:51:42 +00:00
										 |  |  | 				                             draw_em_fancy__setGLSLFaceOpts, em); | 
					
						
							| 
									
										
										
										
											2011-11-21 11:46:05 +00:00
										 |  |  | 				GPU_disable_material(); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-21 11:46:05 +00:00
										 |  |  | 				glFrontFace(GL_CCW); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | 				draw_mesh_textured(scene, v3d, rv3d, ob, finalDM, 0); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2011-12-03 20:49:41 +00:00
										 |  |  | 			/* 3 floats for position,
 | 
					
						
							|  |  |  | 			 * 3 for normal and times two because the faces may actually be quads instead of triangles */ | 
					
						
							| 
									
										
										
										
											2011-11-21 11:46:05 +00:00
										 |  |  | 			glLightModeli(GL_LIGHT_MODEL_TWO_SIDE, me->flag & ME_TWOSIDED); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-21 11:46:05 +00:00
										 |  |  | 			glEnable(GL_LIGHTING); | 
					
						
							|  |  |  | 			glFrontFace((ob->transflag&OB_NEG_SCALE)?GL_CW:GL_CCW); | 
					
						
							| 
									
										
										
										
											2011-12-02 01:01:07 +00:00
										 |  |  | 			finalDM->drawMappedFaces(finalDM, draw_em_fancy__setFaceOpts, GPU_enable_material, NULL, me->edit_btmesh, 0); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-21 11:46:05 +00:00
										 |  |  | 			glFrontFace(GL_CCW); | 
					
						
							|  |  |  | 			glDisable(GL_LIGHTING); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 		// Setup for drawing wire over, disable zbuffer
 | 
					
						
							|  |  |  | 		// write to show selected edge wires better
 | 
					
						
							|  |  |  | 		UI_ThemeColor(TH_WIRE); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | 		bglPolygonOffset(rv3d->dist, 1.0); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		glDepthMask(0); | 
					
						
							|  |  |  | 	}  | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		if (cageDM!=finalDM) { | 
					
						
							|  |  |  | 			UI_ThemeColorBlend(TH_WIRE, TH_BACK, 0.7); | 
					
						
							| 
									
										
										
										
											2010-03-22 11:59:36 +00:00
										 |  |  | 			finalDM->drawEdges(finalDM, 1, 0); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-11-15 00:07:38 +00:00
										 |  |  | 	if(me->drawflag & ME_DRAWFACES) {	/* transp faces */ | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		unsigned char col1[4], col2[4], col3[4]; | 
					
						
							|  |  |  | 			 | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 		UI_GetThemeColor4ubv(TH_FACE, col1); | 
					
						
							|  |  |  | 		UI_GetThemeColor4ubv(TH_FACE_SELECT, col2); | 
					
						
							|  |  |  | 		UI_GetThemeColor4ubv(TH_EDITMESH_ACTIVE, col3); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		glEnable(GL_BLEND); | 
					
						
							|  |  |  | 		glDepthMask(0);		// disable write in zbuffer, needed for nice transp
 | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* dont draw unselected faces, only selected, this is MUCH nicer when texturing */ | 
					
						
							|  |  |  | 		if CHECK_OB_DRAWTEXTURE(v3d, dt) | 
					
						
							|  |  |  | 			col1[3] = 0; | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2011-12-10 05:38:00 +00:00
										 |  |  | 		draw_dm_faces_sel(em, cageDM, col1, col2, col3, efa_act); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		glDisable(GL_BLEND); | 
					
						
							|  |  |  | 		glDepthMask(1);		// restore write in zbuffer
 | 
					
						
							|  |  |  | 	} else if (efa_act) { | 
					
						
							|  |  |  | 		/* even if draw faces is off it would be nice to draw the stipple face
 | 
					
						
							|  |  |  | 		 * Make all other faces zero alpha except for the active | 
					
						
							|  |  |  | 		 * */ | 
					
						
							|  |  |  | 		unsigned char col1[4], col2[4], col3[4]; | 
					
						
							|  |  |  | 		col1[3] = col2[3] = 0; /* dont draw */ | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 		UI_GetThemeColor4ubv(TH_EDITMESH_ACTIVE, col3); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		glEnable(GL_BLEND); | 
					
						
							|  |  |  | 		glDepthMask(0);		// disable write in zbuffer, needed for nice transp
 | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2011-12-10 05:38:00 +00:00
										 |  |  | 		draw_dm_faces_sel(em, cageDM, col1, col2, col3, efa_act); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		glDisable(GL_BLEND); | 
					
						
							|  |  |  | 		glDepthMask(1);		// restore write in zbuffer
 | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* here starts all fancy draw-extra over */ | 
					
						
							| 
									
										
										
										
											2009-01-31 13:30:56 +00:00
										 |  |  | 	if((me->drawflag & ME_DRAWEDGES)==0 && CHECK_OB_DRAWTEXTURE(v3d, dt)) { | 
					
						
							|  |  |  | 		/* we are drawing textures and 'ME_DRAWEDGES' is disabled, dont draw any edges */ | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		/* only draw selected edges otherwise there is no way of telling if a face is selected */ | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 		draw_em_fancy_edges(em, scene, v3d, me, cageDM, 1, eed_act); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 	} else { | 
					
						
							| 
									
										
										
										
											2009-01-31 13:30:56 +00:00
										 |  |  | 		if(me->drawflag & ME_DRAWSEAMS) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			UI_ThemeColor(TH_EDGE_SEAM); | 
					
						
							|  |  |  | 			glLineWidth(2); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 			draw_dm_edges_seams(em, cageDM); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 			glColor3ub(0,0,0); | 
					
						
							|  |  |  | 			glLineWidth(1); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2009-01-31 13:30:56 +00:00
										 |  |  | 		if(me->drawflag & ME_DRAWSHARP) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			UI_ThemeColor(TH_EDGE_SHARP); | 
					
						
							|  |  |  | 			glLineWidth(2); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 			draw_dm_edges_sharp(em, cageDM); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 			glColor3ub(0,0,0); | 
					
						
							|  |  |  | 			glLineWidth(1); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-07-14 22:06:10 +00:00
										 |  |  | 		if(me->drawflag & ME_DRAWCREASES && CustomData_has_layer(&em->bm->edata, CD_CREASE)) { | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 			draw_dm_creases(em, cageDM); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-01-31 13:30:56 +00:00
										 |  |  | 		if(me->drawflag & ME_DRAWBWEIGHTS) { | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 			draw_dm_bweights(em, scene, cageDM); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-09-10 03:59:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 		draw_em_fancy_edges(em, scene, v3d, me, cageDM, 0, eed_act); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-02 19:10:35 +00:00
										 |  |  | 	if(em) { | 
					
						
							|  |  |  | 		draw_em_fancy_verts(scene, v3d, ob, em, cageDM, eve_act); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-31 13:30:56 +00:00
										 |  |  | 		if(me->drawflag & ME_DRAWNORMALS) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			UI_ThemeColor(TH_NORMAL); | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 			draw_dm_face_normals(em, scene, cageDM); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-01-31 13:30:56 +00:00
										 |  |  | 		if(me->drawflag & ME_DRAW_VNORMALS) { | 
					
						
							| 
									
										
										
										
											2010-02-11 03:37:51 +00:00
										 |  |  | 			UI_ThemeColor(TH_VNORMAL); | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 			draw_dm_vert_normals(em, scene, cageDM); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-03 20:49:41 +00:00
										 |  |  | 		if ( (me->drawflag & (ME_DRAWEXTRA_EDGELEN|ME_DRAWEXTRA_FACEAREA|ME_DRAWEXTRA_FACEANG)) && | 
					
						
							|  |  |  | 		     !(v3d->flag2 & V3D_RENDER_OVERRIDE)) | 
					
						
							|  |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2011-12-22 05:52:31 +00:00
										 |  |  | 			draw_em_measure_stats(v3d, ob, em, &scene->unit); | 
					
						
							| 
									
										
										
										
											2011-12-03 20:49:41 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2011-12-22 05:39:23 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		if ((G.f & G_DEBUG) && (me->drawflag & ME_DRAWEXTRA_INDICES) && | 
					
						
							|  |  |  | 		    !(v3d->flag2 & V3D_RENDER_OVERRIDE)) { | 
					
						
							|  |  |  | 			draw_em_indices(em); | 
					
						
							| 
									
										
										
										
											2011-12-03 20:49:41 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(dt>OB_WIRE) { | 
					
						
							|  |  |  | 		glDepthMask(1); | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | 		bglPolygonOffset(rv3d->dist, 0.0); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		GPU_disable_material(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 	EDBM_free_index_arrays(em); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Mesh drawing routines */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void draw_mesh_object_outline(View3D *v3d, Object *ob, DerivedMesh *dm) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if(v3d->transp==0) {	// not when we draw the transparent pass
 | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 		glLineWidth(UI_GetThemeValuef(TH_OUTLINE_WIDTH) * 2.0f); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		glDepthMask(0); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* if transparent, we cannot draw the edges for solid select... edges have no material info.
 | 
					
						
							|  |  |  | 		   drawFacesSolid() doesn't draw the transparent faces */ | 
					
						
							|  |  |  | 		if(ob->dtx & OB_DRAWTRANSP) { | 
					
						
							|  |  |  | 			glPolygonMode(GL_FRONT_AND_BACK, GL_LINE);  | 
					
						
							| 
									
										
										
										
											2009-11-25 14:13:43 +00:00
										 |  |  | 			dm->drawFacesSolid(dm, NULL, 0, GPU_enable_material); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			glPolygonMode(GL_FRONT_AND_BACK, GL_FILL); | 
					
						
							|  |  |  | 			GPU_disable_material(); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2010-03-22 11:59:36 +00:00
										 |  |  | 			dm->drawEdges(dm, 0, 1); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 					 | 
					
						
							|  |  |  | 		glLineWidth(1.0); | 
					
						
							|  |  |  | 		glDepthMask(1); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-09 14:32:55 +00:00
										 |  |  | static int wpaint__setSolidDrawOptions(void *UNUSED(userData), int UNUSED(index), int *drawSmooth_r) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	*drawSmooth_r = 1; | 
					
						
							|  |  |  | 	return 1; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-27 19:53:34 +00:00
										 |  |  | static void draw_mesh_fancy(Scene *scene, ARegion *ar, View3D *v3d, RegionView3D *rv3d, Base *base, int dt, int flag) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	Object *ob= base->object; | 
					
						
							|  |  |  | 	Mesh *me = ob->data; | 
					
						
							|  |  |  | 	Material *ma= give_current_material(ob, 1); | 
					
						
							| 
									
										
										
										
											2010-11-15 00:07:38 +00:00
										 |  |  | 	const short hasHaloMat = (ma && (ma->material_type == MA_TYPE_HALO)); | 
					
						
							| 
									
										
										
										
											2011-11-25 02:35:23 +00:00
										 |  |  | 	eWireDrawMode draw_wire= OBDRAW_WIRE_OFF; | 
					
						
							| 
									
										
										
										
											2011-01-10 03:58:07 +00:00
										 |  |  | 	int /* totvert,*/ totedge, totface; | 
					
						
							| 
									
										
										
										
											2010-12-23 04:26:53 +00:00
										 |  |  | 	DerivedMesh *dm= mesh_get_derived_final(scene, ob, scene->customdata_mask); | 
					
						
							| 
									
										
										
										
											2011-12-05 22:19:30 +00:00
										 |  |  | 	const short is_obact= (ob == OBACT); | 
					
						
							| 
									
										
										
										
											2011-12-03 20:26:53 +00:00
										 |  |  | 	int draw_flags = (is_obact && paint_facesel_test(ob)) ? DRAW_FACE_SELECT : 0; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if(!dm) | 
					
						
							|  |  |  | 		return; | 
					
						
							| 
									
										
										
										
											2011-06-16 10:41:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Add weight preview to WeightVG modifiers, and first, simple/basic refactor of how modifiers can generate preview.
User side:
* Preview for DynamicPaint should keep the same behavior (for now). Weight preview should be somawhat quicker, though.
* Preview for WeightVG modifiers is only active in WeightPaint mode, and if the affected vgroup is the active one.
* Last active preview modifier in stack wins!
Note: that modifier preview topic is yet to be further refined, quite raw/incomplete for now.
Dev side:
* In draw code, renamed DRAW_DYNAMIC_PAINT_PREVIEW flag to DRAW_MODIFIERS_PREVIEW
* Removed use of MOD_DPAINT_PREVIEW_READY in DynamicPaint code (seems unecessary, and if it was, should be of more general scope).
* Added eModifierTypeFlag_UsesPreview to ModifierTypeFlag, for modifiers that can generate some preview data.
* Added three new modifier funcs, to handle preview modifiers in draw code / mod stack.
* For weights preview: added the generic DM_update_weight_mcol func, which can update WEIGHT_MCOL layer with either a given array of weights (currently used by DynamicPaint only), or from current active vgroup(s).
So now, draw code is fully generic (i.e. no more modifier-type checking in it). Mod stack code is generic to some extent, but will need more work.
											
										 
											2012-01-22 17:54:23 +00:00
										 |  |  | 	/* Check to draw dynamic paint colors (or weights from WeightVG modifiers).
 | 
					
						
							|  |  |  | 	 * Note: Last "preview-active" modifier in stack will win! */ | 
					
						
							| 
									
										
										
										
											2012-01-23 16:32:11 +00:00
										 |  |  | 	if(DM_get_tessface_data_layer(dm, CD_WEIGHT_MCOL) && modifiers_isPreview(ob)) | 
					
						
							| 
									
										
											  
											
												Add weight preview to WeightVG modifiers, and first, simple/basic refactor of how modifiers can generate preview.
User side:
* Preview for DynamicPaint should keep the same behavior (for now). Weight preview should be somawhat quicker, though.
* Preview for WeightVG modifiers is only active in WeightPaint mode, and if the affected vgroup is the active one.
* Last active preview modifier in stack wins!
Note: that modifier preview topic is yet to be further refined, quite raw/incomplete for now.
Dev side:
* In draw code, renamed DRAW_DYNAMIC_PAINT_PREVIEW flag to DRAW_MODIFIERS_PREVIEW
* Removed use of MOD_DPAINT_PREVIEW_READY in DynamicPaint code (seems unecessary, and if it was, should be of more general scope).
* Added eModifierTypeFlag_UsesPreview to ModifierTypeFlag, for modifiers that can generate some preview data.
* Added three new modifier funcs, to handle preview modifiers in draw code / mod stack.
* For weights preview: added the generic DM_update_weight_mcol func, which can update WEIGHT_MCOL layer with either a given array of weights (currently used by DynamicPaint only), or from current active vgroup(s).
So now, draw code is fully generic (i.e. no more modifier-type checking in it). Mod stack code is generic to some extent, but will need more work.
											
										 
											2012-01-22 17:54:23 +00:00
										 |  |  | 		draw_flags |= DRAW_MODIFIERS_PREVIEW; | 
					
						
							| 
									
										
										
										
											2011-11-25 02:35:23 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* Unwanted combination */ | 
					
						
							|  |  |  | 	if (draw_flags & DRAW_FACE_SELECT) { | 
					
						
							|  |  |  | 		draw_wire= OBDRAW_WIRE_OFF; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else if (ob->dtx & OB_DRAWWIRE) { | 
					
						
							|  |  |  | 		draw_wire= OBDRAW_WIRE_ON_DEPTH; /* draw wire after solid using zoffset and depth buffer adjusment */ | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2011-01-10 03:58:07 +00:00
										 |  |  | 	/* totvert = dm->getNumVerts(dm); */ /*UNUSED*/ | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	totedge = dm->getNumEdges(dm); | 
					
						
							| 
									
										
											  
											
												(NOTE: DO NOT TEST)
Start of planned DerivedMesh refactoring.  The mface
interfaces in DerivedMesh have been renamed to reflect
their new status as tesselated face interfaces (rather 
then the primary ones, which are now stored in mpolys).
short review: mpolys store "primary" face data, while
mfaces store the tesselated form of the mesh (generally
as triangles).  mpolys are defined by mloops, and each
mpoly defines a range of loops it "owns" in the main
mloop array.
I've also added basic read-only face iterators, which
are implemented for CDDM, ccgsubsurf, and the bmeditmesh
derivedmesh.  Since faces are now variable-length things,
trying to implement the same interface as mfaces would not
have worked well (especially since faces are stored as
an mpoly + a range of mloops).
I figure first we can evaluate these simple read-only
face iterators, then decide if a) we like using iterators
in DerivedMesh, b) how much of it should use them, and c)
if we want write-capable iterators.
I plan to write official docs on this design after I get
it more stable; I'm committing now because there's a rather
lot of changes, and I might do a merge soon.
											
										 
											2009-06-10 10:06:25 +00:00
										 |  |  | 	totface = dm->getNumTessFaces(dm); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* vertexpaint, faceselect wants this, but it doesnt work for shaded? */ | 
					
						
							| 
									
										
										
										
											2011-11-02 18:20:53 +00:00
										 |  |  | 	glFrontFace((ob->transflag&OB_NEG_SCALE)?GL_CW:GL_CCW); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if(dt==OB_BOUNDBOX) { | 
					
						
							| 
									
										
										
										
											2010-05-20 15:04:47 +00:00
										 |  |  | 		if((v3d->flag2 & V3D_RENDER_OVERRIDE && v3d->drawtype >= OB_WIRE)==0) | 
					
						
							| 
									
										
										
										
											2011-11-04 15:53:34 +00:00
										 |  |  | 			draw_bounding_volume(scene, ob, ob->boundtype); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else if(hasHaloMat || (totface==0 && totedge==0)) { | 
					
						
							|  |  |  | 		glPointSize(1.5); | 
					
						
							|  |  |  | 		dm->drawVerts(dm); | 
					
						
							|  |  |  | 		glPointSize(1.0); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else if(dt==OB_WIRE || totface==0) { | 
					
						
							| 
									
										
										
										
											2011-11-25 02:35:23 +00:00
										 |  |  | 		draw_wire= OBDRAW_WIRE_ON; /* draw wire only, no depth buffer stuff  */ | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-12-03 20:26:53 +00:00
										 |  |  | 	else if ( (draw_flags & DRAW_FACE_SELECT || (is_obact && ob->mode & OB_MODE_TEXTURE_PAINT)) || | 
					
						
							| 
									
										
										
										
											2011-11-25 02:35:23 +00:00
										 |  |  | 	          CHECK_OB_DRAWTEXTURE(v3d, dt)) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2011-11-25 02:35:23 +00:00
										 |  |  | 		if ( (v3d->flag & V3D_SELECT_OUTLINE) && | 
					
						
							|  |  |  | 		     ((v3d->flag2 & V3D_RENDER_OVERRIDE)==0) && | 
					
						
							|  |  |  | 		     (base->flag & SELECT) && | 
					
						
							|  |  |  | 		     !(G.f & G_PICKSEL || (draw_flags & DRAW_FACE_SELECT)) && | 
					
						
							|  |  |  | 		     (draw_wire == OBDRAW_WIRE_OFF)) | 
					
						
							|  |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			draw_mesh_object_outline(v3d, ob, dm); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Add weight preview to WeightVG modifiers, and first, simple/basic refactor of how modifiers can generate preview.
User side:
* Preview for DynamicPaint should keep the same behavior (for now). Weight preview should be somawhat quicker, though.
* Preview for WeightVG modifiers is only active in WeightPaint mode, and if the affected vgroup is the active one.
* Last active preview modifier in stack wins!
Note: that modifier preview topic is yet to be further refined, quite raw/incomplete for now.
Dev side:
* In draw code, renamed DRAW_DYNAMIC_PAINT_PREVIEW flag to DRAW_MODIFIERS_PREVIEW
* Removed use of MOD_DPAINT_PREVIEW_READY in DynamicPaint code (seems unecessary, and if it was, should be of more general scope).
* Added eModifierTypeFlag_UsesPreview to ModifierTypeFlag, for modifiers that can generate some preview data.
* Added three new modifier funcs, to handle preview modifiers in draw code / mod stack.
* For weights preview: added the generic DM_update_weight_mcol func, which can update WEIGHT_MCOL layer with either a given array of weights (currently used by DynamicPaint only), or from current active vgroup(s).
So now, draw code is fully generic (i.e. no more modifier-type checking in it). Mod stack code is generic to some extent, but will need more work.
											
										 
											2012-01-22 17:54:23 +00:00
										 |  |  | 		if(draw_glsl_material(scene, ob, v3d, dt) && !(draw_flags & DRAW_MODIFIERS_PREVIEW)) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			glFrontFace((ob->transflag&OB_NEG_SCALE)?GL_CW:GL_CCW); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			dm->drawFacesGLSL(dm, GPU_enable_material); | 
					
						
							|  |  |  | //			if(get_ob_property(ob, "Text"))
 | 
					
						
							|  |  |  | // XXX				draw_mesh_text(ob, 1);
 | 
					
						
							|  |  |  | 			GPU_disable_material(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			glFrontFace(GL_CCW); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2011-06-17 18:04:56 +00:00
										 |  |  | 			draw_mesh_textured(scene, v3d, rv3d, ob, dm, draw_flags); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-09 15:46:53 +00:00
										 |  |  | 		if(!(draw_flags & DRAW_FACE_SELECT)) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			if(base->flag & SELECT) | 
					
						
							| 
									
										
										
										
											2011-12-03 20:26:53 +00:00
										 |  |  | 				UI_ThemeColor(is_obact ? TH_ACTIVE : TH_SELECT); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			else | 
					
						
							|  |  |  | 				UI_ThemeColor(TH_WIRE); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-05-23 10:48:35 +00:00
										 |  |  | 			if((v3d->flag2 & V3D_RENDER_OVERRIDE)==0) | 
					
						
							|  |  |  | 				dm->drawLooseEdges(dm); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else if(dt==OB_SOLID) { | 
					
						
							| 
									
										
										
										
											2011-12-03 20:26:53 +00:00
										 |  |  | 		if(is_obact && ob->mode & OB_MODE_WEIGHT_PAINT) { | 
					
						
							| 
									
										
										
										
											2010-01-14 12:51:17 +00:00
										 |  |  | 			/* weight paint in solid mode, special case. focus on making the weights clear
 | 
					
						
							| 
									
										
										
										
											2011-05-28 13:11:24 +00:00
										 |  |  | 			 * rather than the shading, this is also forced in wire view */ | 
					
						
							| 
									
										
										
										
											2010-01-14 12:51:17 +00:00
										 |  |  | 			GPU_enable_material(0, NULL); | 
					
						
							| 
									
										
										
										
											2012-02-05 03:25:13 +00:00
										 |  |  | 			dm->drawMappedFaces(dm, wpaint__setSolidDrawOptions, GPU_enable_material, NULL, me->mpoly, 1); | 
					
						
							| 
									
										
										
										
											2010-10-10 22:15:48 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2010-01-14 12:51:17 +00:00
										 |  |  | 			bglPolygonOffset(rv3d->dist, 1.0); | 
					
						
							|  |  |  | 			glDepthMask(0);	// disable write in zbuffer, selected edge wires show better
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-14 12:51:17 +00:00
										 |  |  | 			glEnable(GL_BLEND); | 
					
						
							| 
									
										
										
										
											2010-10-10 22:15:48 +00:00
										 |  |  | 			glColor4ub(255, 255, 255, 96); | 
					
						
							| 
									
										
										
										
											2010-01-14 12:51:17 +00:00
										 |  |  | 			glEnable(GL_LINE_STIPPLE); | 
					
						
							| 
									
										
										
										
											2010-10-10 22:15:48 +00:00
										 |  |  | 			glLineStipple(1, 0xAAAA); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-10 22:15:48 +00:00
										 |  |  | 			dm->drawEdges(dm, 1, 1); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-14 12:51:17 +00:00
										 |  |  | 			bglPolygonOffset(rv3d->dist, 0.0); | 
					
						
							|  |  |  | 			glDepthMask(1); | 
					
						
							|  |  |  | 			glDisable(GL_LINE_STIPPLE); | 
					
						
							| 
									
										
										
										
											2012-01-13 08:38:26 +00:00
										 |  |  | 			glDisable(GL_BLEND); | 
					
						
							| 
									
										
										
										
											2010-01-14 12:51:17 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			GPU_disable_material(); | 
					
						
							| 
									
										
										
										
											2010-10-10 22:15:48 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			/* since we already draw wire as wp guide, dont draw over the top */ | 
					
						
							| 
									
										
										
										
											2011-11-25 02:35:23 +00:00
										 |  |  | 			draw_wire= OBDRAW_WIRE_OFF; | 
					
						
							| 
									
										
										
										
											2009-10-27 19:53:34 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
											  
											
												Add weight preview to WeightVG modifiers, and first, simple/basic refactor of how modifiers can generate preview.
User side:
* Preview for DynamicPaint should keep the same behavior (for now). Weight preview should be somawhat quicker, though.
* Preview for WeightVG modifiers is only active in WeightPaint mode, and if the affected vgroup is the active one.
* Last active preview modifier in stack wins!
Note: that modifier preview topic is yet to be further refined, quite raw/incomplete for now.
Dev side:
* In draw code, renamed DRAW_DYNAMIC_PAINT_PREVIEW flag to DRAW_MODIFIERS_PREVIEW
* Removed use of MOD_DPAINT_PREVIEW_READY in DynamicPaint code (seems unecessary, and if it was, should be of more general scope).
* Added eModifierTypeFlag_UsesPreview to ModifierTypeFlag, for modifiers that can generate some preview data.
* Added three new modifier funcs, to handle preview modifiers in draw code / mod stack.
* For weights preview: added the generic DM_update_weight_mcol func, which can update WEIGHT_MCOL layer with either a given array of weights (currently used by DynamicPaint only), or from current active vgroup(s).
So now, draw code is fully generic (i.e. no more modifier-type checking in it). Mod stack code is generic to some extent, but will need more work.
											
										 
											2012-01-22 17:54:23 +00:00
										 |  |  | 		else if (draw_flags & DRAW_MODIFIERS_PREVIEW) { | 
					
						
							| 
									
										
										
										
											2011-06-16 10:41:00 +00:00
										 |  |  | 			/* for object selection draws no shade */ | 
					
						
							|  |  |  | 			if (flag & (DRAW_PICKING|DRAW_CONSTCOLOR)) { | 
					
						
							|  |  |  | 				dm->drawFacesSolid(dm, NULL, 0, GPU_enable_material); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							|  |  |  | 				/* draw outline */ | 
					
						
							| 
									
										
										
										
											2011-11-25 02:35:23 +00:00
										 |  |  | 				if ( (v3d->flag & V3D_SELECT_OUTLINE) && | 
					
						
							|  |  |  | 				     ((v3d->flag2 & V3D_RENDER_OVERRIDE)==0) && | 
					
						
							|  |  |  | 				     (base->flag & SELECT) && | 
					
						
							|  |  |  | 				     (draw_wire == OBDRAW_WIRE_OFF) && | 
					
						
							|  |  |  | 				     (ob->sculpt == NULL)) | 
					
						
							|  |  |  | 				{ | 
					
						
							| 
									
										
										
										
											2011-06-16 10:41:00 +00:00
										 |  |  | 					draw_mesh_object_outline(v3d, ob, dm); | 
					
						
							| 
									
										
										
										
											2011-11-25 02:35:23 +00:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2011-06-16 10:41:00 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				/* materials arent compatible with vertex colors */ | 
					
						
							|  |  |  | 				GPU_end_object_materials(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				GPU_enable_material(0, NULL); | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				/* set default spec */ | 
					
						
							|  |  |  | 				glColorMaterial(GL_FRONT_AND_BACK, GL_SPECULAR); | 
					
						
							|  |  |  | 				glEnable(GL_COLOR_MATERIAL);	/* according manpages needed */ | 
					
						
							|  |  |  | 				glColor3ub(120, 120, 120); | 
					
						
							|  |  |  | 				glDisable(GL_COLOR_MATERIAL); | 
					
						
							|  |  |  | 				/* diffuse */ | 
					
						
							|  |  |  | 				glColorMaterial(GL_FRONT_AND_BACK, GL_DIFFUSE); | 
					
						
							|  |  |  | 				glEnable(GL_LIGHTING); | 
					
						
							|  |  |  | 				glEnable(GL_COLOR_MATERIAL); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-01 12:12:39 +00:00
										 |  |  | 				dm->drawMappedFaces(dm, NULL, GPU_enable_material, NULL, NULL, 1); | 
					
						
							| 
									
										
										
										
											2011-06-16 10:41:00 +00:00
										 |  |  | 				glDisable(GL_COLOR_MATERIAL); | 
					
						
							|  |  |  | 				glDisable(GL_LIGHTING); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				GPU_disable_material(); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2010-01-14 12:51:17 +00:00
										 |  |  | 		else { | 
					
						
							|  |  |  | 			Paint *p; | 
					
						
							| 
									
										
										
										
											2009-10-27 19:53:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-25 02:35:23 +00:00
										 |  |  | 			if ( (v3d->flag & V3D_SELECT_OUTLINE) && | 
					
						
							|  |  |  | 			     ((v3d->flag2 & V3D_RENDER_OVERRIDE)==0) && | 
					
						
							|  |  |  | 			     (base->flag & SELECT) && | 
					
						
							|  |  |  | 			     (draw_wire == OBDRAW_WIRE_OFF) && | 
					
						
							|  |  |  | 			     (ob->sculpt == NULL)) | 
					
						
							|  |  |  | 			{ | 
					
						
							| 
									
										
										
										
											2010-01-14 12:51:17 +00:00
										 |  |  | 				draw_mesh_object_outline(v3d, ob, dm); | 
					
						
							| 
									
										
										
										
											2011-11-25 02:35:23 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-14 12:51:17 +00:00
										 |  |  | 			glLightModeli(GL_LIGHT_MODEL_TWO_SIDE, me->flag & ME_TWOSIDED ); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-14 12:51:17 +00:00
										 |  |  | 			glEnable(GL_LIGHTING); | 
					
						
							|  |  |  | 			glFrontFace((ob->transflag&OB_NEG_SCALE)?GL_CW:GL_CCW); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			if(ob->sculpt && (p=paint_get_active(scene))) { | 
					
						
							|  |  |  | 				float planes[4][4]; | 
					
						
							|  |  |  | 				float (*fpl)[4] = NULL; | 
					
						
							|  |  |  | 				int fast= (p->flags & PAINT_FAST_NAVIGATE) && (rv3d->rflag & RV3D_NAVIGATING); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				if(ob->sculpt->partial_redraw) { | 
					
						
							| 
									
										
										
										
											2010-03-22 11:59:36 +00:00
										 |  |  | 					if(ar->do_draw & RGN_DRAW_PARTIAL) { | 
					
						
							|  |  |  | 						sculpt_get_redraw_planes(planes, ar, rv3d, ob); | 
					
						
							|  |  |  | 						fpl = planes; | 
					
						
							|  |  |  | 						ob->sculpt->partial_redraw = 0; | 
					
						
							|  |  |  | 					} | 
					
						
							| 
									
										
										
										
											2010-01-14 12:51:17 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				dm->drawFacesSolid(dm, fpl, fast, GPU_enable_material); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else | 
					
						
							|  |  |  | 				dm->drawFacesSolid(dm, NULL, 0, GPU_enable_material); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			GPU_disable_material(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			glFrontFace(GL_CCW); | 
					
						
							|  |  |  | 			glDisable(GL_LIGHTING); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			if(base->flag & SELECT) { | 
					
						
							| 
									
										
										
										
											2011-12-03 20:26:53 +00:00
										 |  |  | 				UI_ThemeColor(is_obact ? TH_ACTIVE : TH_SELECT); | 
					
						
							| 
									
										
										
										
											2010-01-14 12:51:17 +00:00
										 |  |  | 			} else { | 
					
						
							|  |  |  | 				UI_ThemeColor(TH_WIRE); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2010-05-23 10:48:35 +00:00
										 |  |  | 			if(!ob->sculpt && (v3d->flag2 & V3D_RENDER_OVERRIDE)==0) | 
					
						
							| 
									
										
										
										
											2010-01-14 12:51:17 +00:00
										 |  |  | 				dm->drawLooseEdges(dm); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-11-02 18:20:53 +00:00
										 |  |  | 	else if(dt==OB_PAINT) { | 
					
						
							| 
									
										
										
										
											2011-12-03 20:26:53 +00:00
										 |  |  | 		if (is_obact) { | 
					
						
							| 
									
										
										
										
											2009-08-15 21:46:25 +00:00
										 |  |  | 			if(ob && ob->mode & OB_MODE_WEIGHT_PAINT) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				/* enforce default material settings */ | 
					
						
							|  |  |  | 				GPU_enable_material(0, NULL); | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				/* but set default spec */ | 
					
						
							|  |  |  | 				glColorMaterial(GL_FRONT_AND_BACK, GL_SPECULAR); | 
					
						
							|  |  |  | 				glEnable(GL_COLOR_MATERIAL);	/* according manpages needed */ | 
					
						
							|  |  |  | 				glColor3ub(120, 120, 120); | 
					
						
							|  |  |  | 				glDisable(GL_COLOR_MATERIAL); | 
					
						
							|  |  |  | 				/* diffuse */ | 
					
						
							|  |  |  | 				glColorMaterial(GL_FRONT_AND_BACK, GL_DIFFUSE); | 
					
						
							|  |  |  | 				glEnable(GL_LIGHTING); | 
					
						
							|  |  |  | 				glEnable(GL_COLOR_MATERIAL); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-05 03:25:13 +00:00
										 |  |  | 				dm->drawMappedFaces(dm, wpaint__setSolidDrawOptions, GPU_enable_material, NULL, me->mpoly, 1); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				glDisable(GL_COLOR_MATERIAL); | 
					
						
							|  |  |  | 				glDisable(GL_LIGHTING); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				GPU_disable_material(); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2009-08-16 01:25:53 +00:00
										 |  |  | 			else if(ob->mode & (OB_MODE_VERTEX_PAINT|OB_MODE_TEXTURE_PAINT)) { | 
					
						
							| 
									
										
										
										
											2012-02-08 11:52:44 +00:00
										 |  |  | 				if(me->mloopcol) | 
					
						
							| 
									
										
										
										
											2011-12-01 12:12:39 +00:00
										 |  |  | 					dm->drawMappedFaces(dm, wpaint__setSolidDrawOptions, GPU_enable_material, NULL, NULL, 1); | 
					
						
							| 
									
										
										
										
											2009-08-15 20:36:15 +00:00
										 |  |  | 				else { | 
					
						
							|  |  |  | 					glColor3f(1.0f, 1.0f, 1.0f); | 
					
						
							| 
									
										
										
										
											2011-12-01 12:12:39 +00:00
										 |  |  | 					dm->drawMappedFaces(dm, wpaint__setSolidDrawOptions, GPU_enable_material, NULL, NULL, 0); | 
					
						
							| 
									
										
										
										
											2009-08-15 20:36:15 +00:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* set default draw color back for wire or for draw-extra later on */ | 
					
						
							|  |  |  | 	if (dt!=OB_WIRE) { | 
					
						
							|  |  |  | 		if(base->flag & SELECT) { | 
					
						
							| 
									
										
										
										
											2011-12-03 20:26:53 +00:00
										 |  |  | 			if (is_obact && ob->flag & OB_FROMGROUP) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				UI_ThemeColor(TH_GROUP_ACTIVE); | 
					
						
							|  |  |  | 			else if(ob->flag & OB_FROMGROUP)  | 
					
						
							|  |  |  | 				UI_ThemeColorShade(TH_GROUP_ACTIVE, -16); | 
					
						
							|  |  |  | 			else if(flag!=DRAW_CONSTCOLOR) | 
					
						
							| 
									
										
										
										
											2011-12-03 20:26:53 +00:00
										 |  |  | 				UI_ThemeColor(is_obact ? TH_ACTIVE : TH_SELECT); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			else | 
					
						
							|  |  |  | 				glColor3ub(80,80,80); | 
					
						
							|  |  |  | 		} else { | 
					
						
							|  |  |  | 			if (ob->flag & OB_FROMGROUP)  | 
					
						
							|  |  |  | 				UI_ThemeColor(TH_GROUP); | 
					
						
							|  |  |  | 			else { | 
					
						
							|  |  |  | 				if(ob->dtx & OB_DRAWWIRE && flag==DRAW_CONSTCOLOR) | 
					
						
							|  |  |  | 					glColor3ub(80,80,80); | 
					
						
							|  |  |  | 				else | 
					
						
							|  |  |  | 					UI_ThemeColor(TH_WIRE); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-11-25 02:35:23 +00:00
										 |  |  | 	if (draw_wire != OBDRAW_WIRE_OFF) { | 
					
						
							| 
									
										
										
										
											2010-01-11 18:10:13 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* When using wireframe object traw in particle edit mode
 | 
					
						
							|  |  |  | 		 * the mesh gets in the way of seeing the particles, fade the wire color | 
					
						
							|  |  |  | 		 * with the background. */ | 
					
						
							| 
									
										
										
										
											2011-12-03 20:26:53 +00:00
										 |  |  | 		if(is_obact && (ob->mode & OB_MODE_PARTICLE_EDIT)) { | 
					
						
							| 
									
										
										
										
											2010-01-11 18:10:13 +00:00
										 |  |  | 			float col_wire[4], col_bg[4], col[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			UI_GetThemeColor3fv(TH_BACK, col_bg); | 
					
						
							|  |  |  | 			glGetFloatv(GL_CURRENT_COLOR, col_wire); | 
					
						
							|  |  |  | 			interp_v3_v3v3(col, col_bg, col_wire, 0.15); | 
					
						
							|  |  |  | 			glColor3fv(col); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* If drawing wire and drawtype is not OB_WIRE then we are
 | 
					
						
							|  |  |  | 		 * overlaying the wires. | 
					
						
							|  |  |  | 		 * | 
					
						
							|  |  |  | 		 * UPDATE bug #10290 - With this wire-only objects can draw | 
					
						
							|  |  |  | 		 * behind other objects depending on their order in the scene. 2x if 0's below. undo'ing zr's commit: r4059 | 
					
						
							|  |  |  | 		 * | 
					
						
							|  |  |  | 		 * if draw wire is 1 then just drawing wire, no need for depth buffer stuff, | 
					
						
							|  |  |  | 		 * otherwise this wire is to overlay solid mode faces so do some depth buffer tricks. | 
					
						
							|  |  |  | 		 */ | 
					
						
							| 
									
										
										
										
											2011-11-25 02:35:23 +00:00
										 |  |  | 		if (dt!=OB_WIRE && (draw_wire == OBDRAW_WIRE_ON_DEPTH)) { | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | 			bglPolygonOffset(rv3d->dist, 1.0); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			glDepthMask(0);	// disable write in zbuffer, selected edge wires show better
 | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2010-05-20 09:17:49 +00:00
										 |  |  | 		if((v3d->flag2 & V3D_RENDER_OVERRIDE && v3d->drawtype >= OB_SOLID)==0) | 
					
						
							| 
									
										
										
										
											2010-06-13 02:54:55 +00:00
										 |  |  | 			dm->drawEdges(dm, (dt==OB_WIRE || totface==0), me->drawflag & ME_ALLEDGES); | 
					
						
							| 
									
										
										
										
											2010-05-20 09:17:49 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-25 02:35:23 +00:00
										 |  |  | 		if (dt!=OB_WIRE && (draw_wire == OBDRAW_WIRE_ON_DEPTH)) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			glDepthMask(1); | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | 			bglPolygonOffset(rv3d->dist, 0.0); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-09-18 17:10:28 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2011-12-03 20:26:53 +00:00
										 |  |  | 	if(is_obact && paint_vertsel_test(ob)) { | 
					
						
							| 
									
										
										
										
											2011-09-18 01:09:18 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2011-07-18 16:47:21 +00:00
										 |  |  | 		glColor3f(0.0f, 0.0f, 0.0f); | 
					
						
							| 
									
										
										
										
											2011-08-09 16:32:15 +00:00
										 |  |  | 		glPointSize(UI_GetThemeValuef(TH_VERTEX_SIZE)); | 
					
						
							| 
									
										
										
										
											2011-09-18 01:09:18 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		drawSelectedVertices(dm, ob->data); | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2011-07-18 16:47:21 +00:00
										 |  |  | 		glPointSize(1.0f); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	dm->release(dm); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* returns 1 if nothing was drawn, for detecting to draw an object center */ | 
					
						
							| 
									
										
										
										
											2009-10-27 19:53:34 +00:00
										 |  |  | static int draw_mesh_object(Scene *scene, ARegion *ar, View3D *v3d, RegionView3D *rv3d, Base *base, int dt, int flag) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	Object *ob= base->object; | 
					
						
							| 
									
										
										
										
											2009-01-24 13:45:24 +00:00
										 |  |  | 	Object *obedit= scene->obedit; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	Mesh *me= ob->data; | 
					
						
							| 
									
										
										
										
											2009-05-18 08:46:04 +00:00
										 |  |  | 	BMEditMesh *em= me->edit_btmesh; | 
					
						
							| 
									
										
										
										
											2011-12-07 22:03:49 +00:00
										 |  |  | 	int do_alpha_after= 0, drawlinked= 0, retval= 0, glsl, check_alpha, i; | 
					
						
							| 
									
										
										
										
											2011-08-24 20:28:54 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-25 15:49:52 +00:00
										 |  |  | 	/* If we are drawing shadows and any of the materials don't cast a shadow,
 | 
					
						
							|  |  |  | 	 * then don't draw the object */ | 
					
						
							|  |  |  | 	if (v3d->flag2 & V3D_RENDER_SHADOW) { | 
					
						
							|  |  |  | 		for(i=0; i<ob->totcol; ++i) { | 
					
						
							|  |  |  | 			Material *ma= give_current_material(ob, i); | 
					
						
							|  |  |  | 			if (ma && !(ma->mode & MA_SHADBUF)) { | 
					
						
							| 
									
										
										
										
											2011-08-24 20:28:54 +00:00
										 |  |  | 				return 1; | 
					
						
							| 
									
										
										
										
											2011-08-25 15:49:52 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2011-08-24 20:28:54 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-01-02 19:10:35 +00:00
										 |  |  | 	if(obedit && ob!=obedit && ob->data==obedit->data) { | 
					
						
							| 
									
										
										
										
											2010-08-06 17:41:45 +00:00
										 |  |  | 		if(ob_get_key(ob) || ob_get_key(obedit)); | 
					
						
							|  |  |  | 		else if(ob->modifiers.first || obedit->modifiers.first); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		else drawlinked= 1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-01-02 19:10:35 +00:00
										 |  |  | 	if(ob==obedit || drawlinked) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		DerivedMesh *finalDM, *cageDM; | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2009-01-02 19:10:35 +00:00
										 |  |  | 		if (obedit!=ob) | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 			finalDM = cageDM = editbmesh_get_derived_base(ob, em); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		else | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 			cageDM = editbmesh_get_derived_cage_and_final(scene, ob, em, &finalDM, | 
					
						
							| 
									
										
										
										
											2010-12-23 04:26:53 +00:00
										 |  |  | 											scene->customdata_mask); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		if(dt>OB_WIRE) { | 
					
						
							|  |  |  | 			glsl = draw_glsl_material(scene, ob, v3d, dt); | 
					
						
							| 
									
										
											  
											
												TexFace to Material Settings big patch
Summary:
========
The idea here is to move the texface options into the material panel.
For images with the change please visit:
http://code.blender.org/index.php/2011/09/bge-material-texface-changes
1 - Some of the legacy problems 2.49 and 2.5x has with the texface system:
==========================================================================
1.1) Shadow, Bilboard and Halo are mutual exclusive (in the code), yet you can
select a face to be more than one mode.
1.2) Sort only works for blend Alpha yet it's an option regardless of the
Transparency Blend you pick.
1.3) Shared doesn't affect anything in BGE.
1.4) ObColor only works for Text objects (old bitmap texts) when using Texture
Face Materials. (not address yet, I so far ignored obcolor)
2 - Notes:
============
2.1) Now "Use Face Textures" in material Option panel will work in Multitexture
even if there is no texture channel.
2.2) In FaceTexture mode it will use TexFace all the time, even if you don't
check the "Use Texture Face" option in the UI. It's a matter of decision, since
the code for either way is there. I decided by the solution that makes the
creation of a material fast - in this mode the user doesn't need to mess with
textures or this "Use Texture Face" option at all. I'm not strong in my opinion
here. But I think if we don't have this then what is the point of the Texture
Face mode?
2.3) I kept references for tface only when we need the image, UV or the tiling
setting. It should help later when/if we split the Image and UV layers from the
tface struct  (Campbell and Brecht proposal).
3 - Changes in a Nutshell:
==========================
3.1) "Texture Face" panel (in the Mesh/Object Data panel) no longer exists. Those settings are all part of the material properties, visible when Game Render is set.
3.2) "Texture Face" Shading mode (in the Render panel) is now called “Single Texture”, it needs a material for special settings (e.g. Billboard, Alpha Sort, …).
3.3) New options in the Material Panel
* Shadeless option in the Material panel is now supported for all three Shading modes.
* Physics is now toggleable, this is the old Collision option.
* Two Side (on) is now called Back Culling (off).
* Alpha Sort is one of the Alpha options, together (and mutually exclusive) to Alpha Blend, Alpha Clip, Add and Opaque (i.e. solid).
* Shadow, Billboard and Halo are grouped in the “Face Orientation” property.
* "Face Textures" and "Face Textures Alpha" (under Options) can be used for all but GLSL shading mode (to be supported in GLSL eventually).
* The backend in the game engine is still the same as before. The only changes are in the interface and in the way you need to think your materials. The bottomline is: It’s no longer possible to share materials between faces that do not share the same game properties.
4 - Acknowledgment:
==================
Mike Pan for the design discussions, and testing along the whole development process.
Vitor Balbio for the first hands-on code with the interface changes. That helped me a lot to push me into work on that.
Benoit Bolsee and Brecht van Lommel for patch review (* no one reviewed the whole patch, or the latest iteractions, so I still hold liability for any problems).
Blender artists that gave feedback and helped testing the patch.
Patch review and original documentation can be found here:
http://wiki.blender.org/index.php/User:Dfelinto/TexFace
http://codereview.appspot.com/4289041/
											
										 
											2011-09-19 19:55:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-25 12:55:42 +00:00
										 |  |  | 			GPU_begin_object_materials(v3d, rv3d, scene, ob, glsl, NULL); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-25 12:55:42 +00:00
										 |  |  | 		draw_em_fancy(scene, v3d, rv3d, ob, em, cageDM, finalDM, dt); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-13 00:40:20 +00:00
										 |  |  | 		GPU_end_object_materials(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-02 19:10:35 +00:00
										 |  |  | 		if (obedit!=ob && finalDM) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			finalDM->release(finalDM); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		/* don't create boundbox here with mesh_get_bb(), the derived system will make it, puts deformed bb's OK */ | 
					
						
							| 
									
										
										
										
											2012-02-15 14:40:45 +00:00
										 |  |  | 		if(me->totpoly <= 4 || ED_view3d_boundbox_clip(rv3d, ob->obmat, (ob->bb)? ob->bb: me->bb)) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			glsl = draw_glsl_material(scene, ob, v3d, dt); | 
					
						
							| 
									
										
										
										
											2011-12-07 22:03:49 +00:00
										 |  |  | 			check_alpha = check_alpha_pass(base); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			if(dt==OB_SOLID || glsl) { | 
					
						
							| 
									
										
										
										
											2009-07-13 00:40:20 +00:00
										 |  |  | 				GPU_begin_object_materials(v3d, rv3d, scene, ob, glsl, | 
					
						
							| 
									
										
										
										
											2011-12-07 22:03:49 +00:00
										 |  |  | 					(check_alpha)? &do_alpha_after: NULL); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-27 19:53:34 +00:00
										 |  |  | 			draw_mesh_fancy(scene, ar, v3d, rv3d, base, dt, flag); | 
					
						
							| 
									
										
										
										
											2009-07-13 00:40:20 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			GPU_end_object_materials(); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			if(me->totvert==0) retval= 1; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-13 00:40:20 +00:00
										 |  |  | 	/* GPU_begin_object_materials checked if this is needed */ | 
					
						
							| 
									
										
										
										
											2011-12-07 22:03:49 +00:00
										 |  |  | 	if(do_alpha_after) { | 
					
						
							| 
									
										
										
										
											2010-09-07 05:47:34 +00:00
										 |  |  | 		if(ob->dtx & OB_DRAWXRAY) { | 
					
						
							|  |  |  | 			add_view3d_after(&v3d->afterdraw_xraytransp, base, flag); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							|  |  |  | 			add_view3d_after(&v3d->afterdraw_transp, base, flag); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else if(ob->dtx & OB_DRAWXRAY && ob->dtx & OB_DRAWTRANSP) { | 
					
						
							|  |  |  | 		/* special case xray+transp when alpha is 1.0, without this the object vanishes */ | 
					
						
							|  |  |  | 		if(v3d->xray == 0 && v3d->transp == 0) { | 
					
						
							|  |  |  | 			add_view3d_after(&v3d->afterdraw_xray, base, flag); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	return retval; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************** DRAW DISPLIST ****************** */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int draw_index_wire= 1; | 
					
						
							|  |  |  | static int index3_nors_incr= 1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* returns 1 when nothing was drawn */ | 
					
						
							|  |  |  | static int drawDispListwire(ListBase *dlbase) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	DispList *dl; | 
					
						
							|  |  |  | 	int parts, nr; | 
					
						
							|  |  |  | 	float *data; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(dlbase==NULL) return 1; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-12-09 14:37:26 +00:00
										 |  |  | 	glEnableClientState(GL_VERTEX_ARRAY); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	glPolygonMode(GL_FRONT_AND_BACK, GL_LINE);  | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for(dl= dlbase->first; dl; dl= dl->next) { | 
					
						
							|  |  |  | 		if(dl->parts==0 || dl->nr==0) | 
					
						
							|  |  |  | 			continue; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		data= dl->verts; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 		switch(dl->type) { | 
					
						
							|  |  |  | 		case DL_SEGM: | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			glVertexPointer(3, GL_FLOAT, 0, data); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			for(parts=0; parts<dl->parts; parts++) | 
					
						
							|  |  |  | 				glDrawArrays(GL_LINE_STRIP, parts*dl->nr, dl->nr); | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case DL_POLY: | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			glVertexPointer(3, GL_FLOAT, 0, data); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			for(parts=0; parts<dl->parts; parts++) | 
					
						
							|  |  |  | 				glDrawArrays(GL_LINE_LOOP, parts*dl->nr, dl->nr); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case DL_SURF: | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			glVertexPointer(3, GL_FLOAT, 0, data); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			for(parts=0; parts<dl->parts; parts++) { | 
					
						
							|  |  |  | 				if(dl->flag & DL_CYCL_U)  | 
					
						
							|  |  |  | 					glDrawArrays(GL_LINE_LOOP, parts*dl->nr, dl->nr); | 
					
						
							|  |  |  | 				else | 
					
						
							|  |  |  | 					glDrawArrays(GL_LINE_STRIP, parts*dl->nr, dl->nr); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			for(nr=0; nr<dl->nr; nr++) { | 
					
						
							|  |  |  | 				int ofs= 3*dl->nr; | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				data= (  dl->verts )+3*nr; | 
					
						
							|  |  |  | 				parts= dl->parts; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				if(dl->flag & DL_CYCL_V) glBegin(GL_LINE_LOOP); | 
					
						
							|  |  |  | 				else glBegin(GL_LINE_STRIP); | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				while(parts--) { | 
					
						
							|  |  |  | 					glVertex3fv(data); | 
					
						
							|  |  |  | 					data+=ofs; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				glEnd(); | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				/* (ton) this code crashes for me when resolv is 86 or higher... no clue */ | 
					
						
							|  |  |  | //				glVertexPointer(3, GL_FLOAT, sizeof(float)*3*dl->nr, data + 3*nr);
 | 
					
						
							|  |  |  | //				if(dl->flag & DL_CYCL_V) 
 | 
					
						
							|  |  |  | //					glDrawArrays(GL_LINE_LOOP, 0, dl->parts);
 | 
					
						
							|  |  |  | //				else
 | 
					
						
							|  |  |  | //					glDrawArrays(GL_LINE_STRIP, 0, dl->parts);
 | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 		case DL_INDEX3: | 
					
						
							|  |  |  | 			if(draw_index_wire) { | 
					
						
							|  |  |  | 				glVertexPointer(3, GL_FLOAT, 0, dl->verts); | 
					
						
							|  |  |  | 				glDrawElements(GL_TRIANGLES, 3*dl->parts, GL_UNSIGNED_INT, dl->index); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 		case DL_INDEX4: | 
					
						
							|  |  |  | 			if(draw_index_wire) { | 
					
						
							|  |  |  | 				glVertexPointer(3, GL_FLOAT, 0, dl->verts); | 
					
						
							|  |  |  | 				glDrawElements(GL_QUADS, 4*dl->parts, GL_UNSIGNED_INT, dl->index); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-12-09 14:37:26 +00:00
										 |  |  | 	glDisableClientState(GL_VERTEX_ARRAY); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	glPolygonMode(GL_FRONT_AND_BACK, GL_FILL);  | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void drawDispListsolid(ListBase *lb, Object *ob, int glsl) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	DispList *dl; | 
					
						
							|  |  |  | 	GPUVertexAttribs gattribs; | 
					
						
							|  |  |  | 	float *data, curcol[4]; | 
					
						
							|  |  |  | 	float *ndata; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if(lb==NULL) return; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* for drawing wire */ | 
					
						
							|  |  |  | 	glGetFloatv(GL_CURRENT_COLOR, curcol); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glEnable(GL_LIGHTING); | 
					
						
							| 
									
										
										
										
											2009-12-09 14:37:26 +00:00
										 |  |  | 	glEnableClientState(GL_VERTEX_ARRAY); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	if(ob->transflag & OB_NEG_SCALE) glFrontFace(GL_CW); | 
					
						
							|  |  |  | 	else glFrontFace(GL_CCW); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if(ob->type==OB_MBALL) {	// mball always smooth shaded
 | 
					
						
							|  |  |  | 		glShadeModel(GL_SMOOTH); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	dl= lb->first; | 
					
						
							|  |  |  | 	while(dl) { | 
					
						
							|  |  |  | 		data= dl->verts; | 
					
						
							|  |  |  | 		ndata= dl->nors; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		switch(dl->type) { | 
					
						
							|  |  |  | 		case DL_SEGM: | 
					
						
							|  |  |  | 			if(ob->type==OB_SURF) { | 
					
						
							|  |  |  | 				int nr; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				glDisable(GL_LIGHTING); | 
					
						
							|  |  |  | 				glColor3fv(curcol); | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				// glVertexPointer(3, GL_FLOAT, 0, dl->verts);
 | 
					
						
							|  |  |  | 				// glDrawArrays(GL_LINE_STRIP, 0, dl->nr);
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				glBegin(GL_LINE_STRIP); | 
					
						
							|  |  |  | 				for(nr= dl->nr; nr; nr--, data+=3) | 
					
						
							|  |  |  | 					glVertex3fv(data); | 
					
						
							|  |  |  | 				glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				glEnable(GL_LIGHTING); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case DL_POLY: | 
					
						
							|  |  |  | 			if(ob->type==OB_SURF) { | 
					
						
							|  |  |  | 				int nr; | 
					
						
							| 
									
										
										
										
											2010-03-12 16:43:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				glDisable(GL_LIGHTING); | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				/* for some reason glDrawArrays crashes here in half of the platforms (not osx) */ | 
					
						
							|  |  |  | 				//glVertexPointer(3, GL_FLOAT, 0, dl->verts);
 | 
					
						
							|  |  |  | 				//glDrawArrays(GL_LINE_LOOP, 0, dl->nr);
 | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				glBegin(GL_LINE_LOOP); | 
					
						
							|  |  |  | 				for(nr= dl->nr; nr; nr--, data+=3) | 
					
						
							|  |  |  | 					glVertex3fv(data); | 
					
						
							|  |  |  | 				glEnd(); | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				glEnable(GL_LIGHTING); | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		case DL_SURF: | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if(dl->index) { | 
					
						
							|  |  |  | 				GPU_enable_material(dl->col+1, (glsl)? &gattribs: NULL); | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				if(dl->rt & CU_SMOOTH) glShadeModel(GL_SMOOTH); | 
					
						
							|  |  |  | 				else glShadeModel(GL_FLAT); | 
					
						
							| 
									
										
										
										
											2009-12-09 14:37:26 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				glEnableClientState(GL_NORMAL_ARRAY); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				glVertexPointer(3, GL_FLOAT, 0, dl->verts); | 
					
						
							|  |  |  | 				glNormalPointer(GL_FLOAT, 0, dl->nors); | 
					
						
							|  |  |  | 				glDrawElements(GL_QUADS, 4*dl->totindex, GL_UNSIGNED_INT, dl->index); | 
					
						
							| 
									
										
										
										
											2009-12-09 14:37:26 +00:00
										 |  |  | 				glDisableClientState(GL_NORMAL_ARRAY); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			}			 | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		case DL_INDEX3: | 
					
						
							|  |  |  | 			GPU_enable_material(dl->col+1, (glsl)? &gattribs: NULL); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			glVertexPointer(3, GL_FLOAT, 0, dl->verts); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* voor polys only one normal needed */ | 
					
						
							| 
									
										
										
										
											2009-12-09 14:37:26 +00:00
										 |  |  | 			if(index3_nors_incr) { | 
					
						
							|  |  |  | 				glEnableClientState(GL_NORMAL_ARRAY); | 
					
						
							|  |  |  | 				glNormalPointer(GL_FLOAT, 0, dl->nors); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else | 
					
						
							| 
									
										
										
										
											2009-12-09 14:37:26 +00:00
										 |  |  | 				glNormal3fv(ndata); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			glDrawElements(GL_TRIANGLES, 3*dl->parts, GL_UNSIGNED_INT, dl->index); | 
					
						
							|  |  |  | 			 | 
					
						
							| 
									
										
										
										
											2009-12-09 14:37:26 +00:00
										 |  |  | 			if(index3_nors_incr) | 
					
						
							|  |  |  | 				glDisableClientState(GL_NORMAL_ARRAY); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		case DL_INDEX4: | 
					
						
							|  |  |  | 			GPU_enable_material(dl->col+1, (glsl)? &gattribs: NULL); | 
					
						
							|  |  |  | 			 | 
					
						
							| 
									
										
										
										
											2009-12-09 14:37:26 +00:00
										 |  |  | 			glEnableClientState(GL_NORMAL_ARRAY); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			glVertexPointer(3, GL_FLOAT, 0, dl->verts); | 
					
						
							|  |  |  | 			glNormalPointer(GL_FLOAT, 0, dl->nors); | 
					
						
							|  |  |  | 			glDrawElements(GL_QUADS, 4*dl->parts, GL_UNSIGNED_INT, dl->index); | 
					
						
							| 
									
										
										
										
											2009-12-09 14:37:26 +00:00
										 |  |  | 			glDisableClientState(GL_NORMAL_ARRAY); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		dl= dl->next; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-09 14:37:26 +00:00
										 |  |  | 	glDisableClientState(GL_VERTEX_ARRAY); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	glShadeModel(GL_FLAT); | 
					
						
							|  |  |  | 	glDisable(GL_LIGHTING); | 
					
						
							|  |  |  | 	glFrontFace(GL_CCW); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-05 16:47:52 +00:00
										 |  |  | static void drawCurveDMWired(Object *ob) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	DerivedMesh *dm = ob->derivedFinal; | 
					
						
							| 
									
										
										
										
											2010-03-22 11:59:36 +00:00
										 |  |  | 	dm->drawEdges (dm, 1, 0); | 
					
						
							| 
									
										
										
										
											2010-03-05 16:47:52 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* return 1 when nothing was drawn */ | 
					
						
							|  |  |  | static int drawCurveDerivedMesh(Scene *scene, View3D *v3d, RegionView3D *rv3d, Base *base, int dt) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	Object *ob= base->object; | 
					
						
							|  |  |  | 	DerivedMesh *dm = ob->derivedFinal; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (!dm) { | 
					
						
							|  |  |  | 		return 1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-29 13:01:51 +00:00
										 |  |  | 	if(dt>OB_WIRE && dm->getNumTessFaces(dm)) { | 
					
						
							| 
									
										
										
										
											2010-03-05 16:47:52 +00:00
										 |  |  | 		int glsl = draw_glsl_material(scene, ob, v3d, dt); | 
					
						
							|  |  |  | 		GPU_begin_object_materials(v3d, rv3d, scene, ob, glsl, NULL); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-20 21:57:29 +00:00
										 |  |  | 		if(!glsl) { | 
					
						
							| 
									
										
										
										
											2010-03-05 16:47:52 +00:00
										 |  |  | 			glLightModeli(GL_LIGHT_MODEL_TWO_SIDE, 0); | 
					
						
							| 
									
										
										
										
											2010-09-20 21:57:29 +00:00
										 |  |  | 			glEnable(GL_LIGHTING); | 
					
						
							|  |  |  | 			dm->drawFacesSolid(dm, NULL, 0, GPU_enable_material); | 
					
						
							|  |  |  | 			glDisable(GL_LIGHTING); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else | 
					
						
							|  |  |  | 			dm->drawFacesGLSL(dm, GPU_enable_material); | 
					
						
							| 
									
										
										
										
											2010-03-05 16:47:52 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		GPU_end_object_materials(); | 
					
						
							|  |  |  | 	} else { | 
					
						
							| 
									
										
										
										
											2010-05-20 09:17:49 +00:00
										 |  |  | 		if((v3d->flag2 & V3D_RENDER_OVERRIDE && v3d->drawtype >= OB_SOLID)==0) | 
					
						
							|  |  |  | 			drawCurveDMWired (ob); | 
					
						
							| 
									
										
										
										
											2010-03-05 16:47:52 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | /* returns 1 when nothing was drawn */ | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | static int drawDispList(Scene *scene, View3D *v3d, RegionView3D *rv3d, Base *base, int dt) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	Object *ob= base->object; | 
					
						
							| 
									
										
										
										
											2011-03-03 17:59:04 +00:00
										 |  |  | 	ListBase *lb=NULL; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	DispList *dl; | 
					
						
							|  |  |  | 	Curve *cu; | 
					
						
							| 
									
										
										
										
											2011-04-05 07:26:22 +00:00
										 |  |  | 	const short render_only= (v3d->flag2 & V3D_RENDER_OVERRIDE); | 
					
						
							|  |  |  | 	const short solid= (dt > OB_WIRE); | 
					
						
							|  |  |  | 	int retval= 0; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-05 16:47:52 +00:00
										 |  |  | 	if (drawCurveDerivedMesh(scene, v3d, rv3d, base, dt) == 0) { | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	switch(ob->type) { | 
					
						
							|  |  |  | 	case OB_FONT: | 
					
						
							|  |  |  | 	case OB_CURVE: | 
					
						
							|  |  |  | 		cu= ob->data; | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2011-01-05 10:40:38 +00:00
										 |  |  | 		lb= &ob->disp; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		if(solid) { | 
					
						
							|  |  |  | 			dl= lb->first; | 
					
						
							|  |  |  | 			if(dl==NULL) return 1; | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-03 17:59:04 +00:00
										 |  |  | 			if(dl->nors==NULL) addnormalsDispList(lb); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			index3_nors_incr= 0; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if( displist_has_faces(lb)==0) { | 
					
						
							| 
									
										
										
										
											2011-04-05 07:26:22 +00:00
										 |  |  | 				if(!render_only) { | 
					
						
							| 
									
										
										
										
											2011-04-04 22:40:56 +00:00
										 |  |  | 					draw_index_wire= 0; | 
					
						
							|  |  |  | 					drawDispListwire(lb); | 
					
						
							|  |  |  | 					draw_index_wire= 1; | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							|  |  |  | 				if(draw_glsl_material(scene, ob, v3d, dt)) { | 
					
						
							| 
									
										
										
										
											2009-07-13 00:40:20 +00:00
										 |  |  | 					GPU_begin_object_materials(v3d, rv3d, scene, ob, 1, NULL); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 					drawDispListsolid(lb, ob, 1); | 
					
						
							| 
									
										
										
										
											2009-07-13 00:40:20 +00:00
										 |  |  | 					GPU_end_object_materials(); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 				else { | 
					
						
							| 
									
										
										
										
											2009-07-13 00:40:20 +00:00
										 |  |  | 					GPU_begin_object_materials(v3d, rv3d, scene, ob, 0, NULL); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 					glLightModeli(GL_LIGHT_MODEL_TWO_SIDE, 0); | 
					
						
							|  |  |  | 					drawDispListsolid(lb, ob, 0); | 
					
						
							| 
									
										
										
										
											2009-07-13 00:40:20 +00:00
										 |  |  | 					GPU_end_object_materials(); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 				if(cu->editnurb && cu->bevobj==NULL && cu->taperobj==NULL && cu->ext1 == 0.0f && cu->ext2 == 0.0f) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 					cpack(0); | 
					
						
							|  |  |  | 					draw_index_wire= 0; | 
					
						
							|  |  |  | 					drawDispListwire(lb); | 
					
						
							|  |  |  | 					draw_index_wire= 1; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			index3_nors_incr= 1; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2011-04-05 07:26:22 +00:00
										 |  |  | 			if(!render_only || (render_only && displist_has_faces(lb))) { | 
					
						
							|  |  |  | 				draw_index_wire= 0; | 
					
						
							|  |  |  | 				retval= drawDispListwire(lb); | 
					
						
							|  |  |  | 				draw_index_wire= 1; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		break; | 
					
						
							|  |  |  | 	case OB_SURF: | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-01-05 10:40:38 +00:00
										 |  |  | 		lb= &ob->disp; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		if(solid) { | 
					
						
							|  |  |  | 			dl= lb->first; | 
					
						
							|  |  |  | 			if(dl==NULL) return 1; | 
					
						
							|  |  |  | 			 | 
					
						
							| 
									
										
										
										
											2010-08-04 04:01:27 +00:00
										 |  |  | 			if(dl->nors==NULL) addnormalsDispList(lb); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			if(draw_glsl_material(scene, ob, v3d, dt)) { | 
					
						
							| 
									
										
										
										
											2009-07-13 00:40:20 +00:00
										 |  |  | 				GPU_begin_object_materials(v3d, rv3d, scene, ob, 1, NULL); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				drawDispListsolid(lb, ob, 1); | 
					
						
							| 
									
										
										
										
											2009-07-13 00:40:20 +00:00
										 |  |  | 				GPU_end_object_materials(); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2009-07-13 00:40:20 +00:00
										 |  |  | 				GPU_begin_object_materials(v3d, rv3d, scene, ob, 0, NULL); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				glLightModeli(GL_LIGHT_MODEL_TWO_SIDE, 0); | 
					
						
							|  |  |  | 				drawDispListsolid(lb, ob, 0); | 
					
						
							| 
									
										
										
										
											2009-07-13 00:40:20 +00:00
										 |  |  | 				GPU_end_object_materials(); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							|  |  |  | 			retval= drawDispListwire(lb); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		break; | 
					
						
							|  |  |  | 	case OB_MBALL: | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		if( is_basis_mball(ob)) { | 
					
						
							|  |  |  | 			lb= &ob->disp; | 
					
						
							| 
									
										
										
										
											2009-01-04 14:14:06 +00:00
										 |  |  | 			if(lb->first==NULL) makeDispListMBall(scene, ob); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			if(lb->first==NULL) return 1; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if(solid) { | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				if(draw_glsl_material(scene, ob, v3d, dt)) { | 
					
						
							| 
									
										
										
										
											2009-07-13 00:40:20 +00:00
										 |  |  | 					GPU_begin_object_materials(v3d, rv3d, scene, ob, 1, NULL); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 					drawDispListsolid(lb, ob, 1); | 
					
						
							| 
									
										
										
										
											2009-07-13 00:40:20 +00:00
										 |  |  | 					GPU_end_object_materials(); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 				else { | 
					
						
							| 
									
										
										
										
											2009-07-13 00:40:20 +00:00
										 |  |  | 					GPU_begin_object_materials(v3d, rv3d, scene, ob, 0, NULL); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 					glLightModeli(GL_LIGHT_MODEL_TWO_SIDE, 0); | 
					
						
							|  |  |  | 					drawDispListsolid(lb, ob, 0); | 
					
						
							| 
									
										
										
										
											2009-07-13 00:40:20 +00:00
										 |  |  | 					GPU_end_object_materials(); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else{ | 
					
						
							|  |  |  | 				/* MetaBalls use DL_INDEX4 type of DispList */ | 
					
						
							|  |  |  | 				retval= drawDispListwire(lb); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		break; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	return retval; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | /* *********** drawing for particles ************* */ | 
					
						
							|  |  |  | static void draw_particle_arrays(int draw_as, int totpoint, int ob_dt, int select) | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 	/* draw created data arrays */ | 
					
						
							|  |  |  | 	switch(draw_as){ | 
					
						
							|  |  |  | 		case PART_DRAW_AXIS: | 
					
						
							|  |  |  | 		case PART_DRAW_CROSS: | 
					
						
							|  |  |  | 			glDrawArrays(GL_LINES, 0, 6*totpoint); | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case PART_DRAW_LINE: | 
					
						
							|  |  |  | 			glDrawArrays(GL_LINES, 0, 2*totpoint); | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case PART_DRAW_BB: | 
					
						
							|  |  |  | 			if(ob_dt<=OB_WIRE || select) | 
					
						
							|  |  |  | 				glPolygonMode(GL_FRONT_AND_BACK,GL_LINE); | 
					
						
							|  |  |  | 			else | 
					
						
							|  |  |  | 				glPolygonMode(GL_FRONT_AND_BACK, GL_FILL);  | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 			glDrawArrays(GL_QUADS, 0, 4*totpoint); | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		default: | 
					
						
							|  |  |  | 			glDrawArrays(GL_POINTS, 0, totpoint); | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2011-12-03 20:49:41 +00:00
										 |  |  | static void draw_particle(ParticleKey *state, int draw_as, short draw, float pixsize, | 
					
						
							|  |  |  |                           float imat[4][4], float *draw_line, ParticleBillboardData *bb, ParticleDrawData *pdd) | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	float vec[3], vec2[3]; | 
					
						
							| 
									
										
										
										
											2010-10-25 17:20:12 +00:00
										 |  |  | 	float *vd = NULL; | 
					
						
							|  |  |  | 	float *cd = NULL; | 
					
						
							| 
									
										
										
										
											2011-11-26 03:13:54 +00:00
										 |  |  | 	float ma_col[3]= {0.0f, 0.0f, 0.0f}; | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-25 17:20:12 +00:00
										 |  |  | 	/* null only for PART_DRAW_CIRC */ | 
					
						
							|  |  |  | 	if(pdd) { | 
					
						
							|  |  |  | 		vd = pdd->vd; | 
					
						
							|  |  |  | 		cd = pdd->cd; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-26 03:13:54 +00:00
										 |  |  | 		if(pdd->ma_col) { | 
					
						
							|  |  |  | 			copy_v3_v3(ma_col, pdd->ma_col); | 
					
						
							| 
									
										
										
										
											2010-10-25 17:20:12 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	switch(draw_as){ | 
					
						
							|  |  |  | 		case PART_DRAW_DOT: | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			if(vd) { | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 				copy_v3_v3(vd,state->co); pdd->vd+=3; | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			if(cd) { | 
					
						
							| 
									
										
										
										
											2011-11-26 03:13:54 +00:00
										 |  |  | 				copy_v3_v3(cd, pdd->ma_col); | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 				pdd->cd+=3; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		case PART_DRAW_CROSS: | 
					
						
							|  |  |  | 		case PART_DRAW_AXIS: | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			vec[0]=2.0f*pixsize; | 
					
						
							|  |  |  | 			vec[1]=vec[2]=0.0; | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 			mul_qt_v3(state->rot,vec); | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 			if(draw_as==PART_DRAW_AXIS) { | 
					
						
							| 
									
										
										
										
											2011-01-09 15:28:43 +00:00
										 |  |  | 				if(cd) { | 
					
						
							|  |  |  | 					cd[1]=cd[2]=cd[4]=cd[5]=0.0; | 
					
						
							|  |  |  | 					cd[0]=cd[3]=1.0; | 
					
						
							|  |  |  | 					cd[6]=cd[8]=cd[9]=cd[11]=0.0; | 
					
						
							|  |  |  | 					cd[7]=cd[10]=1.0; | 
					
						
							|  |  |  | 					cd[13]=cd[12]=cd[15]=cd[16]=0.0; | 
					
						
							|  |  |  | 					cd[14]=cd[17]=1.0; | 
					
						
							|  |  |  | 					pdd->cd+=18; | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 				copy_v3_v3(vec2,state->co); | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							|  |  |  | 				if(cd) { | 
					
						
							| 
									
										
										
										
											2011-11-26 03:13:54 +00:00
										 |  |  | 					cd[0]=cd[3]=cd[6]=cd[ 9]=cd[12]=cd[15]= ma_col[0]; | 
					
						
							|  |  |  | 					cd[1]=cd[4]=cd[7]=cd[10]=cd[13]=cd[16]= ma_col[1]; | 
					
						
							|  |  |  | 					cd[2]=cd[5]=cd[8]=cd[11]=cd[14]=cd[17]= ma_col[2]; | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 					pdd->cd+=18; | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 				sub_v3_v3v3(vec2, state->co, vec); | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 			add_v3_v3(vec, state->co); | 
					
						
							|  |  |  | 			copy_v3_v3(pdd->vd,vec); pdd->vd+=3; | 
					
						
							|  |  |  | 			copy_v3_v3(pdd->vd,vec2); pdd->vd+=3; | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 				 | 
					
						
							|  |  |  | 			vec[1]=2.0f*pixsize; | 
					
						
							|  |  |  | 			vec[0]=vec[2]=0.0; | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 			mul_qt_v3(state->rot,vec); | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 			if(draw_as==PART_DRAW_AXIS){ | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 				copy_v3_v3(vec2,state->co); | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 			}		 | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 			else sub_v3_v3v3(vec2, state->co, vec); | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 			add_v3_v3(vec, state->co); | 
					
						
							|  |  |  | 			copy_v3_v3(pdd->vd,vec); pdd->vd+=3; | 
					
						
							|  |  |  | 			copy_v3_v3(pdd->vd,vec2); pdd->vd+=3; | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			vec[2]=2.0f*pixsize; | 
					
						
							|  |  |  | 			vec[0]=vec[1]=0.0; | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 			mul_qt_v3(state->rot,vec); | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 			if(draw_as==PART_DRAW_AXIS){ | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 				copy_v3_v3(vec2,state->co); | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 			else sub_v3_v3v3(vec2, state->co, vec); | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 			add_v3_v3(vec, state->co); | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 			copy_v3_v3(pdd->vd,vec); pdd->vd+=3; | 
					
						
							|  |  |  | 			copy_v3_v3(pdd->vd,vec2); pdd->vd+=3; | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 			break; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		case PART_DRAW_LINE: | 
					
						
							|  |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 			copy_v3_v3(vec,state->vel); | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 			normalize_v3(vec); | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 			if(draw & PART_DRAW_VEL_LENGTH) | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 				mul_v3_fl(vec,len_v3(state->vel)); | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 			madd_v3_v3v3fl(pdd->vd, state->co, vec, -draw_line[0]); pdd->vd+=3; | 
					
						
							|  |  |  | 			madd_v3_v3v3fl(pdd->vd, state->co, vec,  draw_line[1]); pdd->vd+=3; | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 			if(cd) { | 
					
						
							| 
									
										
										
										
											2011-11-26 03:13:54 +00:00
										 |  |  | 				cd[0]=cd[3]= ma_col[0]; | 
					
						
							|  |  |  | 				cd[1]=cd[4]= ma_col[1]; | 
					
						
							|  |  |  | 				cd[2]=cd[5]= ma_col[2]; | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 				pdd->cd+=6; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		case PART_DRAW_CIRC: | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			drawcircball(GL_LINE_LOOP, state->co, pixsize, imat); | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		case PART_DRAW_BB: | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			float xvec[3], yvec[3], zvec[3], bb_center[3]; | 
					
						
							|  |  |  | 			if(cd) { | 
					
						
							| 
									
										
										
										
											2011-11-26 03:13:54 +00:00
										 |  |  | 				cd[0]=cd[3]=cd[6]=cd[ 9]= ma_col[0]; | 
					
						
							|  |  |  | 				cd[1]=cd[4]=cd[7]=cd[10]= ma_col[1]; | 
					
						
							|  |  |  | 				cd[2]=cd[5]=cd[8]=cd[11]= ma_col[2]; | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 				pdd->cd+=12; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 			copy_v3_v3(bb->vec, state->co); | 
					
						
							|  |  |  | 			copy_v3_v3(bb->vel, state->vel); | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			psys_make_billboard(bb, xvec, yvec, zvec, bb_center); | 
					
						
							|  |  |  | 			 | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 			add_v3_v3v3(pdd->vd, bb_center, xvec); | 
					
						
							|  |  |  | 			add_v3_v3(pdd->vd, yvec); pdd->vd+=3; | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-07 05:47:34 +00:00
										 |  |  | 			sub_v3_v3v3(pdd->vd, bb_center, xvec); | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 			add_v3_v3(pdd->vd, yvec); pdd->vd+=3; | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 			sub_v3_v3v3(pdd->vd, bb_center, xvec); | 
					
						
							|  |  |  | 			sub_v3_v3v3(pdd->vd, pdd->vd,yvec); pdd->vd+=3; | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 			add_v3_v3v3(pdd->vd, bb_center, xvec); | 
					
						
							|  |  |  | 			sub_v3_v3v3(pdd->vd, pdd->vd, yvec); pdd->vd+=3; | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 			copy_v3_v3(pdd->nd, zvec); pdd->nd+=3; | 
					
						
							|  |  |  | 			copy_v3_v3(pdd->nd, zvec); pdd->nd+=3; | 
					
						
							|  |  |  | 			copy_v3_v3(pdd->nd, zvec); pdd->nd+=3; | 
					
						
							|  |  |  | 			copy_v3_v3(pdd->nd, zvec); pdd->nd+=3; | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 			break; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | /* unified drawing of all new particle systems draw types except dupli ob & group	*/ | 
					
						
							|  |  |  | /* mostly tries to use vertex arrays for speed										*/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* 1. check that everything is ok & updated */ | 
					
						
							|  |  |  | /* 2. start initialising things				*/ | 
					
						
							|  |  |  | /* 3. initialize according to draw type		*/ | 
					
						
							|  |  |  | /* 4. allocate drawing data arrays			*/ | 
					
						
							|  |  |  | /* 5. start filling the arrays				*/ | 
					
						
							|  |  |  | /* 6. draw the arrays						*/ | 
					
						
							|  |  |  | /* 7. clean up								*/ | 
					
						
							| 
									
										
										
										
											2011-12-03 20:49:41 +00:00
										 |  |  | static void draw_new_particle_system(Scene *scene, View3D *v3d, RegionView3D *rv3d, | 
					
						
							|  |  |  |                                      Base *base, ParticleSystem *psys, int ob_dt) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	Object *ob=base->object; | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 	ParticleEditSettings *pset = PE_settings(scene); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	ParticleSettings *part; | 
					
						
							|  |  |  | 	ParticleData *pars, *pa; | 
					
						
							| 
									
										
										
										
											2011-03-03 17:59:04 +00:00
										 |  |  | 	ParticleKey state, *states=NULL; | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 	ParticleBillboardData bb; | 
					
						
							| 
									
										
										
										
											2011-03-03 17:59:04 +00:00
										 |  |  | 	ParticleSimulationData sim= {NULL}; | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 	ParticleDrawData *pdd = psys->pdd; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	Material *ma; | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 	float vel[3], imat[4][4]; | 
					
						
							| 
									
										
										
										
											2012-02-01 06:26:48 +00:00
										 |  |  | 	float timestep, pixsize_scale, pa_size, r_tilt, r_length; | 
					
						
							| 
									
										
											  
											
												Completely refactored sph fluid particles. Only the very core of the algorithm remains
the same, but big changes have happened both on the outside and on the inside.
New UI:
* The old parameters were quite true to the underlying algorithm, but were quite obscure
  from a users point of view. Now there are only a few intuitive basic parameters that
  define the basic fluid behavior.
** By default particle size is now used to determine the interaction radius, rest
   density and spring rest lengths so that it's easy to get stable simulations by simply
   emitting particles for a few frames and adjusting the particle size (easy when the
   particle size is drawn) so that the fluid appears continuous (particles are touching
   eachother).
** Stiffness - in reality most fluids are very incompressible, but this is a very hard
   problem to solve with particle based fluid simulation so some compromises have to be
   made. So the bigger the stiffness parameter is the less the fluid will compress under
   stress, but the more substeps are needed for stable simulation.
** Viscosity - how much internal friction there is in the fluid. Large viscosities also
   smooth out instabilities, so less viscous fluids again need more substeps to remain
   stable.
** Buoancy - with high buoancy low pressure areas inside the fluid start to rise against
   gravity, and high pressure areas start to come down.
* In addition to these basic parameters there are separate advanced parameters that can
  either be tweaked relative to the basic parameters (or particle size) or defined
  independently.
** Repulsion - the stiffness parameter tries to keep the fluid density constant, but this
   can lead to small clumps of particles, so the repulsion keeps the particles better
   separated.
** Stiff viscosity - the normal viscosity only applies when particles are moving closer to 
   eachother to allow free flowing fluids. Stiff viscosity also applies smoothing to
   particles that are moving away from eachother.
** Interaction radius - by default this is 4 * particle size.
** Rest density - by default this is a density that the particles have when they're packed
   densely next to eachother.
** Spring rest length - by default this is 2 * particle size.
* There are also new options for 3d view particle coloring in the display panel to show
  particle velocity and acceleration. These make it easier to see what's happening in the
  fluid simulations, but can of course be used with other particles as well.
* Viscoelastic springs have some new options too. The plasticity can now be set to much
  higher values for instant deletion of springs as the elastic limit is exeeded. In addition
  to that there is an option to only create springs for a certain number of frames when a
  particle is born. These options give new possibilities for breaking viscoelastic fluids.
New in the code:
* Most of the fluids code is now thread safe, so when particle dynamics go threaded there
  will be a nice speed boost to fluids as well.
* Fluids now use a bvh-tree instead of a kd-tree for the neighbor lookups. The bvh-tree 
  implementation makes the code quite a bit cleaner and should also give a slight speed
  boost to the simulation too.
* Previously only force fields were calculated with the different integration methods, but
  now the fluid calculations are also done using the selected integration method, so there
  are again more choices in effecting simulation accuracy and stability. This change also
  included a nice cleanup of the whole particle integration code.
As the internals are pretty stirred up old particle fluid simulations will probably not
work correctly straight away, but with some tweaking the same level of control is still
available by not using the "relative versions" of the advanced parameters (by default these
are not used when loading old files).
											
										 
											2011-03-12 12:38:11 +00:00
										 |  |  | 	float pa_time, pa_birthtime, pa_dietime, pa_health, intensity; | 
					
						
							| 
									
										
										
										
											2011-01-12 03:41:12 +00:00
										 |  |  | 	float cfra; | 
					
						
							| 
									
										
										
										
											2011-11-26 03:13:54 +00:00
										 |  |  | 	float ma_col[3]= {0.0f, 0.0f, 0.0f}; | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 	int a, totpart, totpoint=0, totve=0, drawn, draw_as, totchild=0; | 
					
						
							|  |  |  | 	int select=ob->flag&SELECT, create_cdata=0, need_v=0; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	GLint polygonmode[2]; | 
					
						
							| 
									
										
										
										
											2012-01-11 09:33:44 +00:00
										 |  |  | 	char numstr[32]; | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 	unsigned char tcol[4]= {0, 0, 0, 255}; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* 1. */ | 
					
						
							| 
									
										
										
										
											2011-03-03 17:59:04 +00:00
										 |  |  | 	if(psys==NULL) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	part=psys->part; | 
					
						
							|  |  |  | 	pars=psys->particles; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-03 17:59:04 +00:00
										 |  |  | 	if(part==NULL || !psys_check_enabled(ob, psys)) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-03 17:59:04 +00:00
										 |  |  | 	if(pars==NULL) return; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 	/* don't draw normal paths in edit mode */ | 
					
						
							|  |  |  | 	if(psys_in_edit_mode(scene, psys) && (pset->flag & PE_DRAW_PART)==0) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 	if(part->draw_as == PART_DRAW_REND) | 
					
						
							|  |  |  | 		draw_as = part->ren_as; | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 		draw_as = part->draw_as; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(draw_as == PART_DRAW_NOT) | 
					
						
							|  |  |  | 		return; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* 2. */ | 
					
						
							| 
									
										
										
										
											2010-11-03 06:31:53 +00:00
										 |  |  | 	sim.scene= scene; | 
					
						
							|  |  |  | 	sim.ob= ob; | 
					
						
							|  |  |  | 	sim.psys= psys; | 
					
						
							| 
									
										
										
										
											2011-01-12 03:41:12 +00:00
										 |  |  | 	sim.psmd = psys_get_modifier(ob,psys); | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	if(part->phystype==PART_PHYS_KEYED){ | 
					
						
							| 
									
										
										
										
											2009-07-12 23:38:47 +00:00
										 |  |  | 		if(psys->flag&PSYS_KEYED){ | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 			psys_count_keyed_targets(&sim); | 
					
						
							| 
									
										
										
										
											2009-07-12 23:38:47 +00:00
										 |  |  | 			if(psys->totkeyed==0) | 
					
						
							|  |  |  | 				return; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(select){ | 
					
						
							|  |  |  | 		select=0; | 
					
						
							|  |  |  | 		if(psys_get_current(ob)==psys) | 
					
						
							|  |  |  | 			select=1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	psys->flag|=PSYS_DRAWING; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-17 17:07:50 +00:00
										 |  |  | 	if(part->type==PART_HAIR && !psys->childcache) | 
					
						
							|  |  |  | 		totchild=0; | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 		totchild=psys->totchild*part->disp/100; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 	ma= give_current_material(ob,part->omat); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if(v3d->zbuf) glDepthMask(1); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Completely refactored sph fluid particles. Only the very core of the algorithm remains
the same, but big changes have happened both on the outside and on the inside.
New UI:
* The old parameters were quite true to the underlying algorithm, but were quite obscure
  from a users point of view. Now there are only a few intuitive basic parameters that
  define the basic fluid behavior.
** By default particle size is now used to determine the interaction radius, rest
   density and spring rest lengths so that it's easy to get stable simulations by simply
   emitting particles for a few frames and adjusting the particle size (easy when the
   particle size is drawn) so that the fluid appears continuous (particles are touching
   eachother).
** Stiffness - in reality most fluids are very incompressible, but this is a very hard
   problem to solve with particle based fluid simulation so some compromises have to be
   made. So the bigger the stiffness parameter is the less the fluid will compress under
   stress, but the more substeps are needed for stable simulation.
** Viscosity - how much internal friction there is in the fluid. Large viscosities also
   smooth out instabilities, so less viscous fluids again need more substeps to remain
   stable.
** Buoancy - with high buoancy low pressure areas inside the fluid start to rise against
   gravity, and high pressure areas start to come down.
* In addition to these basic parameters there are separate advanced parameters that can
  either be tweaked relative to the basic parameters (or particle size) or defined
  independently.
** Repulsion - the stiffness parameter tries to keep the fluid density constant, but this
   can lead to small clumps of particles, so the repulsion keeps the particles better
   separated.
** Stiff viscosity - the normal viscosity only applies when particles are moving closer to 
   eachother to allow free flowing fluids. Stiff viscosity also applies smoothing to
   particles that are moving away from eachother.
** Interaction radius - by default this is 4 * particle size.
** Rest density - by default this is a density that the particles have when they're packed
   densely next to eachother.
** Spring rest length - by default this is 2 * particle size.
* There are also new options for 3d view particle coloring in the display panel to show
  particle velocity and acceleration. These make it easier to see what's happening in the
  fluid simulations, but can of course be used with other particles as well.
* Viscoelastic springs have some new options too. The plasticity can now be set to much
  higher values for instant deletion of springs as the elastic limit is exeeded. In addition
  to that there is an option to only create springs for a certain number of frames when a
  particle is born. These options give new possibilities for breaking viscoelastic fluids.
New in the code:
* Most of the fluids code is now thread safe, so when particle dynamics go threaded there
  will be a nice speed boost to fluids as well.
* Fluids now use a bvh-tree instead of a kd-tree for the neighbor lookups. The bvh-tree 
  implementation makes the code quite a bit cleaner and should also give a slight speed
  boost to the simulation too.
* Previously only force fields were calculated with the different integration methods, but
  now the fluid calculations are also done using the selected integration method, so there
  are again more choices in effecting simulation accuracy and stability. This change also
  included a nice cleanup of the whole particle integration code.
As the internals are pretty stirred up old particle fluid simulations will probably not
work correctly straight away, but with some tweaking the same level of control is still
available by not using the "relative versions" of the advanced parameters (by default these
are not used when loading old files).
											
										 
											2011-03-12 12:38:11 +00:00
										 |  |  | 	if((ma) && (part->draw_col == PART_DRAW_COL_MAT)) { | 
					
						
							| 
									
										
										
										
											2012-01-19 09:09:00 +00:00
										 |  |  | 		rgb_float_to_uchar(tcol, &(ma->r)); | 
					
						
							| 
									
										
										
										
											2011-11-26 03:13:54 +00:00
										 |  |  | 		copy_v3_v3(ma_col, &ma->r); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 	glColor3ubv(tcol); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 	timestep= psys_get_timestep(&sim); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if( (base->flag & OB_FROMDUPLI) && (ob->flag & OB_FROMGROUP) ) { | 
					
						
							|  |  |  | 		float mat[4][4]; | 
					
						
							| 
									
										
										
											
												Math lib: matrix multiplication order fix for two functions that were
inconsistent with similar functions & math notation:
mul_m4_m4m4(R, B, A) => mult_m4_m4m4(R, A, B)
mul_m3_m3m4(R, B, A) => mult_m3_m3m4(R, A, B)
For branch maintainers, it should be relatively simple to fix things manually,
it's also possible run this script after merging to do automatic replacement:
http://www.pasteall.org/27459/python
											
										 
											2011-12-16 19:53:12 +00:00
										 |  |  | 		mult_m4_m4m4(mat, ob->obmat, psys->imat); | 
					
						
							| 
									
										
										
										
											2010-02-01 15:32:55 +00:00
										 |  |  | 		glMultMatrixf(mat); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-03 11:40:12 +00:00
										 |  |  | 	/* needed for text display */ | 
					
						
							|  |  |  | 	invert_m4_m4(ob->imat, ob->obmat); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	totpart=psys->totpart; | 
					
						
							| 
									
										
										
										
											2009-06-05 23:59:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-06 06:08:18 +00:00
										 |  |  | 	cfra= BKE_curframe(scene); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-17 17:07:50 +00:00
										 |  |  | 	if(draw_as==PART_DRAW_PATH && psys->pathcache==NULL && psys->childcache==NULL) | 
					
						
							|  |  |  | 		draw_as=PART_DRAW_DOT; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* 3. */ | 
					
						
							|  |  |  | 	switch(draw_as){ | 
					
						
							|  |  |  | 		case PART_DRAW_DOT: | 
					
						
							|  |  |  | 			if(part->draw_size) | 
					
						
							|  |  |  | 				glPointSize(part->draw_size); | 
					
						
							|  |  |  | 			else | 
					
						
							|  |  |  | 				glPointSize(2.0); /* default dot size */ | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case PART_DRAW_CIRC: | 
					
						
							|  |  |  | 			/* calculate view aligned matrix: */ | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 			copy_m4_m4(imat, rv3d->viewinv); | 
					
						
							|  |  |  | 			normalize_v3(imat[0]); | 
					
						
							|  |  |  | 			normalize_v3(imat[1]); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			/* no break! */ | 
					
						
							|  |  |  | 		case PART_DRAW_CROSS: | 
					
						
							|  |  |  | 		case PART_DRAW_AXIS: | 
					
						
							|  |  |  | 			/* lets calculate the scale: */ | 
					
						
							| 
									
										
										
										
											2010-11-19 16:19:15 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2012-02-01 06:26:48 +00:00
										 |  |  | 			if (part->draw_size == 0.0) | 
					
						
							|  |  |  | 				pixsize_scale = 2.0f; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			else | 
					
						
							| 
									
										
										
										
											2012-02-01 06:26:48 +00:00
										 |  |  | 				pixsize_scale = part->draw_size; | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			if(draw_as==PART_DRAW_AXIS) | 
					
						
							|  |  |  | 				create_cdata = 1; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			break; | 
					
						
							|  |  |  | 		case PART_DRAW_OB: | 
					
						
							| 
									
										
										
										
											2011-03-03 17:59:04 +00:00
										 |  |  | 			if(part->dup_ob==NULL) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				draw_as=PART_DRAW_DOT; | 
					
						
							|  |  |  | 			else | 
					
						
							|  |  |  | 				draw_as=0; | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case PART_DRAW_GR: | 
					
						
							| 
									
										
										
										
											2011-03-03 17:59:04 +00:00
										 |  |  | 			if(part->dup_group==NULL) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				draw_as=PART_DRAW_DOT; | 
					
						
							|  |  |  | 			else | 
					
						
							|  |  |  | 				draw_as=0; | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case PART_DRAW_BB: | 
					
						
							| 
									
										
										
										
											2011-03-03 17:59:04 +00:00
										 |  |  | 			if(v3d->camera==NULL && part->bb_ob==NULL){ | 
					
						
							| 
									
										
										
										
											2008-12-19 17:14:02 +00:00
										 |  |  | 				printf("Billboards need an active camera or a target object!\n"); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				draw_as=part->draw_as=PART_DRAW_DOT; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				if(part->draw_size) | 
					
						
							|  |  |  | 					glPointSize(part->draw_size); | 
					
						
							|  |  |  | 				else | 
					
						
							|  |  |  | 					glPointSize(2.0); /* default dot size */ | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else if(part->bb_ob) | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 				bb.ob=part->bb_ob; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			else | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 				bb.ob=v3d->camera; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 			bb.align = part->bb_align; | 
					
						
							|  |  |  | 			bb.anim = part->bb_anim; | 
					
						
							|  |  |  | 			bb.lock = part->draw & PART_DRAW_BB_LOCK; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			break; | 
					
						
							|  |  |  | 		case PART_DRAW_PATH: | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 		case PART_DRAW_LINE: | 
					
						
							|  |  |  | 			need_v=1; | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	if(part->draw & PART_DRAW_SIZE && part->draw_as!=PART_DRAW_CIRC){ | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 		copy_m4_m4(imat, rv3d->viewinv); | 
					
						
							|  |  |  | 		normalize_v3(imat[0]); | 
					
						
							|  |  |  | 		normalize_v3(imat[1]); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Completely refactored sph fluid particles. Only the very core of the algorithm remains
the same, but big changes have happened both on the outside and on the inside.
New UI:
* The old parameters were quite true to the underlying algorithm, but were quite obscure
  from a users point of view. Now there are only a few intuitive basic parameters that
  define the basic fluid behavior.
** By default particle size is now used to determine the interaction radius, rest
   density and spring rest lengths so that it's easy to get stable simulations by simply
   emitting particles for a few frames and adjusting the particle size (easy when the
   particle size is drawn) so that the fluid appears continuous (particles are touching
   eachother).
** Stiffness - in reality most fluids are very incompressible, but this is a very hard
   problem to solve with particle based fluid simulation so some compromises have to be
   made. So the bigger the stiffness parameter is the less the fluid will compress under
   stress, but the more substeps are needed for stable simulation.
** Viscosity - how much internal friction there is in the fluid. Large viscosities also
   smooth out instabilities, so less viscous fluids again need more substeps to remain
   stable.
** Buoancy - with high buoancy low pressure areas inside the fluid start to rise against
   gravity, and high pressure areas start to come down.
* In addition to these basic parameters there are separate advanced parameters that can
  either be tweaked relative to the basic parameters (or particle size) or defined
  independently.
** Repulsion - the stiffness parameter tries to keep the fluid density constant, but this
   can lead to small clumps of particles, so the repulsion keeps the particles better
   separated.
** Stiff viscosity - the normal viscosity only applies when particles are moving closer to 
   eachother to allow free flowing fluids. Stiff viscosity also applies smoothing to
   particles that are moving away from eachother.
** Interaction radius - by default this is 4 * particle size.
** Rest density - by default this is a density that the particles have when they're packed
   densely next to eachother.
** Spring rest length - by default this is 2 * particle size.
* There are also new options for 3d view particle coloring in the display panel to show
  particle velocity and acceleration. These make it easier to see what's happening in the
  fluid simulations, but can of course be used with other particles as well.
* Viscoelastic springs have some new options too. The plasticity can now be set to much
  higher values for instant deletion of springs as the elastic limit is exeeded. In addition
  to that there is an option to only create springs for a certain number of frames when a
  particle is born. These options give new possibilities for breaking viscoelastic fluids.
New in the code:
* Most of the fluids code is now thread safe, so when particle dynamics go threaded there
  will be a nice speed boost to fluids as well.
* Fluids now use a bvh-tree instead of a kd-tree for the neighbor lookups. The bvh-tree 
  implementation makes the code quite a bit cleaner and should also give a slight speed
  boost to the simulation too.
* Previously only force fields were calculated with the different integration methods, but
  now the fluid calculations are also done using the selected integration method, so there
  are again more choices in effecting simulation accuracy and stability. This change also
  included a nice cleanup of the whole particle integration code.
As the internals are pretty stirred up old particle fluid simulations will probably not
work correctly straight away, but with some tweaking the same level of control is still
available by not using the "relative versions" of the advanced parameters (by default these
are not used when loading old files).
											
										 
											2011-03-12 12:38:11 +00:00
										 |  |  | 	if(ELEM3(draw_as, PART_DRAW_DOT, PART_DRAW_CROSS, PART_DRAW_LINE) | 
					
						
							|  |  |  | 		&& part->draw_col > PART_DRAW_COL_MAT) | 
					
						
							|  |  |  | 		create_cdata = 1; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 	if(!create_cdata && pdd && pdd->cdata) { | 
					
						
							|  |  |  | 		MEM_freeN(pdd->cdata); | 
					
						
							|  |  |  | 		pdd->cdata = pdd->cd = NULL; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | /* 4. */ | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 	if(draw_as && ELEM(draw_as, PART_DRAW_PATH, PART_DRAW_CIRC)==0) { | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 		int tot_vec_size = (totpart + totchild) * 3 * sizeof(float); | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 		int create_ndata = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if(!pdd) | 
					
						
							|  |  |  | 			pdd = psys->pdd = MEM_callocN(sizeof(ParticleDrawData), "ParticlDrawData"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-12 23:38:47 +00:00
										 |  |  | 		if(part->draw_as == PART_DRAW_REND && part->trail_count > 1) { | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 			tot_vec_size *= part->trail_count; | 
					
						
							| 
									
										
										
										
											2009-07-12 23:38:47 +00:00
										 |  |  | 			psys_make_temp_pointcache(ob, psys); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 		switch(draw_as) { | 
					
						
							|  |  |  | 			case PART_DRAW_AXIS: | 
					
						
							|  |  |  | 			case PART_DRAW_CROSS: | 
					
						
							|  |  |  | 				tot_vec_size *= 6; | 
					
						
							|  |  |  | 				if(draw_as != PART_DRAW_CROSS) | 
					
						
							|  |  |  | 					create_cdata = 1; | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			case PART_DRAW_LINE: | 
					
						
							|  |  |  | 				tot_vec_size *= 2; | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			case PART_DRAW_BB: | 
					
						
							|  |  |  | 				tot_vec_size *= 4; | 
					
						
							|  |  |  | 				create_ndata = 1; | 
					
						
							|  |  |  | 				break; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 		if(pdd->tot_vec_size != tot_vec_size) | 
					
						
							|  |  |  | 			psys_free_pdd(psys); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if(!pdd->vdata) | 
					
						
							|  |  |  | 			pdd->vdata = MEM_callocN(tot_vec_size, "particle_vdata"); | 
					
						
							|  |  |  | 		if(create_cdata && !pdd->cdata) | 
					
						
							|  |  |  | 			pdd->cdata = MEM_callocN(tot_vec_size, "particle_cdata"); | 
					
						
							|  |  |  | 		if(create_ndata && !pdd->ndata) | 
					
						
							| 
									
										
											  
											
												Completely refactored sph fluid particles. Only the very core of the algorithm remains
the same, but big changes have happened both on the outside and on the inside.
New UI:
* The old parameters were quite true to the underlying algorithm, but were quite obscure
  from a users point of view. Now there are only a few intuitive basic parameters that
  define the basic fluid behavior.
** By default particle size is now used to determine the interaction radius, rest
   density and spring rest lengths so that it's easy to get stable simulations by simply
   emitting particles for a few frames and adjusting the particle size (easy when the
   particle size is drawn) so that the fluid appears continuous (particles are touching
   eachother).
** Stiffness - in reality most fluids are very incompressible, but this is a very hard
   problem to solve with particle based fluid simulation so some compromises have to be
   made. So the bigger the stiffness parameter is the less the fluid will compress under
   stress, but the more substeps are needed for stable simulation.
** Viscosity - how much internal friction there is in the fluid. Large viscosities also
   smooth out instabilities, so less viscous fluids again need more substeps to remain
   stable.
** Buoancy - with high buoancy low pressure areas inside the fluid start to rise against
   gravity, and high pressure areas start to come down.
* In addition to these basic parameters there are separate advanced parameters that can
  either be tweaked relative to the basic parameters (or particle size) or defined
  independently.
** Repulsion - the stiffness parameter tries to keep the fluid density constant, but this
   can lead to small clumps of particles, so the repulsion keeps the particles better
   separated.
** Stiff viscosity - the normal viscosity only applies when particles are moving closer to 
   eachother to allow free flowing fluids. Stiff viscosity also applies smoothing to
   particles that are moving away from eachother.
** Interaction radius - by default this is 4 * particle size.
** Rest density - by default this is a density that the particles have when they're packed
   densely next to eachother.
** Spring rest length - by default this is 2 * particle size.
* There are also new options for 3d view particle coloring in the display panel to show
  particle velocity and acceleration. These make it easier to see what's happening in the
  fluid simulations, but can of course be used with other particles as well.
* Viscoelastic springs have some new options too. The plasticity can now be set to much
  higher values for instant deletion of springs as the elastic limit is exeeded. In addition
  to that there is an option to only create springs for a certain number of frames when a
  particle is born. These options give new possibilities for breaking viscoelastic fluids.
New in the code:
* Most of the fluids code is now thread safe, so when particle dynamics go threaded there
  will be a nice speed boost to fluids as well.
* Fluids now use a bvh-tree instead of a kd-tree for the neighbor lookups. The bvh-tree 
  implementation makes the code quite a bit cleaner and should also give a slight speed
  boost to the simulation too.
* Previously only force fields were calculated with the different integration methods, but
  now the fluid calculations are also done using the selected integration method, so there
  are again more choices in effecting simulation accuracy and stability. This change also
  included a nice cleanup of the whole particle integration code.
As the internals are pretty stirred up old particle fluid simulations will probably not
work correctly straight away, but with some tweaking the same level of control is still
available by not using the "relative versions" of the advanced parameters (by default these
are not used when loading old files).
											
										 
											2011-03-12 12:38:11 +00:00
										 |  |  | 			pdd->ndata = MEM_callocN(tot_vec_size, "particle_ndata"); | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 		if(part->draw & PART_DRAW_VEL && draw_as != PART_DRAW_LINE) { | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 			if(!pdd->vedata) | 
					
						
							|  |  |  | 				pdd->vedata = MEM_callocN(2 * (totpart + totchild) * 3 * sizeof(float), "particle_vedata"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 			need_v = 1; | 
					
						
							| 
									
										
										
										
											2009-12-03 00:42:02 +00:00
										 |  |  | 		} else if (pdd->vedata) { | 
					
						
							|  |  |  | 			/* velocity data not needed, so free it */ | 
					
						
							|  |  |  | 			MEM_freeN(pdd->vedata); | 
					
						
							|  |  |  | 			pdd->vedata= NULL; | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 		pdd->vd= pdd->vdata; | 
					
						
							|  |  |  | 		pdd->ved= pdd->vedata; | 
					
						
							|  |  |  | 		pdd->cd= pdd->cdata; | 
					
						
							|  |  |  | 		pdd->nd= pdd->ndata; | 
					
						
							|  |  |  | 		pdd->tot_vec_size= tot_vec_size; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-01-15 12:29:22 +00:00
										 |  |  | 	else if(psys->pdd) { | 
					
						
							|  |  |  | 		psys_free_pdd(psys); | 
					
						
							|  |  |  | 		MEM_freeN(psys->pdd); | 
					
						
							|  |  |  | 		pdd = psys->pdd = NULL; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-25 17:20:12 +00:00
										 |  |  | 	if(pdd) { | 
					
						
							| 
									
										
										
										
											2011-11-26 03:13:54 +00:00
										 |  |  | 		pdd->ma_col= ma_col; | 
					
						
							| 
									
										
										
										
											2010-10-25 17:20:12 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 	psys->lattice= psys_get_lattice(&sim); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-25 17:20:12 +00:00
										 |  |  | 	/* circles don't use drawdata, so have to add a special case here */ | 
					
						
							|  |  |  | 	if((pdd || draw_as==PART_DRAW_CIRC) && draw_as!=PART_DRAW_PATH){ | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | /* 5. */ | 
					
						
							| 
									
										
										
										
											2010-10-25 17:20:12 +00:00
										 |  |  | 		if(pdd && (pdd->flag & PARTICLE_DRAW_DATA_UPDATED) | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 			&& (pdd->vedata || part->draw & (PART_DRAW_SIZE|PART_DRAW_NUM|PART_DRAW_HEALTH))==0) { | 
					
						
							|  |  |  | 			totpoint = pdd->totpoint; /* draw data is up to date */ | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else for(a=0,pa=pars; a<totpart+totchild; a++, pa++){ | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 			/* setup per particle individual stuff */ | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			if(a<totpart){ | 
					
						
							|  |  |  | 				if(totchild && (part->draw&PART_DRAW_PARENT)==0) continue; | 
					
						
							|  |  |  | 				if(pa->flag & PARS_NO_DISP || pa->flag & PARS_UNEXIST) continue; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				pa_time=(cfra-pa->time)/pa->lifetime; | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 				pa_birthtime=pa->time; | 
					
						
							|  |  |  | 				pa_dietime = pa->dietime; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				pa_size=pa->size; | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 				if(part->phystype==PART_PHYS_BOIDS) | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 					pa_health = pa->boid->data.health; | 
					
						
							| 
									
										
										
										
											2009-07-20 23:52:53 +00:00
										 |  |  | 				else | 
					
						
							|  |  |  | 					pa_health = -1.0; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Completely refactored sph fluid particles. Only the very core of the algorithm remains
the same, but big changes have happened both on the outside and on the inside.
New UI:
* The old parameters were quite true to the underlying algorithm, but were quite obscure
  from a users point of view. Now there are only a few intuitive basic parameters that
  define the basic fluid behavior.
** By default particle size is now used to determine the interaction radius, rest
   density and spring rest lengths so that it's easy to get stable simulations by simply
   emitting particles for a few frames and adjusting the particle size (easy when the
   particle size is drawn) so that the fluid appears continuous (particles are touching
   eachother).
** Stiffness - in reality most fluids are very incompressible, but this is a very hard
   problem to solve with particle based fluid simulation so some compromises have to be
   made. So the bigger the stiffness parameter is the less the fluid will compress under
   stress, but the more substeps are needed for stable simulation.
** Viscosity - how much internal friction there is in the fluid. Large viscosities also
   smooth out instabilities, so less viscous fluids again need more substeps to remain
   stable.
** Buoancy - with high buoancy low pressure areas inside the fluid start to rise against
   gravity, and high pressure areas start to come down.
* In addition to these basic parameters there are separate advanced parameters that can
  either be tweaked relative to the basic parameters (or particle size) or defined
  independently.
** Repulsion - the stiffness parameter tries to keep the fluid density constant, but this
   can lead to small clumps of particles, so the repulsion keeps the particles better
   separated.
** Stiff viscosity - the normal viscosity only applies when particles are moving closer to 
   eachother to allow free flowing fluids. Stiff viscosity also applies smoothing to
   particles that are moving away from eachother.
** Interaction radius - by default this is 4 * particle size.
** Rest density - by default this is a density that the particles have when they're packed
   densely next to eachother.
** Spring rest length - by default this is 2 * particle size.
* There are also new options for 3d view particle coloring in the display panel to show
  particle velocity and acceleration. These make it easier to see what's happening in the
  fluid simulations, but can of course be used with other particles as well.
* Viscoelastic springs have some new options too. The plasticity can now be set to much
  higher values for instant deletion of springs as the elastic limit is exeeded. In addition
  to that there is an option to only create springs for a certain number of frames when a
  particle is born. These options give new possibilities for breaking viscoelastic fluids.
New in the code:
* Most of the fluids code is now thread safe, so when particle dynamics go threaded there
  will be a nice speed boost to fluids as well.
* Fluids now use a bvh-tree instead of a kd-tree for the neighbor lookups. The bvh-tree 
  implementation makes the code quite a bit cleaner and should also give a slight speed
  boost to the simulation too.
* Previously only force fields were calculated with the different integration methods, but
  now the fluid calculations are also done using the selected integration method, so there
  are again more choices in effecting simulation accuracy and stability. This change also
  included a nice cleanup of the whole particle integration code.
As the internals are pretty stirred up old particle fluid simulations will probably not
work correctly straight away, but with some tweaking the same level of control is still
available by not using the "relative versions" of the advanced parameters (by default these
are not used when loading old files).
											
										 
											2011-03-12 12:38:11 +00:00
										 |  |  | 				r_tilt = 2.0f*(PSYS_FRAND(a + 21) - 0.5f); | 
					
						
							|  |  |  | 				r_length = PSYS_FRAND(a + 22); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Completely refactored sph fluid particles. Only the very core of the algorithm remains
the same, but big changes have happened both on the outside and on the inside.
New UI:
* The old parameters were quite true to the underlying algorithm, but were quite obscure
  from a users point of view. Now there are only a few intuitive basic parameters that
  define the basic fluid behavior.
** By default particle size is now used to determine the interaction radius, rest
   density and spring rest lengths so that it's easy to get stable simulations by simply
   emitting particles for a few frames and adjusting the particle size (easy when the
   particle size is drawn) so that the fluid appears continuous (particles are touching
   eachother).
** Stiffness - in reality most fluids are very incompressible, but this is a very hard
   problem to solve with particle based fluid simulation so some compromises have to be
   made. So the bigger the stiffness parameter is the less the fluid will compress under
   stress, but the more substeps are needed for stable simulation.
** Viscosity - how much internal friction there is in the fluid. Large viscosities also
   smooth out instabilities, so less viscous fluids again need more substeps to remain
   stable.
** Buoancy - with high buoancy low pressure areas inside the fluid start to rise against
   gravity, and high pressure areas start to come down.
* In addition to these basic parameters there are separate advanced parameters that can
  either be tweaked relative to the basic parameters (or particle size) or defined
  independently.
** Repulsion - the stiffness parameter tries to keep the fluid density constant, but this
   can lead to small clumps of particles, so the repulsion keeps the particles better
   separated.
** Stiff viscosity - the normal viscosity only applies when particles are moving closer to 
   eachother to allow free flowing fluids. Stiff viscosity also applies smoothing to
   particles that are moving away from eachother.
** Interaction radius - by default this is 4 * particle size.
** Rest density - by default this is a density that the particles have when they're packed
   densely next to eachother.
** Spring rest length - by default this is 2 * particle size.
* There are also new options for 3d view particle coloring in the display panel to show
  particle velocity and acceleration. These make it easier to see what's happening in the
  fluid simulations, but can of course be used with other particles as well.
* Viscoelastic springs have some new options too. The plasticity can now be set to much
  higher values for instant deletion of springs as the elastic limit is exeeded. In addition
  to that there is an option to only create springs for a certain number of frames when a
  particle is born. These options give new possibilities for breaking viscoelastic fluids.
New in the code:
* Most of the fluids code is now thread safe, so when particle dynamics go threaded there
  will be a nice speed boost to fluids as well.
* Fluids now use a bvh-tree instead of a kd-tree for the neighbor lookups. The bvh-tree 
  implementation makes the code quite a bit cleaner and should also give a slight speed
  boost to the simulation too.
* Previously only force fields were calculated with the different integration methods, but
  now the fluid calculations are also done using the selected integration method, so there
  are again more choices in effecting simulation accuracy and stability. This change also
  included a nice cleanup of the whole particle integration code.
As the internals are pretty stirred up old particle fluid simulations will probably not
work correctly straight away, but with some tweaking the same level of control is still
available by not using the "relative versions" of the advanced parameters (by default these
are not used when loading old files).
											
										 
											2011-03-12 12:38:11 +00:00
										 |  |  | 				if(part->draw_col > PART_DRAW_COL_MAT) { | 
					
						
							|  |  |  | 					switch(part->draw_col) { | 
					
						
							|  |  |  | 						case PART_DRAW_COL_VEL: | 
					
						
							|  |  |  | 							intensity = len_v3(pa->state.vel)/part->color_vec_max; | 
					
						
							|  |  |  | 							break; | 
					
						
							|  |  |  | 						case PART_DRAW_COL_ACC: | 
					
						
							|  |  |  | 							intensity = len_v3v3(pa->state.vel, pa->prev_state.vel)/((pa->state.time-pa->prev_state.time)*part->color_vec_max); | 
					
						
							|  |  |  | 							break; | 
					
						
							| 
									
										
										
										
											2011-05-24 17:25:11 +00:00
										 |  |  | 						default: | 
					
						
							|  |  |  | 							intensity= 1.0f; /* should never happen */ | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 					} | 
					
						
							| 
									
										
											  
											
												Completely refactored sph fluid particles. Only the very core of the algorithm remains
the same, but big changes have happened both on the outside and on the inside.
New UI:
* The old parameters were quite true to the underlying algorithm, but were quite obscure
  from a users point of view. Now there are only a few intuitive basic parameters that
  define the basic fluid behavior.
** By default particle size is now used to determine the interaction radius, rest
   density and spring rest lengths so that it's easy to get stable simulations by simply
   emitting particles for a few frames and adjusting the particle size (easy when the
   particle size is drawn) so that the fluid appears continuous (particles are touching
   eachother).
** Stiffness - in reality most fluids are very incompressible, but this is a very hard
   problem to solve with particle based fluid simulation so some compromises have to be
   made. So the bigger the stiffness parameter is the less the fluid will compress under
   stress, but the more substeps are needed for stable simulation.
** Viscosity - how much internal friction there is in the fluid. Large viscosities also
   smooth out instabilities, so less viscous fluids again need more substeps to remain
   stable.
** Buoancy - with high buoancy low pressure areas inside the fluid start to rise against
   gravity, and high pressure areas start to come down.
* In addition to these basic parameters there are separate advanced parameters that can
  either be tweaked relative to the basic parameters (or particle size) or defined
  independently.
** Repulsion - the stiffness parameter tries to keep the fluid density constant, but this
   can lead to small clumps of particles, so the repulsion keeps the particles better
   separated.
** Stiff viscosity - the normal viscosity only applies when particles are moving closer to 
   eachother to allow free flowing fluids. Stiff viscosity also applies smoothing to
   particles that are moving away from eachother.
** Interaction radius - by default this is 4 * particle size.
** Rest density - by default this is a density that the particles have when they're packed
   densely next to eachother.
** Spring rest length - by default this is 2 * particle size.
* There are also new options for 3d view particle coloring in the display panel to show
  particle velocity and acceleration. These make it easier to see what's happening in the
  fluid simulations, but can of course be used with other particles as well.
* Viscoelastic springs have some new options too. The plasticity can now be set to much
  higher values for instant deletion of springs as the elastic limit is exeeded. In addition
  to that there is an option to only create springs for a certain number of frames when a
  particle is born. These options give new possibilities for breaking viscoelastic fluids.
New in the code:
* Most of the fluids code is now thread safe, so when particle dynamics go threaded there
  will be a nice speed boost to fluids as well.
* Fluids now use a bvh-tree instead of a kd-tree for the neighbor lookups. The bvh-tree 
  implementation makes the code quite a bit cleaner and should also give a slight speed
  boost to the simulation too.
* Previously only force fields were calculated with the different integration methods, but
  now the fluid calculations are also done using the selected integration method, so there
  are again more choices in effecting simulation accuracy and stability. This change also
  included a nice cleanup of the whole particle integration code.
As the internals are pretty stirred up old particle fluid simulations will probably not
work correctly straight away, but with some tweaking the same level of control is still
available by not using the "relative versions" of the advanced parameters (by default these
are not used when loading old files).
											
										 
											2011-03-12 12:38:11 +00:00
										 |  |  | 					CLAMP(intensity, 0.f, 1.f); | 
					
						
							| 
									
										
										
										
											2011-11-26 03:13:54 +00:00
										 |  |  | 					weight_to_rgb(ma_col, intensity); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else{ | 
					
						
							|  |  |  | 				ChildParticle *cpa= &psys->child[a-totpart]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 				pa_time=psys_get_child_time(psys,cpa,cfra,&pa_birthtime,&pa_dietime); | 
					
						
							| 
									
										
										
										
											2011-03-03 17:59:04 +00:00
										 |  |  | 				pa_size=psys_get_child_size(psys,cpa,cfra,NULL); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-20 23:52:53 +00:00
										 |  |  | 				pa_health = -1.0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 				r_tilt = 2.0f*(PSYS_FRAND(a + 21) - 0.5f); | 
					
						
							|  |  |  | 				r_length = PSYS_FRAND(a + 22); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 			drawn = 0; | 
					
						
							|  |  |  | 			if(part->draw_as == PART_DRAW_REND && part->trail_count > 1) { | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 				float length = part->path_end * (1.0f - part->randlength * r_length); | 
					
						
							|  |  |  | 				int trail_count = part->trail_count * (1.0f - part->randlength * r_length); | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 				float ct = ((part->draw & PART_ABS_PATH_TIME) ? cfra : pa_time) - length; | 
					
						
							|  |  |  | 				float dt = length / (trail_count ? (float)trail_count : 1.0f); | 
					
						
							|  |  |  | 				int i=0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				ct+=dt; | 
					
						
							|  |  |  | 				for(i=0; i < trail_count; i++, ct += dt) { | 
					
						
							| 
									
										
										
										
											2012-02-01 06:26:48 +00:00
										 |  |  | 					float pixsize; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 					if(part->draw & PART_ABS_PATH_TIME) { | 
					
						
							|  |  |  | 						if(ct < pa_birthtime || ct > pa_dietime) | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 							continue; | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 					} | 
					
						
							|  |  |  | 					else if(ct < 0.0f || ct > 1.0f) | 
					
						
							|  |  |  | 						continue; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 					state.time = (part->draw & PART_ABS_PATH_TIME) ? -ct : -(pa_birthtime + ct * (pa_dietime - pa_birthtime)); | 
					
						
							|  |  |  | 					psys_get_particle_on_path(&sim,a,&state,need_v); | 
					
						
							|  |  |  | 					 | 
					
						
							|  |  |  | 					if(psys->parent) | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 						mul_m4_v3(psys->parent->obmat, state.co); | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 					/* create actiual particle data */ | 
					
						
							|  |  |  | 					if(draw_as == PART_DRAW_BB) { | 
					
						
							| 
									
										
										
										
											2011-06-23 18:59:47 +00:00
										 |  |  | 						bb.offset[0] = part->bb_offset[0]; | 
					
						
							|  |  |  | 						bb.offset[1] = part->bb_offset[1]; | 
					
						
							|  |  |  | 						bb.size[0] = part->bb_size[0] * pa_size; | 
					
						
							|  |  |  | 						if (part->bb_align==PART_BB_VEL) { | 
					
						
							|  |  |  | 							float pa_vel = len_v3(state.vel); | 
					
						
							|  |  |  | 							float head = part->bb_vel_head*pa_vel; | 
					
						
							|  |  |  | 							float tail = part->bb_vel_tail*pa_vel; | 
					
						
							|  |  |  | 							bb.size[1] = part->bb_size[1]*pa_size + head + tail; | 
					
						
							|  |  |  | 							/* use offset to adjust the particle center. this is relative to size, so need to divide! */ | 
					
						
							|  |  |  | 							if (bb.size[1] > 0.0f) | 
					
						
							|  |  |  | 								bb.offset[1] += (head-tail) / bb.size[1]; | 
					
						
							|  |  |  | 						} | 
					
						
							|  |  |  | 						else | 
					
						
							|  |  |  | 							bb.size[1] = part->bb_size[1] * pa_size; | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 						bb.tilt = part->bb_tilt * (1.0f - part->bb_rand_tilt * r_tilt); | 
					
						
							|  |  |  | 						bb.time = ct; | 
					
						
							|  |  |  | 					} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-01 06:26:48 +00:00
										 |  |  | 					pixsize = ED_view3d_pixel_size(rv3d, state.co) * pixsize_scale; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 					draw_particle(&state, draw_as, part->draw, pixsize, imat, part->draw_line, &bb, psys->pdd); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 					totpoint++; | 
					
						
							|  |  |  | 					drawn = 1; | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				state.time=cfra; | 
					
						
							|  |  |  | 				if(psys_get_particle_state(&sim,a,&state,0)){ | 
					
						
							| 
									
										
										
										
											2012-02-01 06:26:48 +00:00
										 |  |  | 					float pixsize; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 					if(psys->parent) | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 						mul_m4_v3(psys->parent->obmat, state.co); | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 					/* create actiual particle data */ | 
					
						
							|  |  |  | 					if(draw_as == PART_DRAW_BB) { | 
					
						
							| 
									
										
										
										
											2011-06-23 18:59:47 +00:00
										 |  |  | 						bb.offset[0] = part->bb_offset[0]; | 
					
						
							|  |  |  | 						bb.offset[1] = part->bb_offset[1]; | 
					
						
							|  |  |  | 						bb.size[0] = part->bb_size[0] * pa_size; | 
					
						
							|  |  |  | 						if (part->bb_align==PART_BB_VEL) { | 
					
						
							|  |  |  | 							float pa_vel = len_v3(state.vel); | 
					
						
							|  |  |  | 							float head = part->bb_vel_head*pa_vel; | 
					
						
							|  |  |  | 							float tail = part->bb_vel_tail*pa_vel; | 
					
						
							|  |  |  | 							bb.size[1] = part->bb_size[1]*pa_size + head + tail; | 
					
						
							|  |  |  | 							/* use offset to adjust the particle center. this is relative to size, so need to divide! */ | 
					
						
							|  |  |  | 							if (bb.size[1] > 0.0f) | 
					
						
							|  |  |  | 								bb.offset[1] += (head-tail) / bb.size[1]; | 
					
						
							|  |  |  | 						} | 
					
						
							|  |  |  | 						else | 
					
						
							|  |  |  | 							bb.size[1] = part->bb_size[1] * pa_size; | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 						bb.tilt = part->bb_tilt * (1.0f - part->bb_rand_tilt * r_tilt); | 
					
						
							|  |  |  | 						bb.time = pa_time; | 
					
						
							|  |  |  | 					} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-01 06:26:48 +00:00
										 |  |  | 					pixsize = ED_view3d_pixel_size(rv3d, state.co) * pixsize_scale; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 					draw_particle(&state, draw_as, part->draw, pixsize, imat, part->draw_line, &bb, pdd); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 					totpoint++; | 
					
						
							|  |  |  | 					drawn = 1; | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 			if(drawn) { | 
					
						
							|  |  |  | 				/* additional things to draw for each particle	*/ | 
					
						
							|  |  |  | 				/* (velocity, size and number)					*/ | 
					
						
							| 
									
										
										
										
											2011-01-15 12:29:22 +00:00
										 |  |  | 				if((part->draw & PART_DRAW_VEL) && pdd && pdd->vedata){ | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 					copy_v3_v3(pdd->ved,state.co); | 
					
						
							|  |  |  | 					pdd->ved += 3; | 
					
						
							|  |  |  | 					mul_v3_v3fl(vel, state.vel, timestep); | 
					
						
							|  |  |  | 					add_v3_v3v3(pdd->ved, state.co, vel); | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 					pdd->ved+=3; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					totve++; | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 				if(part->draw & PART_DRAW_SIZE){ | 
					
						
							|  |  |  | 					setlinestyle(3); | 
					
						
							|  |  |  | 					drawcircball(GL_LINE_LOOP, state.co, pa_size, imat); | 
					
						
							|  |  |  | 					setlinestyle(0); | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-16 17:49:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				if((part->draw & PART_DRAW_NUM || part->draw & PART_DRAW_HEALTH) && (v3d->flag2 & V3D_RENDER_OVERRIDE)==0){ | 
					
						
							| 
									
										
										
										
											2010-03-03 11:40:12 +00:00
										 |  |  | 					float vec_txt[3]; | 
					
						
							| 
									
										
										
										
											2012-01-11 09:33:44 +00:00
										 |  |  | 					char *val_pos= numstr; | 
					
						
							|  |  |  | 					numstr[0]= '\0'; | 
					
						
							| 
									
										
										
										
											2010-03-03 11:23:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-30 23:02:38 +00:00
										 |  |  | 					if(part->draw&PART_DRAW_NUM) { | 
					
						
							|  |  |  | 						if(a < totpart && (part->draw & PART_DRAW_HEALTH) && (part->phystype==PART_PHYS_BOIDS)) { | 
					
						
							|  |  |  | 							sprintf(val_pos, "%d:%.2f", a, pa_health); | 
					
						
							|  |  |  | 						} | 
					
						
							|  |  |  | 						else { | 
					
						
							|  |  |  | 							sprintf(val_pos, "%d", a); | 
					
						
							|  |  |  | 						} | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 					else { | 
					
						
							|  |  |  | 						if(a < totpart && (part->draw & PART_DRAW_HEALTH) && (part->phystype==PART_PHYS_BOIDS)) { | 
					
						
							|  |  |  | 							sprintf(val_pos, "%.2f", pa_health); | 
					
						
							|  |  |  | 						} | 
					
						
							|  |  |  | 					} | 
					
						
							| 
									
										
										
										
											2009-07-20 23:52:53 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 					/* in path drawing state.co is the end point */ | 
					
						
							| 
									
										
										
										
											2010-07-17 18:08:14 +00:00
										 |  |  | 					/* use worldspace beause object matrix is already applied */ | 
					
						
							| 
									
										
										
										
											2010-03-03 11:40:12 +00:00
										 |  |  | 					mul_v3_m4v3(vec_txt, ob->imat, state.co); | 
					
						
							| 
									
										
										
										
											2012-01-11 09:33:44 +00:00
										 |  |  | 					view3d_cached_text_draw_add(vec_txt, numstr, 10, V3D_CACHE_TEXT_WORLDSPACE|V3D_CACHE_TEXT_ASCII, tcol); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | /* 6. */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 	glGetIntegerv(GL_POLYGON_MODE, polygonmode); | 
					
						
							| 
									
										
										
										
											2009-12-09 14:37:26 +00:00
										 |  |  | 	glEnableClientState(GL_VERTEX_ARRAY); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 	if(draw_as==PART_DRAW_PATH){ | 
					
						
							|  |  |  | 		ParticleCacheKey **cache, *path; | 
					
						
							| 
									
										
										
										
											2011-09-20 08:48:48 +00:00
										 |  |  | 		float /* *cd2=NULL, */ /* UNUSED */ *cdata2=NULL; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 		/* setup gl flags */ | 
					
						
							| 
									
										
										
										
											2010-05-04 12:31:24 +00:00
										 |  |  | 		if (1) { //ob_dt > OB_WIRE) {
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 			glEnableClientState(GL_NORMAL_ARRAY); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Completely refactored sph fluid particles. Only the very core of the algorithm remains
the same, but big changes have happened both on the outside and on the inside.
New UI:
* The old parameters were quite true to the underlying algorithm, but were quite obscure
  from a users point of view. Now there are only a few intuitive basic parameters that
  define the basic fluid behavior.
** By default particle size is now used to determine the interaction radius, rest
   density and spring rest lengths so that it's easy to get stable simulations by simply
   emitting particles for a few frames and adjusting the particle size (easy when the
   particle size is drawn) so that the fluid appears continuous (particles are touching
   eachother).
** Stiffness - in reality most fluids are very incompressible, but this is a very hard
   problem to solve with particle based fluid simulation so some compromises have to be
   made. So the bigger the stiffness parameter is the less the fluid will compress under
   stress, but the more substeps are needed for stable simulation.
** Viscosity - how much internal friction there is in the fluid. Large viscosities also
   smooth out instabilities, so less viscous fluids again need more substeps to remain
   stable.
** Buoancy - with high buoancy low pressure areas inside the fluid start to rise against
   gravity, and high pressure areas start to come down.
* In addition to these basic parameters there are separate advanced parameters that can
  either be tweaked relative to the basic parameters (or particle size) or defined
  independently.
** Repulsion - the stiffness parameter tries to keep the fluid density constant, but this
   can lead to small clumps of particles, so the repulsion keeps the particles better
   separated.
** Stiff viscosity - the normal viscosity only applies when particles are moving closer to 
   eachother to allow free flowing fluids. Stiff viscosity also applies smoothing to
   particles that are moving away from eachother.
** Interaction radius - by default this is 4 * particle size.
** Rest density - by default this is a density that the particles have when they're packed
   densely next to eachother.
** Spring rest length - by default this is 2 * particle size.
* There are also new options for 3d view particle coloring in the display panel to show
  particle velocity and acceleration. These make it easier to see what's happening in the
  fluid simulations, but can of course be used with other particles as well.
* Viscoelastic springs have some new options too. The plasticity can now be set to much
  higher values for instant deletion of springs as the elastic limit is exeeded. In addition
  to that there is an option to only create springs for a certain number of frames when a
  particle is born. These options give new possibilities for breaking viscoelastic fluids.
New in the code:
* Most of the fluids code is now thread safe, so when particle dynamics go threaded there
  will be a nice speed boost to fluids as well.
* Fluids now use a bvh-tree instead of a kd-tree for the neighbor lookups. The bvh-tree 
  implementation makes the code quite a bit cleaner and should also give a slight speed
  boost to the simulation too.
* Previously only force fields were calculated with the different integration methods, but
  now the fluid calculations are also done using the selected integration method, so there
  are again more choices in effecting simulation accuracy and stability. This change also
  included a nice cleanup of the whole particle integration code.
As the internals are pretty stirred up old particle fluid simulations will probably not
work correctly straight away, but with some tweaking the same level of control is still
available by not using the "relative versions" of the advanced parameters (by default these
are not used when loading old files).
											
										 
											2011-03-12 12:38:11 +00:00
										 |  |  | 			if(part->draw_col == PART_DRAW_COL_MAT) | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 				glEnableClientState(GL_COLOR_ARRAY); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 			glEnable(GL_LIGHTING); | 
					
						
							|  |  |  | 			glColorMaterial(GL_FRONT_AND_BACK, GL_DIFFUSE); | 
					
						
							|  |  |  | 			glEnable(GL_COLOR_MATERIAL); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2010-05-04 12:31:24 +00:00
										 |  |  | 		/*else {
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 			glDisableClientState(GL_NORMAL_ARRAY); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 			glDisable(GL_COLOR_MATERIAL); | 
					
						
							|  |  |  | 			glDisable(GL_LIGHTING); | 
					
						
							|  |  |  | 			UI_ThemeColor(TH_WIRE); | 
					
						
							| 
									
										
										
										
											2010-05-04 12:31:24 +00:00
										 |  |  | 		}*/ | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-17 17:07:50 +00:00
										 |  |  | 		if(totchild && (part->draw&PART_DRAW_PARENT)==0) | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 			totpart=0; | 
					
						
							| 
									
										
										
										
											2009-11-01 00:06:53 +00:00
										 |  |  | 		else if(psys->pathcache==NULL) | 
					
						
							|  |  |  | 			totpart=0; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 		/* draw actual/parent particles */ | 
					
						
							|  |  |  | 		cache=psys->pathcache; | 
					
						
							|  |  |  | 		for(a=0, pa=psys->particles; a<totpart; a++, pa++){ | 
					
						
							|  |  |  | 			path=cache[a]; | 
					
						
							|  |  |  | 			if(path->steps > 0) { | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 				glVertexPointer(3, GL_FLOAT, sizeof(ParticleCacheKey), path->co); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-05-04 12:31:24 +00:00
										 |  |  | 				if(1) { //ob_dt > OB_WIRE) {
 | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 					glNormalPointer(GL_FLOAT, sizeof(ParticleCacheKey), path->vel); | 
					
						
							| 
									
										
											  
											
												Completely refactored sph fluid particles. Only the very core of the algorithm remains
the same, but big changes have happened both on the outside and on the inside.
New UI:
* The old parameters were quite true to the underlying algorithm, but were quite obscure
  from a users point of view. Now there are only a few intuitive basic parameters that
  define the basic fluid behavior.
** By default particle size is now used to determine the interaction radius, rest
   density and spring rest lengths so that it's easy to get stable simulations by simply
   emitting particles for a few frames and adjusting the particle size (easy when the
   particle size is drawn) so that the fluid appears continuous (particles are touching
   eachother).
** Stiffness - in reality most fluids are very incompressible, but this is a very hard
   problem to solve with particle based fluid simulation so some compromises have to be
   made. So the bigger the stiffness parameter is the less the fluid will compress under
   stress, but the more substeps are needed for stable simulation.
** Viscosity - how much internal friction there is in the fluid. Large viscosities also
   smooth out instabilities, so less viscous fluids again need more substeps to remain
   stable.
** Buoancy - with high buoancy low pressure areas inside the fluid start to rise against
   gravity, and high pressure areas start to come down.
* In addition to these basic parameters there are separate advanced parameters that can
  either be tweaked relative to the basic parameters (or particle size) or defined
  independently.
** Repulsion - the stiffness parameter tries to keep the fluid density constant, but this
   can lead to small clumps of particles, so the repulsion keeps the particles better
   separated.
** Stiff viscosity - the normal viscosity only applies when particles are moving closer to 
   eachother to allow free flowing fluids. Stiff viscosity also applies smoothing to
   particles that are moving away from eachother.
** Interaction radius - by default this is 4 * particle size.
** Rest density - by default this is a density that the particles have when they're packed
   densely next to eachother.
** Spring rest length - by default this is 2 * particle size.
* There are also new options for 3d view particle coloring in the display panel to show
  particle velocity and acceleration. These make it easier to see what's happening in the
  fluid simulations, but can of course be used with other particles as well.
* Viscoelastic springs have some new options too. The plasticity can now be set to much
  higher values for instant deletion of springs as the elastic limit is exeeded. In addition
  to that there is an option to only create springs for a certain number of frames when a
  particle is born. These options give new possibilities for breaking viscoelastic fluids.
New in the code:
* Most of the fluids code is now thread safe, so when particle dynamics go threaded there
  will be a nice speed boost to fluids as well.
* Fluids now use a bvh-tree instead of a kd-tree for the neighbor lookups. The bvh-tree 
  implementation makes the code quite a bit cleaner and should also give a slight speed
  boost to the simulation too.
* Previously only force fields were calculated with the different integration methods, but
  now the fluid calculations are also done using the selected integration method, so there
  are again more choices in effecting simulation accuracy and stability. This change also
  included a nice cleanup of the whole particle integration code.
As the internals are pretty stirred up old particle fluid simulations will probably not
work correctly straight away, but with some tweaking the same level of control is still
available by not using the "relative versions" of the advanced parameters (by default these
are not used when loading old files).
											
										 
											2011-03-12 12:38:11 +00:00
										 |  |  | 					if(part->draw_col == PART_DRAW_COL_MAT) | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 						glColorPointer(3, GL_FLOAT, sizeof(ParticleCacheKey), path->col); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 				glDrawArrays(GL_LINE_STRIP, 0, path->steps + 1); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* draw child particles */ | 
					
						
							|  |  |  | 		cache=psys->childcache; | 
					
						
							|  |  |  | 		for(a=0; a<totchild; a++){ | 
					
						
							|  |  |  | 			path=cache[a]; | 
					
						
							|  |  |  | 			glVertexPointer(3, GL_FLOAT, sizeof(ParticleCacheKey), path->co); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-05-04 12:31:24 +00:00
										 |  |  | 			if(1) { //ob_dt > OB_WIRE) {
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 				glNormalPointer(GL_FLOAT, sizeof(ParticleCacheKey), path->vel); | 
					
						
							| 
									
										
											  
											
												Completely refactored sph fluid particles. Only the very core of the algorithm remains
the same, but big changes have happened both on the outside and on the inside.
New UI:
* The old parameters were quite true to the underlying algorithm, but were quite obscure
  from a users point of view. Now there are only a few intuitive basic parameters that
  define the basic fluid behavior.
** By default particle size is now used to determine the interaction radius, rest
   density and spring rest lengths so that it's easy to get stable simulations by simply
   emitting particles for a few frames and adjusting the particle size (easy when the
   particle size is drawn) so that the fluid appears continuous (particles are touching
   eachother).
** Stiffness - in reality most fluids are very incompressible, but this is a very hard
   problem to solve with particle based fluid simulation so some compromises have to be
   made. So the bigger the stiffness parameter is the less the fluid will compress under
   stress, but the more substeps are needed for stable simulation.
** Viscosity - how much internal friction there is in the fluid. Large viscosities also
   smooth out instabilities, so less viscous fluids again need more substeps to remain
   stable.
** Buoancy - with high buoancy low pressure areas inside the fluid start to rise against
   gravity, and high pressure areas start to come down.
* In addition to these basic parameters there are separate advanced parameters that can
  either be tweaked relative to the basic parameters (or particle size) or defined
  independently.
** Repulsion - the stiffness parameter tries to keep the fluid density constant, but this
   can lead to small clumps of particles, so the repulsion keeps the particles better
   separated.
** Stiff viscosity - the normal viscosity only applies when particles are moving closer to 
   eachother to allow free flowing fluids. Stiff viscosity also applies smoothing to
   particles that are moving away from eachother.
** Interaction radius - by default this is 4 * particle size.
** Rest density - by default this is a density that the particles have when they're packed
   densely next to eachother.
** Spring rest length - by default this is 2 * particle size.
* There are also new options for 3d view particle coloring in the display panel to show
  particle velocity and acceleration. These make it easier to see what's happening in the
  fluid simulations, but can of course be used with other particles as well.
* Viscoelastic springs have some new options too. The plasticity can now be set to much
  higher values for instant deletion of springs as the elastic limit is exeeded. In addition
  to that there is an option to only create springs for a certain number of frames when a
  particle is born. These options give new possibilities for breaking viscoelastic fluids.
New in the code:
* Most of the fluids code is now thread safe, so when particle dynamics go threaded there
  will be a nice speed boost to fluids as well.
* Fluids now use a bvh-tree instead of a kd-tree for the neighbor lookups. The bvh-tree 
  implementation makes the code quite a bit cleaner and should also give a slight speed
  boost to the simulation too.
* Previously only force fields were calculated with the different integration methods, but
  now the fluid calculations are also done using the selected integration method, so there
  are again more choices in effecting simulation accuracy and stability. This change also
  included a nice cleanup of the whole particle integration code.
As the internals are pretty stirred up old particle fluid simulations will probably not
work correctly straight away, but with some tweaking the same level of control is still
available by not using the "relative versions" of the advanced parameters (by default these
are not used when loading old files).
											
										 
											2011-03-12 12:38:11 +00:00
										 |  |  | 				if(part->draw_col == PART_DRAW_COL_MAT) | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 					glColorPointer(3, GL_FLOAT, sizeof(ParticleCacheKey), path->col); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 			glDrawArrays(GL_LINE_STRIP, 0, path->steps + 1); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 		/* restore & clean up */ | 
					
						
							| 
									
										
										
										
											2010-05-04 12:31:24 +00:00
										 |  |  | 		if(1) { //ob_dt > OB_WIRE) {
 | 
					
						
							| 
									
										
											  
											
												Completely refactored sph fluid particles. Only the very core of the algorithm remains
the same, but big changes have happened both on the outside and on the inside.
New UI:
* The old parameters were quite true to the underlying algorithm, but were quite obscure
  from a users point of view. Now there are only a few intuitive basic parameters that
  define the basic fluid behavior.
** By default particle size is now used to determine the interaction radius, rest
   density and spring rest lengths so that it's easy to get stable simulations by simply
   emitting particles for a few frames and adjusting the particle size (easy when the
   particle size is drawn) so that the fluid appears continuous (particles are touching
   eachother).
** Stiffness - in reality most fluids are very incompressible, but this is a very hard
   problem to solve with particle based fluid simulation so some compromises have to be
   made. So the bigger the stiffness parameter is the less the fluid will compress under
   stress, but the more substeps are needed for stable simulation.
** Viscosity - how much internal friction there is in the fluid. Large viscosities also
   smooth out instabilities, so less viscous fluids again need more substeps to remain
   stable.
** Buoancy - with high buoancy low pressure areas inside the fluid start to rise against
   gravity, and high pressure areas start to come down.
* In addition to these basic parameters there are separate advanced parameters that can
  either be tweaked relative to the basic parameters (or particle size) or defined
  independently.
** Repulsion - the stiffness parameter tries to keep the fluid density constant, but this
   can lead to small clumps of particles, so the repulsion keeps the particles better
   separated.
** Stiff viscosity - the normal viscosity only applies when particles are moving closer to 
   eachother to allow free flowing fluids. Stiff viscosity also applies smoothing to
   particles that are moving away from eachother.
** Interaction radius - by default this is 4 * particle size.
** Rest density - by default this is a density that the particles have when they're packed
   densely next to eachother.
** Spring rest length - by default this is 2 * particle size.
* There are also new options for 3d view particle coloring in the display panel to show
  particle velocity and acceleration. These make it easier to see what's happening in the
  fluid simulations, but can of course be used with other particles as well.
* Viscoelastic springs have some new options too. The plasticity can now be set to much
  higher values for instant deletion of springs as the elastic limit is exeeded. In addition
  to that there is an option to only create springs for a certain number of frames when a
  particle is born. These options give new possibilities for breaking viscoelastic fluids.
New in the code:
* Most of the fluids code is now thread safe, so when particle dynamics go threaded there
  will be a nice speed boost to fluids as well.
* Fluids now use a bvh-tree instead of a kd-tree for the neighbor lookups. The bvh-tree 
  implementation makes the code quite a bit cleaner and should also give a slight speed
  boost to the simulation too.
* Previously only force fields were calculated with the different integration methods, but
  now the fluid calculations are also done using the selected integration method, so there
  are again more choices in effecting simulation accuracy and stability. This change also
  included a nice cleanup of the whole particle integration code.
As the internals are pretty stirred up old particle fluid simulations will probably not
work correctly straight away, but with some tweaking the same level of control is still
available by not using the "relative versions" of the advanced parameters (by default these
are not used when loading old files).
											
										 
											2011-03-12 12:38:11 +00:00
										 |  |  | 			if(part->draw_col == PART_DRAW_COL_MAT) | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 				glDisable(GL_COLOR_ARRAY); | 
					
						
							|  |  |  | 			glDisable(GL_COLOR_MATERIAL); | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 		if(cdata2) | 
					
						
							|  |  |  | 			MEM_freeN(cdata2); | 
					
						
							| 
									
										
										
										
											2011-09-20 08:48:48 +00:00
										 |  |  | 		/* cd2= */ /* UNUSED */ cdata2=NULL; | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		glLineWidth(1.0f); | 
					
						
							| 
									
										
										
										
											2010-06-22 15:02:23 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		if((part->draw & PART_DRAW_NUM) && (v3d->flag2 & V3D_RENDER_OVERRIDE)==0){ | 
					
						
							|  |  |  | 			cache=psys->pathcache; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			for(a=0, pa=psys->particles; a<totpart; a++, pa++){ | 
					
						
							|  |  |  | 				float vec_txt[3]; | 
					
						
							| 
									
										
										
										
											2012-01-11 12:33:51 +00:00
										 |  |  | 				BLI_snprintf(numstr, sizeof(numstr), "%i", a); | 
					
						
							| 
									
										
										
										
											2010-07-17 18:08:14 +00:00
										 |  |  | 				/* use worldspace beause object matrix is already applied */ | 
					
						
							| 
									
										
										
										
											2010-06-22 15:02:23 +00:00
										 |  |  | 				mul_v3_m4v3(vec_txt, ob->imat, cache[a]->co); | 
					
						
							| 
									
										
										
										
											2012-01-11 09:33:44 +00:00
										 |  |  | 				view3d_cached_text_draw_add(vec_txt, numstr, 10, V3D_CACHE_TEXT_WORLDSPACE|V3D_CACHE_TEXT_ASCII, tcol); | 
					
						
							| 
									
										
										
										
											2010-06-22 15:02:23 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else if(pdd && ELEM(draw_as, 0, PART_DRAW_CIRC)==0){ | 
					
						
							|  |  |  | 		glDisableClientState(GL_COLOR_ARRAY); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* enable point data array */ | 
					
						
							|  |  |  | 		if(pdd->vdata){ | 
					
						
							|  |  |  | 			glEnableClientState(GL_VERTEX_ARRAY); | 
					
						
							|  |  |  | 			glVertexPointer(3, GL_FLOAT, 0, pdd->vdata); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else | 
					
						
							|  |  |  | 			glDisableClientState(GL_VERTEX_ARRAY); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if(select) { | 
					
						
							|  |  |  | 			UI_ThemeColor(TH_ACTIVE); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if(part->draw_size) | 
					
						
							|  |  |  | 				glPointSize(part->draw_size + 2); | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 			else | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 				glPointSize(4.0); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 			glLineWidth(3.0); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 			draw_particle_arrays(draw_as, totpoint, ob_dt, 1); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 		/* restore from select */ | 
					
						
							| 
									
										
										
										
											2011-11-26 03:13:54 +00:00
										 |  |  | 		glColor3fv(ma_col); | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 		glPointSize(part->draw_size ? part->draw_size : 2.0); | 
					
						
							|  |  |  | 		glLineWidth(1.0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* enable other data arrays */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* billboards are drawn this way */ | 
					
						
							|  |  |  | 		if(pdd->ndata && ob_dt>OB_WIRE){ | 
					
						
							|  |  |  | 			glEnableClientState(GL_NORMAL_ARRAY); | 
					
						
							|  |  |  | 			glNormalPointer(GL_FLOAT, 0, pdd->ndata); | 
					
						
							|  |  |  | 			glEnable(GL_LIGHTING); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else{ | 
					
						
							|  |  |  | 			glDisableClientState(GL_NORMAL_ARRAY); | 
					
						
							|  |  |  | 			glDisable(GL_LIGHTING); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 		if(pdd->cdata){ | 
					
						
							|  |  |  | 			glEnableClientState(GL_COLOR_ARRAY); | 
					
						
							|  |  |  | 			glColorPointer(3, GL_FLOAT, 0, pdd->cdata); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 		draw_particle_arrays(draw_as, totpoint, ob_dt, 0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		pdd->flag |= PARTICLE_DRAW_DATA_UPDATED; | 
					
						
							|  |  |  | 		pdd->totpoint = totpoint; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(pdd && pdd->vedata){ | 
					
						
							|  |  |  | 		glDisableClientState(GL_COLOR_ARRAY); | 
					
						
							|  |  |  | 		cpack(0xC0C0C0); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		glVertexPointer(3, GL_FLOAT, 0, pdd->vedata); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		glDrawArrays(GL_LINES, 0, 2*totve); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 	glPolygonMode(GL_FRONT, polygonmode[0]); | 
					
						
							|  |  |  | 	glPolygonMode(GL_BACK, polygonmode[1]); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | /* 7. */ | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	glDisable(GL_LIGHTING); | 
					
						
							|  |  |  | 	glDisableClientState(GL_COLOR_ARRAY); | 
					
						
							| 
									
										
										
										
											2009-12-09 14:37:26 +00:00
										 |  |  | 	glDisableClientState(GL_VERTEX_ARRAY); | 
					
						
							|  |  |  | 	glDisableClientState(GL_NORMAL_ARRAY); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if(states) | 
					
						
							|  |  |  | 		MEM_freeN(states); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	psys->flag &= ~PSYS_DRAWING; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 	/* draw data can't be saved for billboards as they must update to target changes */ | 
					
						
							|  |  |  | 	if(draw_as == PART_DRAW_BB) { | 
					
						
							|  |  |  | 		psys_free_pdd(psys); | 
					
						
							|  |  |  | 		pdd->flag &= ~PARTICLE_DRAW_DATA_UPDATED; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	if(psys->lattice){ | 
					
						
							| 
									
										
										
										
											2009-01-07 16:05:55 +00:00
										 |  |  | 		end_latt_deform(psys->lattice); | 
					
						
							|  |  |  | 		psys->lattice= NULL; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-12 16:54:24 +00:00
										 |  |  | 	if(pdd) { | 
					
						
							|  |  |  | 		/* drop references to stack memory */ | 
					
						
							| 
									
										
										
										
											2011-11-26 03:13:54 +00:00
										 |  |  | 		pdd->ma_col= NULL; | 
					
						
							| 
									
										
										
										
											2011-02-12 16:54:24 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if( (base->flag & OB_FROMDUPLI) && (ob->flag & OB_FROMGROUP) ) { | 
					
						
							| 
									
										
										
										
											2010-02-01 15:32:55 +00:00
										 |  |  | 		glLoadMatrixf(rv3d->viewmat); | 
					
						
							| 
									
										
										
										
											2011-02-12 16:54:24 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-07 17:55:58 +00:00
										 |  |  | static void draw_update_ptcache_edit(Scene *scene, Object *ob, PTCacheEdit *edit) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if(edit->psys && edit->psys->flag & PSYS_HAIR_UPDATED) | 
					
						
							|  |  |  | 		PE_update_object(scene, ob, 0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* create path and child path cache if it doesn't exist already */ | 
					
						
							| 
									
										
										
										
											2011-03-03 17:59:04 +00:00
										 |  |  | 	if(edit->pathcache == NULL) | 
					
						
							| 
									
										
										
										
											2009-12-07 17:55:58 +00:00
										 |  |  | 		psys_cache_edit_paths(scene, ob, edit, CFRA); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-14 01:22:14 +00:00
										 |  |  | static void draw_ptcache_edit(Scene *scene, View3D *v3d, PTCacheEdit *edit) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 	ParticleCacheKey **cache, *path, *pkey; | 
					
						
							|  |  |  | 	PTCacheEditPoint *point; | 
					
						
							|  |  |  | 	PTCacheEditKey *key; | 
					
						
							| 
									
										
										
										
											2009-01-24 13:45:24 +00:00
										 |  |  | 	ParticleEditSettings *pset = PE_settings(scene); | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 	int i, k, totpoint = edit->totpoint, timed = pset->flag & PE_FADE_TIME ? pset->fade_frames : 0; | 
					
						
							| 
									
										
										
										
											2009-11-01 00:06:53 +00:00
										 |  |  | 	int steps=1; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	float sel_col[3]; | 
					
						
							|  |  |  | 	float nosel_col[3]; | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 	float *pathcol = NULL, *pcol; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-03 17:59:04 +00:00
										 |  |  | 	if(edit->pathcache == NULL) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 	PE_hide_keys_time(scene, edit, CFRA); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* opengl setup */ | 
					
						
							|  |  |  | 	if((v3d->flag & V3D_ZBUF_SELECT)==0) | 
					
						
							|  |  |  | 		glDisable(GL_DEPTH_TEST); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* get selection theme colors */ | 
					
						
							| 
									
										
										
										
											2009-12-03 00:42:02 +00:00
										 |  |  | 	UI_GetThemeColor3fv(TH_VERTEX_SELECT, sel_col); | 
					
						
							|  |  |  | 	UI_GetThemeColor3fv(TH_VERTEX, nosel_col); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* draw paths */ | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 	if(timed) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		glEnable(GL_BLEND); | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 		steps = (*edit->pathcache)->steps + 1; | 
					
						
							|  |  |  | 		pathcol = MEM_callocN(steps*4*sizeof(float), "particle path color data"); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	glEnableClientState(GL_VERTEX_ARRAY); | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 	glEnableClientState(GL_COLOR_ARRAY); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 	glColorMaterial(GL_FRONT_AND_BACK, GL_DIFFUSE); | 
					
						
							| 
									
										
										
										
											2010-11-26 23:38:23 +00:00
										 |  |  | 	glEnable(GL_COLOR_MATERIAL); | 
					
						
							| 
									
										
										
										
											2010-01-14 09:01:57 +00:00
										 |  |  | 	glShadeModel(GL_SMOOTH); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-14 08:53:10 +00:00
										 |  |  | 	if(pset->brushtype == PE_BRUSH_WEIGHT) { | 
					
						
							|  |  |  | 		glLineWidth(2.0f); | 
					
						
							|  |  |  | 		glDisable(GL_LIGHTING); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 	cache=edit->pathcache; | 
					
						
							|  |  |  | 	for(i=0; i<totpoint; i++){ | 
					
						
							|  |  |  | 		path = cache[i]; | 
					
						
							|  |  |  | 		glVertexPointer(3, GL_FLOAT, sizeof(ParticleCacheKey), path->co); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 		if(timed) { | 
					
						
							|  |  |  | 			for(k=0, pcol=pathcol, pkey=path; k<steps; k++, pkey++, pcol+=4){ | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 				copy_v3_v3(pcol, pkey->col); | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 				pcol[3] = 1.0f - fabsf((float)(CFRA) - pkey->time)/(float)pset->fade_frames; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 			glColorPointer(4, GL_FLOAT, 4*sizeof(float), pathcol); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 		else | 
					
						
							|  |  |  | 			glColorPointer(3, GL_FLOAT, sizeof(ParticleCacheKey), path->col); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 		glDrawArrays(GL_LINE_STRIP, 0, path->steps + 1); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 	if(pathcol) { MEM_freeN(pathcol); pathcol = pcol = NULL; } | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* draw edit vertices */ | 
					
						
							| 
									
										
										
										
											2009-06-23 00:41:55 +00:00
										 |  |  | 	if(pset->selectmode!=SCE_SELECT_PATH){ | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		glPointSize(UI_GetThemeValuef(TH_VERTEX_SIZE)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-23 00:41:55 +00:00
										 |  |  | 		if(pset->selectmode==SCE_SELECT_POINT){ | 
					
						
							| 
									
										
										
										
											2011-03-03 17:59:04 +00:00
										 |  |  | 			float *pd=NULL,*pdata=NULL; | 
					
						
							|  |  |  | 			float *cd=NULL,*cdata=NULL; | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 			int totkeys = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			for (i=0, point=edit->points; i<totpoint; i++, point++) | 
					
						
							|  |  |  | 				if(!(point->flag & PEP_HIDE)) | 
					
						
							|  |  |  | 					totkeys += point->totkey; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 			if(edit->points && !(edit->points->keys->flag & PEK_USE_WCO)) | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 				pd=pdata=MEM_callocN(totkeys*3*sizeof(float), "particle edit point data"); | 
					
						
							|  |  |  | 			cd=cdata=MEM_callocN(totkeys*(timed?4:3)*sizeof(float), "particle edit color data"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			for(i=0, point=edit->points; i<totpoint; i++, point++){ | 
					
						
							|  |  |  | 				if(point->flag & PEP_HIDE) | 
					
						
							|  |  |  | 					continue; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				for(k=0, key=point->keys; k<point->totkey; k++, key++){ | 
					
						
							|  |  |  | 					if(pd) { | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 						copy_v3_v3(pd, key->co); | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 						pd += 3; | 
					
						
							|  |  |  | 					} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 					if(key->flag&PEK_SELECT){ | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 						copy_v3_v3(cd,sel_col); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 					} | 
					
						
							|  |  |  | 					else{ | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 						copy_v3_v3(cd,nosel_col); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 					} | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 					if(timed) | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 						*(cd+3) = 1.0f - fabsf((float)CFRA - *key->time)/(float)pset->fade_frames; | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 					cd += (timed?4:3); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			cd=cdata; | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 			pd=pdata; | 
					
						
							|  |  |  | 			for(i=0, point=edit->points; i<totpoint; i++, point++){ | 
					
						
							|  |  |  | 				if(point->flag & PEP_HIDE) | 
					
						
							|  |  |  | 					continue; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 				if(point->keys->flag & PEK_USE_WCO) | 
					
						
							|  |  |  | 					glVertexPointer(3, GL_FLOAT, sizeof(PTCacheEditKey), point->keys->world_co); | 
					
						
							|  |  |  | 				else | 
					
						
							|  |  |  | 					glVertexPointer(3, GL_FLOAT, 3*sizeof(float), pd); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 				glColorPointer((timed?4:3), GL_FLOAT, (timed?4:3)*sizeof(float), cd); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				glDrawArrays(GL_POINTS, 0, point->totkey); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				pd += pd ? 3 * point->totkey : 0; | 
					
						
							|  |  |  | 				cd += (timed?4:3) * point->totkey; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2011-03-03 17:59:04 +00:00
										 |  |  | 			if(pdata) { MEM_freeN(pdata); pd=pdata=NULL; } | 
					
						
							|  |  |  | 			if(cdata) { MEM_freeN(cdata); cd=cdata=NULL; } | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-06-23 00:41:55 +00:00
										 |  |  | 		else if(pset->selectmode == SCE_SELECT_END){ | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 			for(i=0, point=edit->points; i<totpoint; i++, point++){ | 
					
						
							|  |  |  | 				if((point->flag & PEP_HIDE)==0){ | 
					
						
							|  |  |  | 					key = point->keys + point->totkey - 1; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 					if(key->flag & PEK_SELECT) | 
					
						
							|  |  |  | 						glColor3fv(sel_col); | 
					
						
							|  |  |  | 					else | 
					
						
							|  |  |  | 						glColor3fv(nosel_col); | 
					
						
							|  |  |  | 					/* has to be like this.. otherwise selection won't work, have try glArrayElement later..*/ | 
					
						
							|  |  |  | 					glBegin(GL_POINTS); | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 					glVertex3fv(key->flag & PEK_USE_WCO ? key->world_co : key->co); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 					glEnd(); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glDisable(GL_BLEND); | 
					
						
							|  |  |  | 	glDisable(GL_LIGHTING); | 
					
						
							|  |  |  | 	glDisable(GL_COLOR_MATERIAL); | 
					
						
							|  |  |  | 	glDisableClientState(GL_COLOR_ARRAY); | 
					
						
							| 
									
										
										
										
											2009-12-09 14:37:26 +00:00
										 |  |  | 	glDisableClientState(GL_NORMAL_ARRAY); | 
					
						
							|  |  |  | 	glDisableClientState(GL_VERTEX_ARRAY); | 
					
						
							| 
									
										
										
										
											2010-01-14 09:01:57 +00:00
										 |  |  | 	glShadeModel(GL_FLAT); | 
					
						
							| 
									
										
										
										
											2011-05-02 12:50:26 +00:00
										 |  |  | 	if(v3d->zbuf) glEnable(GL_DEPTH_TEST); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	glLineWidth(1.0f); | 
					
						
							|  |  |  | 	glPointSize(1.0); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-11-26 00:15:26 +00:00
										 |  |  | //static void ob_draw_RE_motion(float com[3],float rotscale[3][3],float tw,float th)
 | 
					
						
							|  |  |  | static void ob_draw_RE_motion(float com[3],float rotscale[3][3],float itw,float ith,float drw_size) | 
					
						
							| 
									
										
										
										
											2009-11-21 22:45:25 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-11-26 00:15:26 +00:00
										 |  |  | 	float tr[3][3]; | 
					
						
							|  |  |  | 	float root[3],tip[3]; | 
					
						
							|  |  |  | 	float tw,th; | 
					
						
							|  |  |  | 	/* take a copy for not spoiling original */ | 
					
						
							|  |  |  | 	copy_m3_m3(tr,rotscale); | 
					
						
							|  |  |  | 	tw = itw * drw_size; | 
					
						
							|  |  |  | 	th = ith * drw_size; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glColor4ub(0x7F, 0x00, 0x00, 155); | 
					
						
							|  |  |  | 	glBegin(GL_LINES); | 
					
						
							|  |  |  | 	root[1] = root[2] = 0.0f; | 
					
						
							|  |  |  | 	root[0] = -drw_size; | 
					
						
							|  |  |  | 	mul_m3_v3(tr,root); | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 	add_v3_v3(root, com); | 
					
						
							| 
									
										
										
										
											2009-11-26 00:15:26 +00:00
										 |  |  | 	glVertex3fv(root);  | 
					
						
							|  |  |  | 	tip[1] = tip[2] = 0.0f; | 
					
						
							|  |  |  | 	tip[0] = drw_size; | 
					
						
							|  |  |  | 	mul_m3_v3(tr,tip); | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 	add_v3_v3(tip, com); | 
					
						
							| 
									
										
										
										
											2009-11-26 00:15:26 +00:00
										 |  |  | 	glVertex3fv(tip);  | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-26 00:15:26 +00:00
										 |  |  | 	root[1] =0.0f; root[2] = tw; | 
					
						
							|  |  |  | 	root[0] = th; | 
					
						
							|  |  |  | 	glBegin(GL_LINES); | 
					
						
							|  |  |  | 	mul_m3_v3(tr,root); | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 	add_v3_v3(root, com); | 
					
						
							| 
									
										
										
										
											2009-11-26 00:15:26 +00:00
										 |  |  | 	glVertex3fv(root);  | 
					
						
							|  |  |  | 	glVertex3fv(tip);  | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							| 
									
										
										
										
											2009-11-21 22:45:25 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-26 00:15:26 +00:00
										 |  |  | 	root[1] =0.0f; root[2] = -tw; | 
					
						
							|  |  |  | 	root[0] = th; | 
					
						
							|  |  |  | 	glBegin(GL_LINES); | 
					
						
							|  |  |  | 	mul_m3_v3(tr,root); | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 	add_v3_v3(root, com); | 
					
						
							| 
									
										
										
										
											2009-11-26 00:15:26 +00:00
										 |  |  | 	glVertex3fv(root);  | 
					
						
							|  |  |  | 	glVertex3fv(tip);  | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							| 
									
										
										
										
											2009-11-21 22:45:25 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-26 00:15:26 +00:00
										 |  |  | 	root[1] =tw; root[2] = 0.0f; | 
					
						
							|  |  |  | 	root[0] =th; | 
					
						
							|  |  |  | 	glBegin(GL_LINES); | 
					
						
							|  |  |  | 	mul_m3_v3(tr,root); | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 	add_v3_v3(root, com); | 
					
						
							| 
									
										
										
										
											2009-11-26 00:15:26 +00:00
										 |  |  | 	glVertex3fv(root);  | 
					
						
							|  |  |  | 	glVertex3fv(tip);  | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							| 
									
										
										
										
											2009-11-21 22:45:25 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-26 00:15:26 +00:00
										 |  |  | 	root[1] =-tw; root[2] = 0.0f; | 
					
						
							|  |  |  | 	root[0] = th; | 
					
						
							|  |  |  | 	glBegin(GL_LINES); | 
					
						
							|  |  |  | 	mul_m3_v3(tr,root); | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 	add_v3_v3(root, com); | 
					
						
							| 
									
										
										
										
											2009-11-26 00:15:26 +00:00
										 |  |  | 	glVertex3fv(root);  | 
					
						
							|  |  |  | 	glVertex3fv(tip);  | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glColor4ub(0x00, 0x7F, 0x00, 155); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glBegin(GL_LINES); | 
					
						
							|  |  |  | 	root[0] = root[2] = 0.0f; | 
					
						
							|  |  |  | 	root[1] = -drw_size; | 
					
						
							|  |  |  | 	mul_m3_v3(tr,root); | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 	add_v3_v3(root, com); | 
					
						
							| 
									
										
										
										
											2009-11-26 00:15:26 +00:00
										 |  |  | 	glVertex3fv(root);  | 
					
						
							|  |  |  | 	tip[0] = tip[2] = 0.0f; | 
					
						
							|  |  |  | 	tip[1] = drw_size; | 
					
						
							|  |  |  | 	mul_m3_v3(tr,tip); | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 	add_v3_v3(tip, com); | 
					
						
							| 
									
										
										
										
											2009-11-26 00:15:26 +00:00
										 |  |  | 	glVertex3fv(tip);  | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	root[0] =0.0f; root[2] = tw; | 
					
						
							|  |  |  | 	root[1] = th; | 
					
						
							|  |  |  | 	glBegin(GL_LINES); | 
					
						
							|  |  |  | 	mul_m3_v3(tr,root); | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 	add_v3_v3(root, com); | 
					
						
							| 
									
										
										
										
											2009-11-26 00:15:26 +00:00
										 |  |  | 	glVertex3fv(root);  | 
					
						
							|  |  |  | 	glVertex3fv(tip);  | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	root[0] =0.0f; root[2] = -tw; | 
					
						
							|  |  |  | 	root[1] = th; | 
					
						
							|  |  |  | 	glBegin(GL_LINES); | 
					
						
							|  |  |  | 	mul_m3_v3(tr,root); | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 	add_v3_v3(root, com); | 
					
						
							| 
									
										
										
										
											2009-11-26 00:15:26 +00:00
										 |  |  | 	glVertex3fv(root);  | 
					
						
							|  |  |  | 	glVertex3fv(tip);  | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	root[0] =tw; root[2] = 0.0f; | 
					
						
							|  |  |  | 	root[1] =th; | 
					
						
							|  |  |  | 	glBegin(GL_LINES); | 
					
						
							|  |  |  | 	mul_m3_v3(tr,root); | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 	add_v3_v3(root, com); | 
					
						
							| 
									
										
										
										
											2009-11-26 00:15:26 +00:00
										 |  |  | 	glVertex3fv(root);  | 
					
						
							|  |  |  | 	glVertex3fv(tip);  | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	root[0] =-tw; root[2] = 0.0f; | 
					
						
							|  |  |  | 	root[1] = th; | 
					
						
							|  |  |  | 	glBegin(GL_LINES); | 
					
						
							|  |  |  | 	mul_m3_v3(tr,root); | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 	add_v3_v3(root, com); | 
					
						
							| 
									
										
										
										
											2009-11-26 00:15:26 +00:00
										 |  |  | 	glVertex3fv(root);  | 
					
						
							|  |  |  | 	glVertex3fv(tip);  | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glColor4ub(0x00, 0x00, 0x7F, 155); | 
					
						
							|  |  |  | 	glBegin(GL_LINES); | 
					
						
							|  |  |  | 	root[0] = root[1] = 0.0f; | 
					
						
							|  |  |  | 	root[2] = -drw_size; | 
					
						
							|  |  |  | 	mul_m3_v3(tr,root); | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 	add_v3_v3(root, com); | 
					
						
							| 
									
										
										
										
											2009-11-26 00:15:26 +00:00
										 |  |  | 	glVertex3fv(root);  | 
					
						
							|  |  |  | 	tip[0] = tip[1] = 0.0f; | 
					
						
							|  |  |  | 	tip[2] = drw_size; | 
					
						
							|  |  |  | 	mul_m3_v3(tr,tip); | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 	add_v3_v3(tip, com); | 
					
						
							| 
									
										
										
										
											2009-11-26 00:15:26 +00:00
										 |  |  | 	glVertex3fv(tip);  | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	root[0] =0.0f; root[1] = tw; | 
					
						
							|  |  |  | 	root[2] = th; | 
					
						
							|  |  |  | 	glBegin(GL_LINES); | 
					
						
							|  |  |  | 	mul_m3_v3(tr,root); | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 	add_v3_v3(root, com); | 
					
						
							| 
									
										
										
										
											2009-11-26 00:15:26 +00:00
										 |  |  | 	glVertex3fv(root);  | 
					
						
							|  |  |  | 	glVertex3fv(tip);  | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	root[0] =0.0f; root[1] = -tw; | 
					
						
							|  |  |  | 	root[2] = th; | 
					
						
							|  |  |  | 	glBegin(GL_LINES); | 
					
						
							|  |  |  | 	mul_m3_v3(tr,root); | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 	add_v3_v3(root, com); | 
					
						
							| 
									
										
										
										
											2009-11-26 00:15:26 +00:00
										 |  |  | 	glVertex3fv(root);  | 
					
						
							|  |  |  | 	glVertex3fv(tip);  | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	root[0] = tw; root[1] = 0.0f; | 
					
						
							|  |  |  | 	root[2] = th; | 
					
						
							|  |  |  | 	glBegin(GL_LINES); | 
					
						
							|  |  |  | 	mul_m3_v3(tr,root); | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 	add_v3_v3(root, com); | 
					
						
							| 
									
										
										
										
											2009-11-26 00:15:26 +00:00
										 |  |  | 	glVertex3fv(root);  | 
					
						
							|  |  |  | 	glVertex3fv(tip);  | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	root[0] = -tw; root[1] = 0.0f; | 
					
						
							|  |  |  | 	root[2] = th; | 
					
						
							|  |  |  | 	glBegin(GL_LINES); | 
					
						
							|  |  |  | 	mul_m3_v3(tr,root); | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 	add_v3_v3(root, com); | 
					
						
							| 
									
										
										
										
											2009-11-26 00:15:26 +00:00
										 |  |  | 	glVertex3fv(root);  | 
					
						
							|  |  |  | 	glVertex3fv(tip);  | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-21 22:45:25 +00:00
										 |  |  | /*place to add drawers */ | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | static void tekenhandlesN(Nurb *nu, short sel, short hide_handles) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	BezTriple *bezt; | 
					
						
							|  |  |  | 	float *fp; | 
					
						
							|  |  |  | 	int a; | 
					
						
							| 
									
										
										
										
											2011-09-17 07:14:39 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 	if(nu->hide || hide_handles) return; | 
					
						
							| 
									
										
										
										
											2010-03-12 16:43:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	glBegin(GL_LINES);  | 
					
						
							| 
									
										
										
										
											2011-09-17 07:14:39 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 	if(nu->type == CU_BEZIER) { | 
					
						
							| 
									
										
										
										
											2011-09-17 07:14:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define TH_HANDLE_COL_TOT ((TH_HANDLE_SEL_FREE - TH_HANDLE_FREE) + 1)
 | 
					
						
							|  |  |  | 		/* use MIN2 when indexing to ensure newer files dont read outside the array */ | 
					
						
							|  |  |  | 		unsigned char handle_cols[TH_HANDLE_COL_TOT][3]; | 
					
						
							|  |  |  | 		const int basecol= sel ? TH_HANDLE_SEL_FREE : TH_HANDLE_FREE; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		for (a=0; a < TH_HANDLE_COL_TOT; a++) { | 
					
						
							|  |  |  | 			UI_GetThemeColor3ubv(basecol + a, handle_cols[a]); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		bezt= nu->bezt; | 
					
						
							|  |  |  | 		a= nu->pntsu; | 
					
						
							|  |  |  | 		while(a--) { | 
					
						
							|  |  |  | 			if(bezt->hide==0) { | 
					
						
							|  |  |  | 				if( (bezt->f2 & SELECT)==sel) { | 
					
						
							|  |  |  | 					fp= bezt->vec[0]; | 
					
						
							| 
									
										
										
										
											2010-03-12 16:43:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-17 07:14:39 +00:00
										 |  |  | 					glColor3ubv(handle_cols[MIN2(bezt->h1, TH_HANDLE_COL_TOT-1)]); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 					glVertex3fv(fp); | 
					
						
							|  |  |  | 					glVertex3fv(fp+3);  | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-17 07:14:39 +00:00
										 |  |  | 					glColor3ubv(handle_cols[MIN2(bezt->h2, TH_HANDLE_COL_TOT-1)]); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 					glVertex3fv(fp+3);  | 
					
						
							|  |  |  | 					glVertex3fv(fp+6);  | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				else if( (bezt->f1 & SELECT)==sel) { | 
					
						
							|  |  |  | 					fp= bezt->vec[0]; | 
					
						
							| 
									
										
										
										
											2010-03-12 16:43:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-17 07:14:39 +00:00
										 |  |  | 					glColor3ubv(handle_cols[MIN2(bezt->h1, TH_HANDLE_COL_TOT-1)]); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 					glVertex3fv(fp);  | 
					
						
							|  |  |  | 					glVertex3fv(fp+3);  | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				else if( (bezt->f3 & SELECT)==sel) { | 
					
						
							|  |  |  | 					fp= bezt->vec[1]; | 
					
						
							| 
									
										
										
										
											2010-03-12 16:43:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-17 07:14:39 +00:00
										 |  |  | 					glColor3ubv(handle_cols[MIN2(bezt->h2, TH_HANDLE_COL_TOT-1)]); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 					glVertex3fv(fp);  | 
					
						
							|  |  |  | 					glVertex3fv(fp+3);  | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			bezt++; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2011-09-17 07:14:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #undef TH_HANDLE_COL_TOT
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-12 16:43:04 +00:00
										 |  |  | static void tekenhandlesN_active(Nurb *nu) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	BezTriple *bezt; | 
					
						
							|  |  |  | 	float *fp; | 
					
						
							|  |  |  | 	int a; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(nu->hide) return; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	UI_ThemeColor(TH_ACTIVE_SPLINE); | 
					
						
							|  |  |  | 	glLineWidth(2); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glBegin(GL_LINES); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(nu->type == CU_BEZIER) { | 
					
						
							|  |  |  | 		bezt= nu->bezt; | 
					
						
							|  |  |  | 		a= nu->pntsu; | 
					
						
							|  |  |  | 		while(a--) { | 
					
						
							|  |  |  | 			if(bezt->hide==0) { | 
					
						
							|  |  |  | 				fp= bezt->vec[0]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				glVertex3fv(fp); | 
					
						
							|  |  |  | 				glVertex3fv(fp+3); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				glVertex3fv(fp+3); | 
					
						
							|  |  |  | 				glVertex3fv(fp+6); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			bezt++; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glColor3ub(0,0,0); | 
					
						
							|  |  |  | 	glLineWidth(1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-30 04:48:40 +00:00
										 |  |  | static void tekenvertsN(Nurb *nu, short sel, short hide_handles, void *lastsel) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	BezTriple *bezt; | 
					
						
							|  |  |  | 	BPoint *bp; | 
					
						
							|  |  |  | 	float size; | 
					
						
							| 
									
										
										
										
											2010-04-30 04:48:40 +00:00
										 |  |  | 	int a, color; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if(nu->hide) return; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-30 04:48:40 +00:00
										 |  |  | 	if(sel) color= TH_VERTEX_SELECT; | 
					
						
							|  |  |  | 	else color= TH_VERTEX; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	UI_ThemeColor(color); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	size= UI_GetThemeValuef(TH_VERTEX_SIZE); | 
					
						
							|  |  |  | 	glPointSize(size); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	bglBegin(GL_POINTS); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 	if(nu->type == CU_BEZIER) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		bezt= nu->bezt; | 
					
						
							|  |  |  | 		a= nu->pntsu; | 
					
						
							|  |  |  | 		while(a--) { | 
					
						
							|  |  |  | 			if(bezt->hide==0) { | 
					
						
							| 
									
										
										
										
											2010-07-09 07:53:06 +00:00
										 |  |  | 				if (sel == 1 && bezt == lastsel) { | 
					
						
							| 
									
										
										
										
											2010-04-30 04:48:40 +00:00
										 |  |  | 					UI_ThemeColor(TH_LASTSEL_POINT); | 
					
						
							|  |  |  | 					bglVertex3fv(bezt->vec[1]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					if (!hide_handles) { | 
					
						
							| 
									
										
										
										
											2010-07-09 07:53:06 +00:00
										 |  |  | 						if(bezt->f1 & SELECT) bglVertex3fv(bezt->vec[0]); | 
					
						
							|  |  |  | 						if(bezt->f3 & SELECT) bglVertex3fv(bezt->vec[2]); | 
					
						
							| 
									
										
										
										
											2010-04-30 04:48:40 +00:00
										 |  |  | 					} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					UI_ThemeColor(color); | 
					
						
							|  |  |  | 				} else if (hide_handles) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 					if((bezt->f2 & SELECT)==sel) bglVertex3fv(bezt->vec[1]); | 
					
						
							|  |  |  | 				} else { | 
					
						
							|  |  |  | 					if((bezt->f1 & SELECT)==sel) bglVertex3fv(bezt->vec[0]); | 
					
						
							|  |  |  | 					if((bezt->f2 & SELECT)==sel) bglVertex3fv(bezt->vec[1]); | 
					
						
							|  |  |  | 					if((bezt->f3 & SELECT)==sel) bglVertex3fv(bezt->vec[2]); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			bezt++; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		bp= nu->bp; | 
					
						
							|  |  |  | 		a= nu->pntsu*nu->pntsv; | 
					
						
							|  |  |  | 		while(a--) { | 
					
						
							|  |  |  | 			if(bp->hide==0) { | 
					
						
							| 
									
										
										
										
											2010-04-30 04:48:40 +00:00
										 |  |  | 				if (bp == lastsel) { | 
					
						
							|  |  |  | 					UI_ThemeColor(TH_LASTSEL_POINT); | 
					
						
							|  |  |  | 					bglVertex3fv(bp->vec); | 
					
						
							|  |  |  | 					UI_ThemeColor(color); | 
					
						
							|  |  |  | 				} else { | 
					
						
							|  |  |  | 					if((bp->f1 & SELECT)==sel) bglVertex3fv(bp->vec); | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			bp++; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	bglEnd(); | 
					
						
							|  |  |  | 	glPointSize(1.0); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-12 16:43:04 +00:00
										 |  |  | static void editnurb_draw_active_poly(Nurb *nu) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	BPoint *bp; | 
					
						
							|  |  |  | 	int a, b; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	UI_ThemeColor(TH_ACTIVE_SPLINE); | 
					
						
							|  |  |  | 	glLineWidth(2); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	bp= nu->bp; | 
					
						
							|  |  |  | 	for(b=0; b<nu->pntsv; b++) { | 
					
						
							|  |  |  | 		if(nu->flagu & 1) glBegin(GL_LINE_LOOP); | 
					
						
							|  |  |  | 		else glBegin(GL_LINE_STRIP); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		for(a=0; a<nu->pntsu; a++, bp++) { | 
					
						
							|  |  |  | 			glVertex3fv(bp->vec); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		glEnd(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glColor3ub(0,0,0); | 
					
						
							|  |  |  | 	glLineWidth(1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void editnurb_draw_active_nurbs(Nurb *nu) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	BPoint *bp, *bp1; | 
					
						
							|  |  |  | 	int a, b, ofs; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	UI_ThemeColor(TH_ACTIVE_SPLINE); | 
					
						
							|  |  |  | 	glLineWidth(2); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glBegin(GL_LINES); | 
					
						
							|  |  |  | 	bp= nu->bp; | 
					
						
							|  |  |  | 	for(b=0; b<nu->pntsv; b++) { | 
					
						
							|  |  |  | 		bp1= bp; | 
					
						
							|  |  |  | 		bp++; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		for(a=nu->pntsu-1; a>0; a--, bp++) { | 
					
						
							|  |  |  | 			if(bp->hide==0 && bp1->hide==0) { | 
					
						
							|  |  |  | 				glVertex3fv(bp->vec); | 
					
						
							|  |  |  | 				glVertex3fv(bp1->vec); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			bp1= bp; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(nu->pntsv > 1) {	/* surface */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		ofs= nu->pntsu; | 
					
						
							|  |  |  | 		for(b=0; b<nu->pntsu; b++) { | 
					
						
							|  |  |  | 			bp1= nu->bp+b; | 
					
						
							|  |  |  | 			bp= bp1+ofs; | 
					
						
							|  |  |  | 			for(a=nu->pntsv-1; a>0; a--, bp+=ofs) { | 
					
						
							|  |  |  | 				if(bp->hide==0 && bp1->hide==0) { | 
					
						
							|  |  |  | 					glVertex3fv(bp->vec); | 
					
						
							|  |  |  | 					glVertex3fv(bp1->vec); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				bp1= bp; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glColor3ub(0,0,0); | 
					
						
							|  |  |  | 	glLineWidth(1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | static void draw_editnurb(Object *ob, Nurb *nurb, int sel) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	Nurb *nu; | 
					
						
							|  |  |  | 	BPoint *bp, *bp1; | 
					
						
							| 
									
										
										
										
											2010-03-12 16:43:04 +00:00
										 |  |  | 	int a, b, ofs, index; | 
					
						
							|  |  |  | 	Curve *cu= (Curve*)ob->data; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	index= 0; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	nu= nurb; | 
					
						
							|  |  |  | 	while(nu) { | 
					
						
							|  |  |  | 		if(nu->hide==0) { | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 			switch(nu->type) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			case CU_POLY: | 
					
						
							| 
									
										
										
										
											2010-03-12 16:43:04 +00:00
										 |  |  | 				if (!sel && index== cu->actnu) { | 
					
						
							|  |  |  | 					/* we should draw active spline highlight below everything */ | 
					
						
							|  |  |  | 					editnurb_draw_active_poly(nu); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				UI_ThemeColor(TH_NURB_ULINE); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				bp= nu->bp; | 
					
						
							|  |  |  | 				for(b=0; b<nu->pntsv; b++) { | 
					
						
							|  |  |  | 					if(nu->flagu & 1) glBegin(GL_LINE_LOOP); | 
					
						
							|  |  |  | 					else glBegin(GL_LINE_STRIP); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					for(a=0; a<nu->pntsu; a++, bp++) { | 
					
						
							|  |  |  | 						glVertex3fv(bp->vec); | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					glEnd(); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			case CU_NURBS: | 
					
						
							| 
									
										
										
										
											2010-03-12 16:43:04 +00:00
										 |  |  | 				if (!sel && index== cu->actnu) { | 
					
						
							|  |  |  | 					/* we should draw active spline highlight below everything */ | 
					
						
							|  |  |  | 					editnurb_draw_active_nurbs(nu); | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				bp= nu->bp; | 
					
						
							|  |  |  | 				for(b=0; b<nu->pntsv; b++) { | 
					
						
							|  |  |  | 					bp1= bp; | 
					
						
							|  |  |  | 					bp++; | 
					
						
							|  |  |  | 					for(a=nu->pntsu-1; a>0; a--, bp++) { | 
					
						
							|  |  |  | 						if(bp->hide==0 && bp1->hide==0) { | 
					
						
							|  |  |  | 							if(sel) { | 
					
						
							|  |  |  | 								if( (bp->f1 & SELECT) && ( bp1->f1 & SELECT ) ) { | 
					
						
							| 
									
										
										
										
											2010-03-12 16:43:04 +00:00
										 |  |  | 									UI_ThemeColor(TH_NURB_SEL_ULINE); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 									glBegin(GL_LINE_STRIP); | 
					
						
							|  |  |  | 									glVertex3fv(bp->vec);  | 
					
						
							|  |  |  | 									glVertex3fv(bp1->vec); | 
					
						
							|  |  |  | 									glEnd(); | 
					
						
							|  |  |  | 								} | 
					
						
							|  |  |  | 							} | 
					
						
							|  |  |  | 							else { | 
					
						
							|  |  |  | 								if( (bp->f1 & SELECT) && ( bp1->f1 & SELECT) ); | 
					
						
							|  |  |  | 								else { | 
					
						
							| 
									
										
										
										
											2010-03-12 16:43:04 +00:00
										 |  |  | 									UI_ThemeColor(TH_NURB_ULINE); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 									glBegin(GL_LINE_STRIP); | 
					
						
							|  |  |  | 									glVertex3fv(bp->vec);  | 
					
						
							|  |  |  | 									glVertex3fv(bp1->vec); | 
					
						
							|  |  |  | 									glEnd(); | 
					
						
							|  |  |  | 								} | 
					
						
							|  |  |  | 							} | 
					
						
							|  |  |  | 						} | 
					
						
							|  |  |  | 						bp1= bp; | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				if(nu->pntsv > 1) {	/* surface */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					ofs= nu->pntsu; | 
					
						
							|  |  |  | 					for(b=0; b<nu->pntsu; b++) { | 
					
						
							|  |  |  | 						bp1= nu->bp+b; | 
					
						
							|  |  |  | 						bp= bp1+ofs; | 
					
						
							|  |  |  | 						for(a=nu->pntsv-1; a>0; a--, bp+=ofs) { | 
					
						
							|  |  |  | 							if(bp->hide==0 && bp1->hide==0) { | 
					
						
							|  |  |  | 								if(sel) { | 
					
						
							|  |  |  | 									if( (bp->f1 & SELECT) && ( bp1->f1 & SELECT) ) { | 
					
						
							| 
									
										
										
										
											2010-03-12 16:43:04 +00:00
										 |  |  | 										UI_ThemeColor(TH_NURB_SEL_VLINE); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 										glBegin(GL_LINE_STRIP); | 
					
						
							|  |  |  | 										glVertex3fv(bp->vec);  | 
					
						
							|  |  |  | 										glVertex3fv(bp1->vec); | 
					
						
							|  |  |  | 										glEnd(); | 
					
						
							|  |  |  | 									} | 
					
						
							|  |  |  | 								} | 
					
						
							|  |  |  | 								else { | 
					
						
							|  |  |  | 									if( (bp->f1 & SELECT) && ( bp1->f1 & SELECT) ); | 
					
						
							|  |  |  | 									else { | 
					
						
							| 
									
										
										
										
											2010-03-12 16:43:04 +00:00
										 |  |  | 										UI_ThemeColor(TH_NURB_VLINE); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 										glBegin(GL_LINE_STRIP); | 
					
						
							|  |  |  | 										glVertex3fv(bp->vec);  | 
					
						
							|  |  |  | 										glVertex3fv(bp1->vec); | 
					
						
							|  |  |  | 										glEnd(); | 
					
						
							|  |  |  | 									} | 
					
						
							|  |  |  | 								} | 
					
						
							|  |  |  | 							} | 
					
						
							|  |  |  | 							bp1= bp; | 
					
						
							|  |  |  | 						} | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2010-03-12 16:43:04 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		++index; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		nu= nu->next; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | static void drawnurb(Scene *scene, View3D *v3d, RegionView3D *rv3d, Base *base, Nurb *nurb, int dt) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-06-23 00:41:55 +00:00
										 |  |  | 	ToolSettings *ts= scene->toolsettings; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	Object *ob= base->object; | 
					
						
							|  |  |  | 	Curve *cu = ob->data; | 
					
						
							|  |  |  | 	Nurb *nu; | 
					
						
							|  |  |  | 	BevList *bl; | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 	short hide_handles = (cu->drawflag & CU_HIDE_HANDLES); | 
					
						
							| 
									
										
										
										
											2010-03-12 16:43:04 +00:00
										 |  |  | 	int index; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* DispList */ | 
					
						
							|  |  |  | 	UI_ThemeColor(TH_WIRE); | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | 	drawDispList(scene, v3d, rv3d, base, dt); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if(v3d->zbuf) glDisable(GL_DEPTH_TEST); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-03-12 16:43:04 +00:00
										 |  |  | 	/* first non-selected and active handles */ | 
					
						
							|  |  |  | 	index= 0; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	for(nu=nurb; nu; nu=nu->next) { | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 		if(nu->type == CU_BEZIER) { | 
					
						
							| 
									
										
										
										
											2010-03-12 16:43:04 +00:00
										 |  |  | 			if (index == cu->actnu && !hide_handles) | 
					
						
							|  |  |  | 				tekenhandlesN_active(nu); | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 			tekenhandlesN(nu, 0, hide_handles); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2010-03-12 16:43:04 +00:00
										 |  |  | 		++index; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	draw_editnurb(ob, nurb, 0); | 
					
						
							|  |  |  | 	draw_editnurb(ob, nurb, 1); | 
					
						
							|  |  |  | 	/* selected handles */ | 
					
						
							|  |  |  | 	for(nu=nurb; nu; nu=nu->next) { | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 		if(nu->type == CU_BEZIER && (cu->drawflag & CU_HIDE_HANDLES)==0) | 
					
						
							|  |  |  | 			tekenhandlesN(nu, 1, hide_handles); | 
					
						
							| 
									
										
										
										
											2010-04-30 04:48:40 +00:00
										 |  |  | 		tekenvertsN(nu, 0, hide_handles, NULL); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if(v3d->zbuf) glEnable(GL_DEPTH_TEST); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/*	direction vectors for 3d curve paths
 | 
					
						
							|  |  |  | 		when at its lowest, dont render normals */ | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 	if(cu->flag & CU_3D && ts->normalsize > 0.0015f && (cu->drawflag & CU_HIDE_NORMALS)==0) { | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		UI_ThemeColor(TH_WIRE); | 
					
						
							|  |  |  | 		for (bl=cu->bev.first,nu=nurb; nu && bl; bl=bl->next,nu=nu->next) { | 
					
						
							|  |  |  | 			BevPoint *bevp= (BevPoint *)(bl+1);		 | 
					
						
							|  |  |  | 			int nr= bl->nr; | 
					
						
							|  |  |  | 			int skip= nu->resolu/16; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			while (nr-->0) { /* accounts for empty bevel lists */ | 
					
						
							| 
									
										
										
										
											2011-11-07 01:38:32 +00:00
										 |  |  | 				const float fac= bevp->radius * ts->normalsize; | 
					
						
							| 
									
										
										
										
											2010-11-03 06:31:53 +00:00
										 |  |  | 				float vec_a[3]; // Offset perpendicular to the curve
 | 
					
						
							|  |  |  | 				float vec_b[3]; // Delta along the curve
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				vec_a[0]= fac; | 
					
						
							|  |  |  | 				vec_a[1]= 0.0f; | 
					
						
							|  |  |  | 				vec_a[2]= 0.0f; | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-03 06:31:53 +00:00
										 |  |  | 				vec_b[0]= -fac; | 
					
						
							|  |  |  | 				vec_b[1]= 0.0f; | 
					
						
							|  |  |  | 				vec_b[2]= 0.0f; | 
					
						
							|  |  |  | 				 | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 				mul_qt_v3(bevp->quat, vec_a); | 
					
						
							|  |  |  | 				mul_qt_v3(bevp->quat, vec_b); | 
					
						
							| 
									
										
										
										
											2010-04-21 12:27:48 +00:00
										 |  |  | 				add_v3_v3(vec_a, bevp->vec); | 
					
						
							|  |  |  | 				add_v3_v3(vec_b, bevp->vec); | 
					
						
							| 
									
										
										
										
											2011-11-07 01:38:32 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				madd_v3_v3fl(vec_a, bevp->dir, -fac); | 
					
						
							|  |  |  | 				madd_v3_v3fl(vec_b, bevp->dir, -fac); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				glBegin(GL_LINE_STRIP); | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 				glVertex3fv(vec_a); | 
					
						
							|  |  |  | 				glVertex3fv(bevp->vec); | 
					
						
							|  |  |  | 				glVertex3fv(vec_b); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				glEnd(); | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				bevp += skip+1; | 
					
						
							|  |  |  | 				nr -= skip; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(v3d->zbuf) glDisable(GL_DEPTH_TEST); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	for(nu=nurb; nu; nu=nu->next) { | 
					
						
							| 
									
										
										
										
											2010-04-30 04:48:40 +00:00
										 |  |  | 		tekenvertsN(nu, 1, hide_handles, cu->lastsel); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if(v3d->zbuf) glEnable(GL_DEPTH_TEST);  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* draw a sphere for use as an empty drawtype */ | 
					
						
							|  |  |  | static void draw_empty_sphere (float size) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2008-12-21 10:52:57 +00:00
										 |  |  | 	static GLuint displist=0; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (displist == 0) { | 
					
						
							|  |  |  | 		GLUquadricObj	*qobj; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2008-12-21 10:52:57 +00:00
										 |  |  | 		displist= glGenLists(1); | 
					
						
							| 
									
										
										
										
											2010-09-08 02:55:48 +00:00
										 |  |  | 		glNewList(displist, GL_COMPILE); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2008-12-21 10:52:57 +00:00
										 |  |  | 		glPushMatrix(); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		qobj	= gluNewQuadric();  | 
					
						
							|  |  |  | 		gluQuadricDrawStyle(qobj, GLU_SILHOUETTE);  | 
					
						
							|  |  |  | 		gluDisk(qobj, 0.0,  1, 16, 1); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		glRotatef(90, 0, 1, 0); | 
					
						
							|  |  |  | 		gluDisk(qobj, 0.0,  1, 16, 1); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		glRotatef(90, 1, 0, 0); | 
					
						
							|  |  |  | 		gluDisk(qobj, 0.0,  1, 16, 1); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		gluDeleteQuadric(qobj);   | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		glPopMatrix(); | 
					
						
							|  |  |  | 		glEndList(); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2008-12-21 10:52:57 +00:00
										 |  |  | 	glScalef(size, size, size); | 
					
						
							| 
									
										
										
										
											2010-09-08 02:55:48 +00:00
										 |  |  | 	glCallList(displist); | 
					
						
							|  |  |  | 	glScalef(1.0f/size, 1.0f/size, 1.0f/size); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* draw a cone for use as an empty drawtype */ | 
					
						
							|  |  |  | static void draw_empty_cone (float size) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	float cent=0; | 
					
						
							| 
									
										
										
										
											2009-12-26 20:23:13 +00:00
										 |  |  | 	float radius; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	GLUquadricObj *qobj = gluNewQuadric();  | 
					
						
							|  |  |  | 	gluQuadricDrawStyle(qobj, GLU_SILHOUETTE);  | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	glPushMatrix(); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	radius = size; | 
					
						
							|  |  |  | 	glTranslatef(cent,cent, cent); | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 	glScalef(radius, size * 2.0f, radius); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	glRotatef(-90., 1.0, 0.0, 0.0); | 
					
						
							|  |  |  | 	gluCylinder(qobj, 1.0, 0.0, 1.0, 8, 1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glPopMatrix(); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	gluDeleteQuadric(qobj);  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* draw points on curve speed handles */ | 
					
						
							| 
									
										
										
										
											2010-10-14 01:22:14 +00:00
										 |  |  | #if 0 // XXX old animation system stuff
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | static void curve_draw_speed(Scene *scene, Object *ob) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	Curve *cu= ob->data; | 
					
						
							|  |  |  | 	IpoCurve *icu; | 
					
						
							|  |  |  | 	BezTriple *bezt; | 
					
						
							|  |  |  | 	float loc[4], dir[3]; | 
					
						
							|  |  |  | 	int a; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if(cu->ipo==NULL) | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	icu= cu->ipo->curve.first;  | 
					
						
							|  |  |  | 	if(icu==NULL || icu->totvert<2) | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	glPointSize( UI_GetThemeValuef(TH_VERTEX_SIZE) ); | 
					
						
							|  |  |  | 	bglBegin(GL_POINTS); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for(a=0, bezt= icu->bezt; a<icu->totvert; a++, bezt++) { | 
					
						
							|  |  |  | 		if( where_on_path(ob, bezt->vec[1][1], loc, dir)) { | 
					
						
							|  |  |  | 			UI_ThemeColor((bezt->f2 & SELECT) && ob==OBACT?TH_VERTEX_SELECT:TH_VERTEX); | 
					
						
							|  |  |  | 			bglVertex3fv(loc); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glPointSize(1.0); | 
					
						
							|  |  |  | 	bglEnd(); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2010-10-14 01:22:14 +00:00
										 |  |  | #endif // XXX old animation system stuff
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-16 06:56:50 +00:00
										 |  |  | static void draw_textcurs(float textcurs[4][2]) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	cpack(0); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	set_inverted_drawing(1); | 
					
						
							|  |  |  | 	glBegin(GL_QUADS); | 
					
						
							| 
									
										
										
										
											2009-01-23 14:43:25 +00:00
										 |  |  | 	glVertex2fv(textcurs[0]); | 
					
						
							|  |  |  | 	glVertex2fv(textcurs[1]); | 
					
						
							|  |  |  | 	glVertex2fv(textcurs[2]); | 
					
						
							|  |  |  | 	glVertex2fv(textcurs[3]); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	glEnd(); | 
					
						
							|  |  |  | 	set_inverted_drawing(0); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-11 02:50:01 +00:00
										 |  |  | static void drawspiral(const float cent[3], float rad, float tmat[][4], int start) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	float vec[3], vx[3], vy[3]; | 
					
						
							| 
									
										
										
										
											2011-09-17 05:35:55 +00:00
										 |  |  | 	const float tot_inv= (1.0f / (float)CIRCLE_RESOL); | 
					
						
							| 
									
										
										
										
											2011-09-16 06:56:50 +00:00
										 |  |  | 	int a; | 
					
						
							|  |  |  | 	char inverse= FALSE; | 
					
						
							| 
									
										
										
										
											2011-09-22 18:42:16 +00:00
										 |  |  | 	float x, y, fac; | 
					
						
							| 
									
										
										
										
											2011-09-16 06:56:50 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	if (start < 0) { | 
					
						
							| 
									
										
										
										
											2011-09-16 06:56:50 +00:00
										 |  |  | 		inverse = TRUE; | 
					
						
							|  |  |  | 		start= -start; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 	mul_v3_v3fl(vx, tmat[0], rad); | 
					
						
							|  |  |  | 	mul_v3_v3fl(vy, tmat[1], rad); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-22 18:42:16 +00:00
										 |  |  | 	glBegin(GL_LINE_STRIP); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (inverse==0) { | 
					
						
							| 
									
										
										
										
											2011-09-22 18:42:16 +00:00
										 |  |  | 		copy_v3_v3(vec, cent); | 
					
						
							|  |  |  | 		glVertex3fv(vec); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-17 05:35:55 +00:00
										 |  |  | 		for(a=0; a<CIRCLE_RESOL; a++) { | 
					
						
							| 
									
										
										
										
											2011-09-22 18:42:16 +00:00
										 |  |  | 			if (a+start>=CIRCLE_RESOL) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				start=-a + 1; | 
					
						
							| 
									
										
										
										
											2011-09-22 18:42:16 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			fac= (float)a * tot_inv; | 
					
						
							|  |  |  | 			x= sinval[a+start] * fac; | 
					
						
							|  |  |  | 			y= cosval[a+start] * fac; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			vec[0]= cent[0] + (x * vx[0] + y * vy[0]); | 
					
						
							|  |  |  | 			vec[1]= cent[1] + (x * vx[1] + y * vy[1]); | 
					
						
							|  |  |  | 			vec[2]= cent[2] + (x * vx[2] + y * vy[2]); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			glVertex3fv(vec); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2011-09-22 18:42:16 +00:00
										 |  |  | 		fac= (float)(CIRCLE_RESOL-1) * tot_inv; | 
					
						
							|  |  |  | 		x= sinval[start] * fac; | 
					
						
							|  |  |  | 		y= cosval[start] * fac; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		vec[0]= cent[0] + (x * vx[0] + y * vy[0]); | 
					
						
							|  |  |  | 		vec[1]= cent[1] + (x * vx[1] + y * vy[1]); | 
					
						
							|  |  |  | 		vec[2]= cent[2] + (x * vx[2] + y * vy[2]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		glVertex3fv(vec); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-17 05:35:55 +00:00
										 |  |  | 		for(a=0; a<CIRCLE_RESOL; a++) { | 
					
						
							| 
									
										
										
										
											2011-09-22 18:42:16 +00:00
										 |  |  | 			if (a+start>=CIRCLE_RESOL) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				start=-a + 1; | 
					
						
							| 
									
										
										
										
											2011-09-22 18:42:16 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			fac= (float)(-a+(CIRCLE_RESOL-1)) * tot_inv; | 
					
						
							|  |  |  | 			x= sinval[a+start] * fac; | 
					
						
							|  |  |  | 			y= cosval[a+start] * fac; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			vec[0]= cent[0] + (x * vx[0] + y * vy[0]); | 
					
						
							|  |  |  | 			vec[1]= cent[1] + (x * vx[1] + y * vy[1]); | 
					
						
							|  |  |  | 			vec[2]= cent[2] + (x * vx[2] + y * vy[2]); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			glVertex3fv(vec); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-09-22 18:42:16 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* draws a circle on x-z plane given the scaling of the circle, assuming that 
 | 
					
						
							|  |  |  |  * all required matrices have been set (used for drawing empties) | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | static void drawcircle_size(float size) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-12-26 20:23:13 +00:00
										 |  |  | 	float x, y; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	short degrees; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glBegin(GL_LINE_LOOP); | 
					
						
							| 
									
										
										
										
											2009-12-26 20:23:13 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	/* coordinates are: cos(degrees*11.25)=x, sin(degrees*11.25)=y, 0.0f=z */ | 
					
						
							| 
									
										
										
										
											2011-09-17 05:35:55 +00:00
										 |  |  | 	for (degrees=0; degrees<CIRCLE_RESOL; degrees++) { | 
					
						
							|  |  |  | 		x= cosval[degrees]; | 
					
						
							|  |  |  | 		y= sinval[degrees]; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		glVertex3f(x*size, 0.0f, y*size); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* needs fixing if non-identity matrice used */ | 
					
						
							| 
									
										
										
										
											2011-09-11 02:50:01 +00:00
										 |  |  | static void drawtube(const float vec[3], float radius, float height, float tmat[][4]) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	float cur[3]; | 
					
						
							|  |  |  | 	drawcircball(GL_LINE_LOOP, vec, radius, tmat); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 	copy_v3_v3(cur,vec); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	cur[2]+=height; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	drawcircball(GL_LINE_LOOP, cur, radius, tmat); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glBegin(GL_LINES); | 
					
						
							|  |  |  | 		glVertex3f(vec[0]+radius,vec[1],vec[2]); | 
					
						
							|  |  |  | 		glVertex3f(cur[0]+radius,cur[1],cur[2]); | 
					
						
							|  |  |  | 		glVertex3f(vec[0]-radius,vec[1],vec[2]); | 
					
						
							|  |  |  | 		glVertex3f(cur[0]-radius,cur[1],cur[2]); | 
					
						
							|  |  |  | 		glVertex3f(vec[0],vec[1]+radius,vec[2]); | 
					
						
							|  |  |  | 		glVertex3f(cur[0],cur[1]+radius,cur[2]); | 
					
						
							|  |  |  | 		glVertex3f(vec[0],vec[1]-radius,vec[2]); | 
					
						
							|  |  |  | 		glVertex3f(cur[0],cur[1]-radius,cur[2]); | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | /* needs fixing if non-identity matrice used */ | 
					
						
							| 
									
										
										
										
											2011-09-11 02:50:01 +00:00
										 |  |  | static void drawcone(const float vec[3], float radius, float height, float tmat[][4]) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	float cur[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 	copy_v3_v3(cur,vec); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	cur[2]+=height; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	drawcircball(GL_LINE_LOOP, cur, radius, tmat); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glBegin(GL_LINES); | 
					
						
							|  |  |  | 		glVertex3f(vec[0],vec[1],vec[2]); | 
					
						
							|  |  |  | 		glVertex3f(cur[0]+radius,cur[1],cur[2]); | 
					
						
							|  |  |  | 		glVertex3f(vec[0],vec[1],vec[2]); | 
					
						
							|  |  |  | 		glVertex3f(cur[0]-radius,cur[1],cur[2]); | 
					
						
							|  |  |  | 		glVertex3f(vec[0],vec[1],vec[2]); | 
					
						
							|  |  |  | 		glVertex3f(cur[0],cur[1]+radius,cur[2]); | 
					
						
							|  |  |  | 		glVertex3f(vec[0],vec[1],vec[2]); | 
					
						
							|  |  |  | 		glVertex3f(cur[0],cur[1]-radius,cur[2]); | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | /* return 1 if nothing was drawn */ | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | static int drawmball(Scene *scene, View3D *v3d, RegionView3D *rv3d, Base *base, int dt) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	Object *ob= base->object; | 
					
						
							|  |  |  | 	MetaBall *mb; | 
					
						
							|  |  |  | 	MetaElem *ml; | 
					
						
							| 
									
										
										
										
											2010-02-01 15:32:55 +00:00
										 |  |  | 	float imat[4][4]; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	int code= 1; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	mb= ob->data; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-02 19:10:35 +00:00
										 |  |  | 	if(mb->editelems) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		UI_ThemeColor(TH_WIRE); | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | 		if((G.f & G_PICKSEL)==0 ) drawDispList(scene, v3d, rv3d, base, dt); | 
					
						
							| 
									
										
										
										
											2009-01-02 19:10:35 +00:00
										 |  |  | 		ml= mb->editelems->first; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		if((base->flag & OB_FROMDUPLI)==0)  | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | 			drawDispList(scene, v3d, rv3d, base, dt); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		ml= mb->elems.first; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(ml==NULL) return 1; | 
					
						
							| 
									
										
										
										
											2010-07-06 17:10:02 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if(v3d->flag2 & V3D_RENDER_OVERRIDE) return 0; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* in case solid draw, reset wire colors */ | 
					
						
							| 
									
										
										
										
											2009-08-03 14:40:10 +00:00
										 |  |  | 	if(ob->flag & SELECT) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		if(ob==OBACT) UI_ThemeColor(TH_ACTIVE); | 
					
						
							|  |  |  | 		else UI_ThemeColor(TH_SELECT); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else UI_ThemeColor(TH_WIRE); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-01 15:32:55 +00:00
										 |  |  | 	invert_m4_m4(imat, rv3d->viewmatob); | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 	normalize_v3(imat[0]); | 
					
						
							|  |  |  | 	normalize_v3(imat[1]); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	while(ml) { | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 		/* draw radius */ | 
					
						
							| 
									
										
										
										
											2009-01-02 19:10:35 +00:00
										 |  |  | 		if(mb->editelems) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			if((ml->flag & SELECT) && (ml->flag & MB_SCALE_RAD)) cpack(0xA0A0F0); | 
					
						
							|  |  |  | 			else cpack(0x3030A0); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if(G.f & G_PICKSEL) { | 
					
						
							|  |  |  | 				ml->selcol1= code; | 
					
						
							|  |  |  | 				glLoadName(code++); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		drawcircball(GL_LINE_LOOP, &(ml->x), ml->rad, imat); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* draw stiffness */ | 
					
						
							| 
									
										
										
										
											2009-01-02 19:10:35 +00:00
										 |  |  | 		if(mb->editelems) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			if((ml->flag & SELECT) && !(ml->flag & MB_SCALE_RAD)) cpack(0xA0F0A0); | 
					
						
							|  |  |  | 			else cpack(0x30A030); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if(G.f & G_PICKSEL) { | 
					
						
							|  |  |  | 				ml->selcol2= code; | 
					
						
							|  |  |  | 				glLoadName(code++); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 			drawcircball(GL_LINE_LOOP, &(ml->x), ml->rad*atanf(ml->s)/(float)M_PI_2, imat); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		ml= ml->next; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-01 15:32:55 +00:00
										 |  |  | static void draw_forcefield(Scene *scene, Object *ob, RegionView3D *rv3d) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	PartDeflect *pd= ob->pd; | 
					
						
							|  |  |  | 	float imat[4][4], tmat[4][4]; | 
					
						
							|  |  |  | 	float vec[3]= {0.0, 0.0, 0.0}; | 
					
						
							|  |  |  | 	int curcol; | 
					
						
							|  |  |  | 	float size; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-02 19:10:35 +00:00
										 |  |  | 	/* XXX why? */ | 
					
						
							|  |  |  | 	if(ob!=scene->obedit && (ob->flag & SELECT)) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		if(ob==OBACT) curcol= TH_ACTIVE; | 
					
						
							|  |  |  | 		else curcol= TH_SELECT; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else curcol= TH_WIRE; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* scale size of circle etc with the empty drawsize */ | 
					
						
							|  |  |  | 	if (ob->type == OB_EMPTY) size = ob->empty_drawsize; | 
					
						
							|  |  |  | 	else size = 1.0; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* calculus here, is reused in PFIELD_FORCE */ | 
					
						
							| 
									
										
										
										
											2010-02-01 15:32:55 +00:00
										 |  |  | 	invert_m4_m4(imat, rv3d->viewmatob); | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | //	normalize_v3(imat[0]);		// we don't do this because field doesnt scale either... apart from wind!
 | 
					
						
							|  |  |  | //	normalize_v3(imat[1]);
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	if (pd->forcefield == PFIELD_WIND) { | 
					
						
							|  |  |  | 		float force_val; | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 		unit_m4(tmat); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		UI_ThemeColorBlend(curcol, TH_BACK, 0.5); | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
											  
											
												2.5: Blender "Animato" - New Animation System 
Finally, here is the basic (functional) prototype of the new animation system which will allow for the infamous "everything is animatable", and which also addresses several of the more serious shortcomings of the old system. Unfortunately, this will break old animation files (especially right now, as I haven't written the version patching code yet), however, this is for the future.
Highlights of the new system:
* Scrapped IPO-Curves/IPO/(Action+Constraint-Channels)/Action system, and replaced it with F-Curve/Action. 
- F-Curves (animators from other packages will feel at home with this name) replace IPO-Curves. 
- The 'new' Actions, act as the containers for F-Curves, so that they can be reused. They are therefore more akin to the old 'IPO' blocks, except they do not have the blocktype restriction, so you can store materials/texture/geometry F-Curves in the same Action as Object transforms, etc.
* F-Curves use RNA-paths for Data Access, hence allowing "every" (where sensible/editable that is) user-accessible setting from RNA to be animated.
* Drivers are no longer mixed with Animation Data, so rigs will not be that easily broken and several dependency problems can be eliminated. (NOTE: drivers haven't been hooked up yet, but the code is in place)
* F-Curve modifier system allows useful 'large-scale' manipulation of F-Curve values, including (I've only included implemented ones here): envelope deform (similar to lattices to allow broad-scale reshaping of curves), curve generator (polynomial or py-expression), cycles (replacing the old cyclic extrapolation modes, giving more control over this). (NOTE: currently this cannot be tested, as there's not access to them, but the code is all in place)
* NLA system with 'tracks' (i.e. layers), and multiple strips per track. (NOTE: NLA system is not yet functional, as it's only partially coded still) 
There are more nice things that I will be preparing some nice docs for soon, but for now, check for more details:
http://lists.blender.org/pipermail/bf-taskforce25/2009-January/000260.html
So, what currently works:
* I've implemented two basic operators for the 3D-view only to Insert and Delete Keyframes. These are tempolary ones only that will be replaced in due course with 'proper' code.
* Object Loc/Rot/Scale can be keyframed. Also, the colour of the 'active' material (Note: this should really be for nth material instead, but that doesn't work yet in RNA) can also be keyframed into the same datablock.
* Standard animation refresh (i.e. animation resulting from NLA and Action evaluation) is now done completely separate from drivers before anything else is done after a frame change. Drivers are handled after this in a separate pass, as dictated by depsgraph flags, etc.
Notes:
* Drivers haven't been hooked up yet
* Only objects and data directly linked to objects can be animated.
* Depsgraph will need further tweaks. Currently, I've only made sure that it will update some things in the most basic cases (i.e. frame change).
* Animation Editors are currently broken (in terms of editing stuff). This will be my next target (priority to get Dopesheet working first, then F-Curve editor - i.e. old IPO Editor)
* I've had to put in large chunks of XXX sandboxing for old animation system code all around the place. This will be cleaned up in due course, as some places need special review.
In particular, the particles and sequencer code have far too many manual calls to calculate + flush animation info, which is really bad (this is a 'please explain yourselves' call to Physics coders!).
											
										 
											2009-01-17 03:12:50 +00:00
										 |  |  | 		//if (has_ipo_code(ob->ipo, OB_PD_FSTR))
 | 
					
						
							|  |  |  | 		//	force_val = IPO_GetFloatValue(ob->ipo, OB_PD_FSTR, scene->r.cfra);
 | 
					
						
							|  |  |  | 		//else 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			force_val = pd->f_strength; | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 		force_val *= 0.1f; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		drawcircball(GL_LINE_LOOP, vec, size, tmat); | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 		vec[2]= 0.5f * force_val; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		drawcircball(GL_LINE_LOOP, vec, size, tmat); | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 		vec[2]= 1.0f * force_val; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		drawcircball(GL_LINE_LOOP, vec, size, tmat); | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 		vec[2]= 1.5f * force_val; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		drawcircball(GL_LINE_LOOP, vec, size, tmat); | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 		vec[2] = 0.0f; /* reset vec for max dist circle */ | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else if (pd->forcefield == PFIELD_FORCE) { | 
					
						
							|  |  |  | 		float ffall_val; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												2.5: Blender "Animato" - New Animation System 
Finally, here is the basic (functional) prototype of the new animation system which will allow for the infamous "everything is animatable", and which also addresses several of the more serious shortcomings of the old system. Unfortunately, this will break old animation files (especially right now, as I haven't written the version patching code yet), however, this is for the future.
Highlights of the new system:
* Scrapped IPO-Curves/IPO/(Action+Constraint-Channels)/Action system, and replaced it with F-Curve/Action. 
- F-Curves (animators from other packages will feel at home with this name) replace IPO-Curves. 
- The 'new' Actions, act as the containers for F-Curves, so that they can be reused. They are therefore more akin to the old 'IPO' blocks, except they do not have the blocktype restriction, so you can store materials/texture/geometry F-Curves in the same Action as Object transforms, etc.
* F-Curves use RNA-paths for Data Access, hence allowing "every" (where sensible/editable that is) user-accessible setting from RNA to be animated.
* Drivers are no longer mixed with Animation Data, so rigs will not be that easily broken and several dependency problems can be eliminated. (NOTE: drivers haven't been hooked up yet, but the code is in place)
* F-Curve modifier system allows useful 'large-scale' manipulation of F-Curve values, including (I've only included implemented ones here): envelope deform (similar to lattices to allow broad-scale reshaping of curves), curve generator (polynomial or py-expression), cycles (replacing the old cyclic extrapolation modes, giving more control over this). (NOTE: currently this cannot be tested, as there's not access to them, but the code is all in place)
* NLA system with 'tracks' (i.e. layers), and multiple strips per track. (NOTE: NLA system is not yet functional, as it's only partially coded still) 
There are more nice things that I will be preparing some nice docs for soon, but for now, check for more details:
http://lists.blender.org/pipermail/bf-taskforce25/2009-January/000260.html
So, what currently works:
* I've implemented two basic operators for the 3D-view only to Insert and Delete Keyframes. These are tempolary ones only that will be replaced in due course with 'proper' code.
* Object Loc/Rot/Scale can be keyframed. Also, the colour of the 'active' material (Note: this should really be for nth material instead, but that doesn't work yet in RNA) can also be keyframed into the same datablock.
* Standard animation refresh (i.e. animation resulting from NLA and Action evaluation) is now done completely separate from drivers before anything else is done after a frame change. Drivers are handled after this in a separate pass, as dictated by depsgraph flags, etc.
Notes:
* Drivers haven't been hooked up yet
* Only objects and data directly linked to objects can be animated.
* Depsgraph will need further tweaks. Currently, I've only made sure that it will update some things in the most basic cases (i.e. frame change).
* Animation Editors are currently broken (in terms of editing stuff). This will be my next target (priority to get Dopesheet working first, then F-Curve editor - i.e. old IPO Editor)
* I've had to put in large chunks of XXX sandboxing for old animation system code all around the place. This will be cleaned up in due course, as some places need special review.
In particular, the particles and sequencer code have far too many manual calls to calculate + flush animation info, which is really bad (this is a 'please explain yourselves' call to Physics coders!).
											
										 
											2009-01-17 03:12:50 +00:00
										 |  |  | 		//if (has_ipo_code(ob->ipo, OB_PD_FFALL)) 
 | 
					
						
							|  |  |  | 		//	ffall_val = IPO_GetFloatValue(ob->ipo, OB_PD_FFALL, scene->r.cfra);
 | 
					
						
							|  |  |  | 		//else 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			ffall_val = pd->f_power; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		UI_ThemeColorBlend(curcol, TH_BACK, 0.5); | 
					
						
							|  |  |  | 		drawcircball(GL_LINE_LOOP, vec, size, imat); | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 		UI_ThemeColorBlend(curcol, TH_BACK, 0.9f - 0.4f / powf(1.5f, ffall_val)); | 
					
						
							|  |  |  | 		drawcircball(GL_LINE_LOOP, vec, size * 1.5f, imat); | 
					
						
							|  |  |  | 		UI_ThemeColorBlend(curcol, TH_BACK, 0.9f - 0.4f / powf(2.0f, ffall_val)); | 
					
						
							|  |  |  | 		drawcircball(GL_LINE_LOOP, vec, size*2.0f, imat); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else if (pd->forcefield == PFIELD_VORTEX) { | 
					
						
							| 
									
										
										
										
											2011-03-19 05:06:06 +00:00
										 |  |  | 		float /*ffall_val,*/ force_val; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 		unit_m4(tmat); | 
					
						
							| 
									
										
											  
											
												2.5: Blender "Animato" - New Animation System 
Finally, here is the basic (functional) prototype of the new animation system which will allow for the infamous "everything is animatable", and which also addresses several of the more serious shortcomings of the old system. Unfortunately, this will break old animation files (especially right now, as I haven't written the version patching code yet), however, this is for the future.
Highlights of the new system:
* Scrapped IPO-Curves/IPO/(Action+Constraint-Channels)/Action system, and replaced it with F-Curve/Action. 
- F-Curves (animators from other packages will feel at home with this name) replace IPO-Curves. 
- The 'new' Actions, act as the containers for F-Curves, so that they can be reused. They are therefore more akin to the old 'IPO' blocks, except they do not have the blocktype restriction, so you can store materials/texture/geometry F-Curves in the same Action as Object transforms, etc.
* F-Curves use RNA-paths for Data Access, hence allowing "every" (where sensible/editable that is) user-accessible setting from RNA to be animated.
* Drivers are no longer mixed with Animation Data, so rigs will not be that easily broken and several dependency problems can be eliminated. (NOTE: drivers haven't been hooked up yet, but the code is in place)
* F-Curve modifier system allows useful 'large-scale' manipulation of F-Curve values, including (I've only included implemented ones here): envelope deform (similar to lattices to allow broad-scale reshaping of curves), curve generator (polynomial or py-expression), cycles (replacing the old cyclic extrapolation modes, giving more control over this). (NOTE: currently this cannot be tested, as there's not access to them, but the code is all in place)
* NLA system with 'tracks' (i.e. layers), and multiple strips per track. (NOTE: NLA system is not yet functional, as it's only partially coded still) 
There are more nice things that I will be preparing some nice docs for soon, but for now, check for more details:
http://lists.blender.org/pipermail/bf-taskforce25/2009-January/000260.html
So, what currently works:
* I've implemented two basic operators for the 3D-view only to Insert and Delete Keyframes. These are tempolary ones only that will be replaced in due course with 'proper' code.
* Object Loc/Rot/Scale can be keyframed. Also, the colour of the 'active' material (Note: this should really be for nth material instead, but that doesn't work yet in RNA) can also be keyframed into the same datablock.
* Standard animation refresh (i.e. animation resulting from NLA and Action evaluation) is now done completely separate from drivers before anything else is done after a frame change. Drivers are handled after this in a separate pass, as dictated by depsgraph flags, etc.
Notes:
* Drivers haven't been hooked up yet
* Only objects and data directly linked to objects can be animated.
* Depsgraph will need further tweaks. Currently, I've only made sure that it will update some things in the most basic cases (i.e. frame change).
* Animation Editors are currently broken (in terms of editing stuff). This will be my next target (priority to get Dopesheet working first, then F-Curve editor - i.e. old IPO Editor)
* I've had to put in large chunks of XXX sandboxing for old animation system code all around the place. This will be cleaned up in due course, as some places need special review.
In particular, the particles and sequencer code have far too many manual calls to calculate + flush animation info, which is really bad (this is a 'please explain yourselves' call to Physics coders!).
											
										 
											2009-01-17 03:12:50 +00:00
										 |  |  | 		//if (has_ipo_code(ob->ipo, OB_PD_FFALL)) 
 | 
					
						
							|  |  |  | 		//	ffall_val = IPO_GetFloatValue(ob->ipo, OB_PD_FFALL, scene->r.cfra);
 | 
					
						
							|  |  |  | 		//else 
 | 
					
						
							| 
									
										
										
										
											2011-03-19 05:06:06 +00:00
										 |  |  | 		//	ffall_val = pd->f_power;
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												2.5: Blender "Animato" - New Animation System 
Finally, here is the basic (functional) prototype of the new animation system which will allow for the infamous "everything is animatable", and which also addresses several of the more serious shortcomings of the old system. Unfortunately, this will break old animation files (especially right now, as I haven't written the version patching code yet), however, this is for the future.
Highlights of the new system:
* Scrapped IPO-Curves/IPO/(Action+Constraint-Channels)/Action system, and replaced it with F-Curve/Action. 
- F-Curves (animators from other packages will feel at home with this name) replace IPO-Curves. 
- The 'new' Actions, act as the containers for F-Curves, so that they can be reused. They are therefore more akin to the old 'IPO' blocks, except they do not have the blocktype restriction, so you can store materials/texture/geometry F-Curves in the same Action as Object transforms, etc.
* F-Curves use RNA-paths for Data Access, hence allowing "every" (where sensible/editable that is) user-accessible setting from RNA to be animated.
* Drivers are no longer mixed with Animation Data, so rigs will not be that easily broken and several dependency problems can be eliminated. (NOTE: drivers haven't been hooked up yet, but the code is in place)
* F-Curve modifier system allows useful 'large-scale' manipulation of F-Curve values, including (I've only included implemented ones here): envelope deform (similar to lattices to allow broad-scale reshaping of curves), curve generator (polynomial or py-expression), cycles (replacing the old cyclic extrapolation modes, giving more control over this). (NOTE: currently this cannot be tested, as there's not access to them, but the code is all in place)
* NLA system with 'tracks' (i.e. layers), and multiple strips per track. (NOTE: NLA system is not yet functional, as it's only partially coded still) 
There are more nice things that I will be preparing some nice docs for soon, but for now, check for more details:
http://lists.blender.org/pipermail/bf-taskforce25/2009-January/000260.html
So, what currently works:
* I've implemented two basic operators for the 3D-view only to Insert and Delete Keyframes. These are tempolary ones only that will be replaced in due course with 'proper' code.
* Object Loc/Rot/Scale can be keyframed. Also, the colour of the 'active' material (Note: this should really be for nth material instead, but that doesn't work yet in RNA) can also be keyframed into the same datablock.
* Standard animation refresh (i.e. animation resulting from NLA and Action evaluation) is now done completely separate from drivers before anything else is done after a frame change. Drivers are handled after this in a separate pass, as dictated by depsgraph flags, etc.
Notes:
* Drivers haven't been hooked up yet
* Only objects and data directly linked to objects can be animated.
* Depsgraph will need further tweaks. Currently, I've only made sure that it will update some things in the most basic cases (i.e. frame change).
* Animation Editors are currently broken (in terms of editing stuff). This will be my next target (priority to get Dopesheet working first, then F-Curve editor - i.e. old IPO Editor)
* I've had to put in large chunks of XXX sandboxing for old animation system code all around the place. This will be cleaned up in due course, as some places need special review.
In particular, the particles and sequencer code have far too many manual calls to calculate + flush animation info, which is really bad (this is a 'please explain yourselves' call to Physics coders!).
											
										 
											2009-01-17 03:12:50 +00:00
										 |  |  | 		//if (has_ipo_code(ob->ipo, OB_PD_FSTR))
 | 
					
						
							|  |  |  | 		//	force_val = IPO_GetFloatValue(ob->ipo, OB_PD_FSTR, scene->r.cfra);
 | 
					
						
							|  |  |  | 		//else 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			force_val = pd->f_strength; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 		UI_ThemeColorBlend(curcol, TH_BACK, 0.7f); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		if (force_val < 0) { | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 			drawspiral(vec, size, tmat, 1); | 
					
						
							|  |  |  | 			drawspiral(vec, size, tmat, 16); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 			drawspiral(vec, size, tmat, -1); | 
					
						
							|  |  |  | 			drawspiral(vec, size, tmat, -16); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else if (pd->forcefield == PFIELD_GUIDE && ob->type==OB_CURVE) { | 
					
						
							|  |  |  | 		Curve *cu= ob->data; | 
					
						
							|  |  |  | 		if((cu->flag & CU_PATH) && cu->path && cu->path->data) { | 
					
						
							|  |  |  | 			float mindist, guidevec1[4], guidevec2[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												2.5: Blender "Animato" - New Animation System 
Finally, here is the basic (functional) prototype of the new animation system which will allow for the infamous "everything is animatable", and which also addresses several of the more serious shortcomings of the old system. Unfortunately, this will break old animation files (especially right now, as I haven't written the version patching code yet), however, this is for the future.
Highlights of the new system:
* Scrapped IPO-Curves/IPO/(Action+Constraint-Channels)/Action system, and replaced it with F-Curve/Action. 
- F-Curves (animators from other packages will feel at home with this name) replace IPO-Curves. 
- The 'new' Actions, act as the containers for F-Curves, so that they can be reused. They are therefore more akin to the old 'IPO' blocks, except they do not have the blocktype restriction, so you can store materials/texture/geometry F-Curves in the same Action as Object transforms, etc.
* F-Curves use RNA-paths for Data Access, hence allowing "every" (where sensible/editable that is) user-accessible setting from RNA to be animated.
* Drivers are no longer mixed with Animation Data, so rigs will not be that easily broken and several dependency problems can be eliminated. (NOTE: drivers haven't been hooked up yet, but the code is in place)
* F-Curve modifier system allows useful 'large-scale' manipulation of F-Curve values, including (I've only included implemented ones here): envelope deform (similar to lattices to allow broad-scale reshaping of curves), curve generator (polynomial or py-expression), cycles (replacing the old cyclic extrapolation modes, giving more control over this). (NOTE: currently this cannot be tested, as there's not access to them, but the code is all in place)
* NLA system with 'tracks' (i.e. layers), and multiple strips per track. (NOTE: NLA system is not yet functional, as it's only partially coded still) 
There are more nice things that I will be preparing some nice docs for soon, but for now, check for more details:
http://lists.blender.org/pipermail/bf-taskforce25/2009-January/000260.html
So, what currently works:
* I've implemented two basic operators for the 3D-view only to Insert and Delete Keyframes. These are tempolary ones only that will be replaced in due course with 'proper' code.
* Object Loc/Rot/Scale can be keyframed. Also, the colour of the 'active' material (Note: this should really be for nth material instead, but that doesn't work yet in RNA) can also be keyframed into the same datablock.
* Standard animation refresh (i.e. animation resulting from NLA and Action evaluation) is now done completely separate from drivers before anything else is done after a frame change. Drivers are handled after this in a separate pass, as dictated by depsgraph flags, etc.
Notes:
* Drivers haven't been hooked up yet
* Only objects and data directly linked to objects can be animated.
* Depsgraph will need further tweaks. Currently, I've only made sure that it will update some things in the most basic cases (i.e. frame change).
* Animation Editors are currently broken (in terms of editing stuff). This will be my next target (priority to get Dopesheet working first, then F-Curve editor - i.e. old IPO Editor)
* I've had to put in large chunks of XXX sandboxing for old animation system code all around the place. This will be cleaned up in due course, as some places need special review.
In particular, the particles and sequencer code have far too many manual calls to calculate + flush animation info, which is really bad (this is a 'please explain yourselves' call to Physics coders!).
											
										 
											2009-01-17 03:12:50 +00:00
										 |  |  | 			//if (has_ipo_code(ob->ipo, OB_PD_FSTR))
 | 
					
						
							|  |  |  | 			//	mindist = IPO_GetFloatValue(ob->ipo, OB_PD_FSTR, scene->r.cfra);
 | 
					
						
							|  |  |  | 			//else 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				mindist = pd->f_strength; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/*path end*/ | 
					
						
							|  |  |  | 			setlinestyle(3); | 
					
						
							| 
									
										
										
										
											2010-04-21 11:59:47 +00:00
										 |  |  | 			where_on_path(ob, 1.0f, guidevec1, guidevec2, NULL, NULL, NULL); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			UI_ThemeColorBlend(curcol, TH_BACK, 0.5); | 
					
						
							|  |  |  | 			drawcircball(GL_LINE_LOOP, guidevec1, mindist, imat); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/*path beginning*/ | 
					
						
							|  |  |  | 			setlinestyle(0); | 
					
						
							| 
									
										
										
										
											2010-04-21 11:59:47 +00:00
										 |  |  | 			where_on_path(ob, 0.0f, guidevec1, guidevec2, NULL, NULL, NULL); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			UI_ThemeColorBlend(curcol, TH_BACK, 0.5); | 
					
						
							|  |  |  | 			drawcircball(GL_LINE_LOOP, guidevec1, mindist, imat); | 
					
						
							|  |  |  | 			 | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 			copy_v3_v3(vec, guidevec1);	/* max center */ | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	setlinestyle(3); | 
					
						
							|  |  |  | 	UI_ThemeColorBlend(curcol, TH_BACK, 0.5); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(pd->falloff==PFIELD_FALL_SPHERE){ | 
					
						
							|  |  |  | 		/* as last, guide curve alters it */ | 
					
						
							|  |  |  | 		if(pd->flag & PFIELD_USEMAX) | 
					
						
							|  |  |  | 			drawcircball(GL_LINE_LOOP, vec, pd->maxdist, imat);		 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if(pd->flag & PFIELD_USEMIN) | 
					
						
							|  |  |  | 			drawcircball(GL_LINE_LOOP, vec, pd->mindist, imat); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else if(pd->falloff==PFIELD_FALL_TUBE){ | 
					
						
							|  |  |  | 		float radius,distance; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 		unit_m4(tmat); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		vec[0]=vec[1]=0.0f; | 
					
						
							|  |  |  | 		radius=(pd->flag&PFIELD_USEMAXR)?pd->maxrad:1.0f; | 
					
						
							|  |  |  | 		distance=(pd->flag&PFIELD_USEMAX)?pd->maxdist:0.0f; | 
					
						
							|  |  |  | 		vec[2]=distance; | 
					
						
							|  |  |  | 		distance=(pd->flag&PFIELD_POSZ)?-distance:-2.0f*distance; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if(pd->flag & (PFIELD_USEMAX|PFIELD_USEMAXR)) | 
					
						
							|  |  |  | 			drawtube(vec,radius,distance,tmat); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		radius=(pd->flag&PFIELD_USEMINR)?pd->minrad:1.0f; | 
					
						
							|  |  |  | 		distance=(pd->flag&PFIELD_USEMIN)?pd->mindist:0.0f; | 
					
						
							|  |  |  | 		vec[2]=distance; | 
					
						
							|  |  |  | 		distance=(pd->flag&PFIELD_POSZ)?-distance:-2.0f*distance; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if(pd->flag & (PFIELD_USEMIN|PFIELD_USEMINR)) | 
					
						
							|  |  |  | 			drawtube(vec,radius,distance,tmat); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else if(pd->falloff==PFIELD_FALL_CONE){ | 
					
						
							|  |  |  | 		float radius,distance; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 		unit_m4(tmat); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-17 09:43:51 +00:00
										 |  |  | 		radius= DEG2RADF((pd->flag&PFIELD_USEMAXR) ? pd->maxrad : 1.0f); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		distance=(pd->flag&PFIELD_USEMAX)?pd->maxdist:0.0f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if(pd->flag & (PFIELD_USEMAX|PFIELD_USEMAXR)){ | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 			drawcone(vec, distance * sinf(radius),distance * cosf(radius), tmat); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			if((pd->flag & PFIELD_POSZ)==0) | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 				drawcone(vec, distance * sinf(radius),-distance * cosf(radius),tmat); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-17 09:43:51 +00:00
										 |  |  | 		radius= DEG2RADF((pd->flag&PFIELD_USEMINR) ? pd->minrad : 1.0f); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		distance=(pd->flag&PFIELD_USEMIN)?pd->mindist:0.0f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if(pd->flag & (PFIELD_USEMIN|PFIELD_USEMINR)){ | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 			drawcone(vec,distance*sinf(radius),distance*cosf(radius),tmat); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			if((pd->flag & PFIELD_POSZ)==0) | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 				drawcone(vec, distance * sinf(radius), -distance * cosf(radius), tmat); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	setlinestyle(0); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void draw_box(float vec[8][3]) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	glBegin(GL_LINE_STRIP); | 
					
						
							|  |  |  | 	glVertex3fv(vec[0]); glVertex3fv(vec[1]);glVertex3fv(vec[2]); glVertex3fv(vec[3]); | 
					
						
							|  |  |  | 	glVertex3fv(vec[0]); glVertex3fv(vec[4]);glVertex3fv(vec[5]); glVertex3fv(vec[6]); | 
					
						
							|  |  |  | 	glVertex3fv(vec[7]); glVertex3fv(vec[4]); | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glBegin(GL_LINES); | 
					
						
							|  |  |  | 	glVertex3fv(vec[1]); glVertex3fv(vec[5]); | 
					
						
							|  |  |  | 	glVertex3fv(vec[2]); glVertex3fv(vec[6]); | 
					
						
							|  |  |  | 	glVertex3fv(vec[3]); glVertex3fv(vec[7]); | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* uses boundbox, function used by Ketsji */ | 
					
						
							| 
									
										
										
										
											2011-02-17 12:05:09 +00:00
										 |  |  | #if 0
 | 
					
						
							| 
									
										
										
										
											2011-09-11 02:50:01 +00:00
										 |  |  | static void get_local_bounds(Object *ob, float center[3], float size[3]) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	BoundBox *bb= object_get_boundbox(ob); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if(bb==NULL) { | 
					
						
							| 
									
										
										
										
											2010-07-31 10:58:10 +00:00
										 |  |  | 		zero_v3(center); | 
					
						
							|  |  |  | 		copy_v3_v3(size, ob->size); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		size[0]= 0.5*fabs(bb->vec[0][0] - bb->vec[4][0]); | 
					
						
							|  |  |  | 		size[1]= 0.5*fabs(bb->vec[0][1] - bb->vec[2][1]); | 
					
						
							|  |  |  | 		size[2]= 0.5*fabs(bb->vec[0][2] - bb->vec[1][2]); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		center[0]= (bb->vec[0][0] + bb->vec[4][0])/2.0; | 
					
						
							|  |  |  | 		center[1]= (bb->vec[0][1] + bb->vec[2][1])/2.0; | 
					
						
							|  |  |  | 		center[2]= (bb->vec[0][2] + bb->vec[1][2])/2.0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2011-02-17 12:05:09 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-05 02:30:25 +00:00
										 |  |  | static void draw_bb_quadric(BoundBox *bb, char type) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	float size[3], cent[3]; | 
					
						
							|  |  |  | 	GLUquadricObj *qobj = gluNewQuadric();  | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	gluQuadricDrawStyle(qobj, GLU_SILHOUETTE);  | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 	size[0]= 0.5f*fabsf(bb->vec[0][0] - bb->vec[4][0]); | 
					
						
							|  |  |  | 	size[1]= 0.5f*fabsf(bb->vec[0][1] - bb->vec[2][1]); | 
					
						
							|  |  |  | 	size[2]= 0.5f*fabsf(bb->vec[0][2] - bb->vec[1][2]); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 	cent[0]= 0.5f*(bb->vec[0][0] + bb->vec[4][0]); | 
					
						
							|  |  |  | 	cent[1]= 0.5f*(bb->vec[0][1] + bb->vec[2][1]); | 
					
						
							|  |  |  | 	cent[2]= 0.5f*(bb->vec[0][2] + bb->vec[1][2]); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	glPushMatrix(); | 
					
						
							|  |  |  | 	if(type==OB_BOUND_SPHERE) { | 
					
						
							|  |  |  | 		glTranslatef(cent[0], cent[1], cent[2]); | 
					
						
							|  |  |  | 		glScalef(size[0], size[1], size[2]); | 
					
						
							|  |  |  | 		gluSphere(qobj, 1.0, 8, 5); | 
					
						
							|  |  |  | 	}	 | 
					
						
							|  |  |  | 	else if(type==OB_BOUND_CYLINDER) { | 
					
						
							|  |  |  | 		float radius = size[0] > size[1] ? size[0] : size[1]; | 
					
						
							|  |  |  | 		glTranslatef(cent[0], cent[1], cent[2]-size[2]); | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 		glScalef(radius, radius, 2.0f * size[2]); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		gluCylinder(qobj, 1.0, 1.0, 1.0, 8, 1); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else if(type==OB_BOUND_CONE) { | 
					
						
							|  |  |  | 		float radius = size[0] > size[1] ? size[0] : size[1]; | 
					
						
							| 
									
										
										
										
											2011-11-28 16:25:42 +00:00
										 |  |  | 		glTranslatef(cent[0], cent[1], cent[2]-size[2]); | 
					
						
							|  |  |  | 		glScalef(radius, radius, 2.0f * size[2]); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		gluCylinder(qobj, 1.0, 0.0, 1.0, 8, 1); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	glPopMatrix(); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	gluDeleteQuadric(qobj);  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-05 02:30:25 +00:00
										 |  |  | static void draw_bounding_volume(Scene *scene, Object *ob, char type) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 	BoundBox *bb= NULL; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	if(ob->type==OB_MESH) { | 
					
						
							|  |  |  | 		bb= mesh_get_bb(ob); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else if ELEM3(ob->type, OB_CURVE, OB_SURF, OB_FONT) { | 
					
						
							| 
									
										
										
										
											2010-03-05 16:47:52 +00:00
										 |  |  | 		bb= ob->bb ? ob->bb : ( (Curve *)ob->data )->bb; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else if(ob->type==OB_MBALL) { | 
					
						
							| 
									
										
										
										
											2010-11-18 04:26:50 +00:00
										 |  |  | 		if(is_basis_mball(ob)) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			bb= ob->bb; | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 			if(bb==NULL) { | 
					
						
							| 
									
										
										
										
											2010-11-18 04:26:50 +00:00
										 |  |  | 				makeDispListMBall(scene, ob); | 
					
						
							|  |  |  | 				bb= ob->bb; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		drawcube(); | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 	if(bb==NULL) return; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2011-11-04 15:53:34 +00:00
										 |  |  | 	if(type==OB_BOUND_BOX) draw_box(bb->vec); | 
					
						
							|  |  |  | 	else draw_bb_quadric(bb, type); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void drawtexspace(Object *ob) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	float vec[8][3], loc[3], size[3]; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if(ob->type==OB_MESH) { | 
					
						
							|  |  |  | 		mesh_get_texspace(ob->data, loc, NULL, size); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else if ELEM3(ob->type, OB_CURVE, OB_SURF, OB_FONT) { | 
					
						
							|  |  |  | 		Curve *cu= ob->data; | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 		copy_v3_v3(size, cu->size); | 
					
						
							|  |  |  | 		copy_v3_v3(loc, cu->loc); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else if(ob->type==OB_MBALL) { | 
					
						
							|  |  |  | 		MetaBall *mb= ob->data; | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 		copy_v3_v3(size, mb->size); | 
					
						
							|  |  |  | 		copy_v3_v3(loc, mb->loc); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else return; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	vec[0][0]=vec[1][0]=vec[2][0]=vec[3][0]= loc[0]-size[0]; | 
					
						
							|  |  |  | 	vec[4][0]=vec[5][0]=vec[6][0]=vec[7][0]= loc[0]+size[0]; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	vec[0][1]=vec[1][1]=vec[4][1]=vec[5][1]= loc[1]-size[1]; | 
					
						
							|  |  |  | 	vec[2][1]=vec[3][1]=vec[6][1]=vec[7][1]= loc[1]+size[1]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	vec[0][2]=vec[3][2]=vec[4][2]=vec[7][2]= loc[2]-size[2]; | 
					
						
							|  |  |  | 	vec[1][2]=vec[2][2]=vec[5][2]=vec[6][2]= loc[2]+size[2]; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	setlinestyle(2); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	draw_box(vec); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	setlinestyle(0); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* draws wire outline */ | 
					
						
							| 
									
										
										
										
											2010-11-21 14:05:18 +00:00
										 |  |  | static void drawObjectSelect(Scene *scene, View3D *v3d, ARegion *ar, Base *base) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 	RegionView3D *rv3d= ar->regiondata; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	Object *ob= base->object; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	glLineWidth(2.0); | 
					
						
							|  |  |  | 	glDepthMask(0); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if(ELEM3(ob->type, OB_FONT,OB_CURVE, OB_SURF)) { | 
					
						
							|  |  |  | 		Curve *cu = ob->data; | 
					
						
							| 
									
										
										
										
											2010-03-05 16:47:52 +00:00
										 |  |  | 		DerivedMesh *dm = ob->derivedFinal; | 
					
						
							| 
									
										
										
										
											2010-04-04 11:07:42 +00:00
										 |  |  | 		int hasfaces= 0; | 
					
						
							| 
									
										
										
										
											2010-03-05 16:47:52 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-04 11:07:42 +00:00
										 |  |  | 		if (dm) { | 
					
						
							| 
									
										
										
										
											2011-11-29 13:01:51 +00:00
										 |  |  | 			hasfaces= dm->getNumTessFaces(dm); | 
					
						
							| 
									
										
										
										
											2010-04-04 11:07:42 +00:00
										 |  |  | 		} else { | 
					
						
							| 
									
										
										
										
											2011-01-05 10:40:38 +00:00
										 |  |  | 			hasfaces= displist_has_faces(&ob->disp); | 
					
						
							| 
									
										
										
										
											2010-04-04 11:07:42 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-21 08:56:37 +00:00
										 |  |  | 		if (hasfaces && ED_view3d_boundbox_clip(rv3d, ob->obmat, ob->bb ? ob->bb : cu->bb)) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			draw_index_wire= 0; | 
					
						
							| 
									
										
										
										
											2010-03-05 16:47:52 +00:00
										 |  |  | 			if (dm) { | 
					
						
							|  |  |  | 				draw_mesh_object_outline(v3d, ob, dm); | 
					
						
							|  |  |  | 			} else { | 
					
						
							| 
									
										
										
										
											2011-01-05 10:40:38 +00:00
										 |  |  | 				drawDispListwire(&ob->disp); | 
					
						
							| 
									
										
										
										
											2010-03-05 16:47:52 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			draw_index_wire= 1; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} else if (ob->type==OB_MBALL) { | 
					
						
							| 
									
										
										
										
											2010-11-18 04:26:50 +00:00
										 |  |  | 		if(is_basis_mball(ob)) { | 
					
						
							|  |  |  | 			if((base->flag & OB_FROMDUPLI)==0) | 
					
						
							|  |  |  | 				drawDispListwire(&ob->disp); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else if(ob->type==OB_ARMATURE) { | 
					
						
							| 
									
										
										
										
											2011-08-16 13:46:51 +00:00
										 |  |  | 		if(!(ob->mode & OB_MODE_POSE && base == scene->basact)) | 
					
						
							| 
									
										
										
										
											2011-06-17 03:17:07 +00:00
										 |  |  | 			draw_armature(scene, v3d, ar, base, OB_WIRE, FALSE, TRUE); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glLineWidth(1.0); | 
					
						
							|  |  |  | 	glDepthMask(1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | static void drawWireExtra(Scene *scene, RegionView3D *rv3d, Object *ob)  | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-01-02 19:10:35 +00:00
										 |  |  | 	if(ob!=scene->obedit && (ob->flag & SELECT)) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		if(ob==OBACT) { | 
					
						
							|  |  |  | 			if(ob->flag & OB_FROMGROUP) UI_ThemeColor(TH_GROUP_ACTIVE); | 
					
						
							|  |  |  | 			else UI_ThemeColor(TH_ACTIVE); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else if(ob->flag & OB_FROMGROUP) | 
					
						
							|  |  |  | 			UI_ThemeColorShade(TH_GROUP_ACTIVE, -16); | 
					
						
							|  |  |  | 		else | 
					
						
							|  |  |  | 			UI_ThemeColor(TH_SELECT); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		if(ob->flag & OB_FROMGROUP) | 
					
						
							|  |  |  | 			UI_ThemeColor(TH_GROUP); | 
					
						
							|  |  |  | 		else { | 
					
						
							|  |  |  | 			if(ob->dtx & OB_DRAWWIRE) { | 
					
						
							|  |  |  | 				glColor3ub(80,80,80); | 
					
						
							|  |  |  | 			} else { | 
					
						
							|  |  |  | 				UI_ThemeColor(TH_WIRE); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | 	bglPolygonOffset(rv3d->dist, 1.0); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	glDepthMask(0);	// disable write in zbuffer, selected edge wires show better
 | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (ELEM3(ob->type, OB_FONT, OB_CURVE, OB_SURF)) { | 
					
						
							|  |  |  | 		Curve *cu = ob->data; | 
					
						
							| 
									
										
										
										
											2011-05-21 08:56:37 +00:00
										 |  |  | 		if (ED_view3d_boundbox_clip(rv3d, ob->obmat, ob->bb ? ob->bb : cu->bb)) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			if (ob->type==OB_CURVE) | 
					
						
							|  |  |  | 				draw_index_wire= 0; | 
					
						
							| 
									
										
										
										
											2010-03-05 16:47:52 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			if (ob->derivedFinal) { | 
					
						
							|  |  |  | 				drawCurveDMWired(ob); | 
					
						
							|  |  |  | 			} else { | 
					
						
							| 
									
										
										
										
											2011-01-05 10:40:38 +00:00
										 |  |  | 				drawDispListwire(&ob->disp); | 
					
						
							| 
									
										
										
										
											2010-03-05 16:47:52 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			if (ob->type==OB_CURVE) | 
					
						
							|  |  |  | 				draw_index_wire= 1; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} else if (ob->type==OB_MBALL) { | 
					
						
							| 
									
										
										
										
											2010-11-18 04:26:50 +00:00
										 |  |  | 		if(is_basis_mball(ob)) { | 
					
						
							|  |  |  | 			drawDispListwire(&ob->disp); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glDepthMask(1); | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | 	bglPolygonOffset(rv3d->dist, 0.0); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* should be called in view space */ | 
					
						
							|  |  |  | static void draw_hooks(Object *ob) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	ModifierData *md; | 
					
						
							|  |  |  | 	float vec[3]; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	for (md=ob->modifiers.first; md; md=md->next) { | 
					
						
							|  |  |  | 		if (md->type==eModifierType_Hook) { | 
					
						
							|  |  |  | 			HookModifierData *hmd = (HookModifierData*) md; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 			mul_v3_m4v3(vec, ob->obmat, hmd->cent); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			if(hmd->object) { | 
					
						
							|  |  |  | 				setlinestyle(3); | 
					
						
							|  |  |  | 				glBegin(GL_LINES); | 
					
						
							|  |  |  | 				glVertex3fv(hmd->object->obmat[3]); | 
					
						
							|  |  |  | 				glVertex3fv(vec); | 
					
						
							|  |  |  | 				glEnd(); | 
					
						
							|  |  |  | 				setlinestyle(0); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			glPointSize(3.0); | 
					
						
							|  |  |  | 			bglBegin(GL_POINTS); | 
					
						
							|  |  |  | 			bglVertex3fv(vec); | 
					
						
							|  |  |  | 			bglEnd(); | 
					
						
							|  |  |  | 			glPointSize(1.0); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-13 14:16:36 +00:00
										 |  |  | static void drawRBpivot(bRigidBodyJointConstraint *data) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int axis; | 
					
						
							|  |  |  | 	float mat[4][4]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 	/* color */ | 
					
						
							|  |  |  | 	float curcol[4]; | 
					
						
							|  |  |  | 	unsigned char tcol[4]; | 
					
						
							|  |  |  | 	glGetFloatv(GL_CURRENT_COLOR, curcol); | 
					
						
							| 
									
										
										
										
											2012-01-19 09:09:00 +00:00
										 |  |  | 	rgb_float_to_uchar(tcol, curcol); | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 	tcol[3]= 255; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-03 06:31:53 +00:00
										 |  |  | 	eul_to_mat4(mat,&data->axX); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	glLineWidth (4.0f); | 
					
						
							|  |  |  | 	setlinestyle(2); | 
					
						
							|  |  |  | 	for (axis=0; axis<3; axis++) { | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 		float dir[3] = {0,0,0}; | 
					
						
							| 
									
										
										
										
											2010-11-03 06:31:53 +00:00
										 |  |  | 		float v[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		copy_v3_v3(v, &data->pivX); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 		dir[axis] = 1.f; | 
					
						
							|  |  |  | 		glBegin(GL_LINES); | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 		mul_m4_v3(mat,dir); | 
					
						
							| 
									
										
										
										
											2010-07-31 10:58:10 +00:00
										 |  |  | 		add_v3_v3(v, dir); | 
					
						
							| 
									
										
										
										
											2010-11-03 06:31:53 +00:00
										 |  |  | 		glVertex3fv(&data->pivX); | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 		glVertex3fv(v);			 | 
					
						
							|  |  |  | 		glEnd(); | 
					
						
							|  |  |  | 		if (axis==0) | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 			view3d_cached_text_draw_add(v, "px", 0, V3D_CACHE_TEXT_ASCII, tcol); | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 		else if (axis==1) | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 			view3d_cached_text_draw_add(v, "py", 0, V3D_CACHE_TEXT_ASCII, tcol); | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 		else | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 			view3d_cached_text_draw_add(v, "pz", 0, V3D_CACHE_TEXT_ASCII, tcol); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	glLineWidth (1.0f); | 
					
						
							|  |  |  | 	setlinestyle(0); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* flag can be DRAW_PICKING	and/or DRAW_CONSTCOLOR, DRAW_SCENESET */ | 
					
						
							| 
									
										
										
										
											2008-12-19 14:14:43 +00:00
										 |  |  | void draw_object(Scene *scene, ARegion *ar, View3D *v3d, Base *base, int flag) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	static int warning_recursive= 0; | 
					
						
							| 
									
										
										
										
											2009-07-30 15:00:26 +00:00
										 |  |  | 	ModifierData *md = NULL; | 
					
						
							| 
									
										
										
										
											2011-12-03 20:26:53 +00:00
										 |  |  | 	Object *ob= base->object; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	Curve *cu; | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | 	RegionView3D *rv3d= ar->regiondata; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	float vec1[3], vec2[3]; | 
					
						
							|  |  |  | 	unsigned int col=0; | 
					
						
							| 
									
										
											  
											
												2.5: Blender "Animato" - New Animation System 
Finally, here is the basic (functional) prototype of the new animation system which will allow for the infamous "everything is animatable", and which also addresses several of the more serious shortcomings of the old system. Unfortunately, this will break old animation files (especially right now, as I haven't written the version patching code yet), however, this is for the future.
Highlights of the new system:
* Scrapped IPO-Curves/IPO/(Action+Constraint-Channels)/Action system, and replaced it with F-Curve/Action. 
- F-Curves (animators from other packages will feel at home with this name) replace IPO-Curves. 
- The 'new' Actions, act as the containers for F-Curves, so that they can be reused. They are therefore more akin to the old 'IPO' blocks, except they do not have the blocktype restriction, so you can store materials/texture/geometry F-Curves in the same Action as Object transforms, etc.
* F-Curves use RNA-paths for Data Access, hence allowing "every" (where sensible/editable that is) user-accessible setting from RNA to be animated.
* Drivers are no longer mixed with Animation Data, so rigs will not be that easily broken and several dependency problems can be eliminated. (NOTE: drivers haven't been hooked up yet, but the code is in place)
* F-Curve modifier system allows useful 'large-scale' manipulation of F-Curve values, including (I've only included implemented ones here): envelope deform (similar to lattices to allow broad-scale reshaping of curves), curve generator (polynomial or py-expression), cycles (replacing the old cyclic extrapolation modes, giving more control over this). (NOTE: currently this cannot be tested, as there's not access to them, but the code is all in place)
* NLA system with 'tracks' (i.e. layers), and multiple strips per track. (NOTE: NLA system is not yet functional, as it's only partially coded still) 
There are more nice things that I will be preparing some nice docs for soon, but for now, check for more details:
http://lists.blender.org/pipermail/bf-taskforce25/2009-January/000260.html
So, what currently works:
* I've implemented two basic operators for the 3D-view only to Insert and Delete Keyframes. These are tempolary ones only that will be replaced in due course with 'proper' code.
* Object Loc/Rot/Scale can be keyframed. Also, the colour of the 'active' material (Note: this should really be for nth material instead, but that doesn't work yet in RNA) can also be keyframed into the same datablock.
* Standard animation refresh (i.e. animation resulting from NLA and Action evaluation) is now done completely separate from drivers before anything else is done after a frame change. Drivers are handled after this in a separate pass, as dictated by depsgraph flags, etc.
Notes:
* Drivers haven't been hooked up yet
* Only objects and data directly linked to objects can be animated.
* Depsgraph will need further tweaks. Currently, I've only made sure that it will update some things in the most basic cases (i.e. frame change).
* Animation Editors are currently broken (in terms of editing stuff). This will be my next target (priority to get Dopesheet working first, then F-Curve editor - i.e. old IPO Editor)
* I've had to put in large chunks of XXX sandboxing for old animation system code all around the place. This will be cleaned up in due course, as some places need special review.
In particular, the particles and sequencer code have far too many manual calls to calculate + flush animation info, which is really bad (this is a 'please explain yourselves' call to Physics coders!).
											
										 
											2009-01-17 03:12:50 +00:00
										 |  |  | 	int /*sel, drawtype,*/ colindex= 0; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	int i, selstart, selend, empty_object=0; | 
					
						
							|  |  |  | 	short dt, dtx, zbufoff= 0; | 
					
						
							| 
									
										
										
										
											2011-12-05 22:19:30 +00:00
										 |  |  | 	const short is_obact= (ob == OBACT); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* only once set now, will be removed too, should become a global standard */ | 
					
						
							|  |  |  | 	glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-02 19:10:35 +00:00
										 |  |  | 	if (ob!=scene->obedit) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		if (ob->restrictflag & OB_RESTRICT_VIEW)  | 
					
						
							|  |  |  | 			return; | 
					
						
							| 
									
										
										
										
											2010-07-04 17:22:24 +00:00
										 |  |  | 		if ((ob->restrictflag & OB_RESTRICT_RENDER) &&  | 
					
						
							|  |  |  | 			(v3d->flag2 & V3D_RENDER_OVERRIDE)) | 
					
						
							|  |  |  | 			return; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-22 10:52:37 +00:00
										 |  |  | 	/* XXX particles are not safe for simultaneous threaded render */ | 
					
						
							|  |  |  | 	if(G.rendering && ob->particlesystem.first) | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	/* xray delay? */ | 
					
						
							|  |  |  | 	if((flag & DRAW_PICKING)==0 && (base->flag & OB_FROMDUPLI)==0) { | 
					
						
							|  |  |  | 		/* don't do xray in particle mode, need the z-buffer */ | 
					
						
							| 
									
										
										
										
											2009-08-16 02:35:44 +00:00
										 |  |  | 		if(!(ob->mode & OB_MODE_PARTICLE_EDIT)) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			/* xray and transp are set when it is drawing the 2nd/3rd pass */ | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 			if(!v3d->xray && !v3d->transp && (ob->dtx & OB_DRAWXRAY) && !(ob->dtx & OB_DRAWTRANSP)) { | 
					
						
							| 
									
										
										
										
											2010-09-07 05:47:34 +00:00
										 |  |  | 				add_view3d_after(&v3d->afterdraw_xray, base, flag); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				return; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 	/* no return after this point, otherwise leaks */ | 
					
						
							|  |  |  | 	view3d_cached_text_draw_begin(); | 
					
						
							| 
									
										
										
										
											2010-01-19 11:31:49 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	/* patch? children objects with a timeoffs change the parents. How to solve! */ | 
					
						
							| 
									
										
										
										
											2009-01-04 14:14:06 +00:00
										 |  |  | 	/* if( ((int)ob->ctime) != F_(scene->r.cfra)) where_is_object(scene, ob); */ | 
					
						
							| 
									
										
										
										
											2009-08-21 11:04:33 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-01-19 11:31:49 +00:00
										 |  |  | 	/* draw motion paths (in view space) */ | 
					
						
							| 
									
										
										
										
											2011-08-10 15:53:46 +00:00
										 |  |  | 	if (ob->mpath && (v3d->flag2 & V3D_RENDER_OVERRIDE)==0) { | 
					
						
							| 
									
										
										
										
											2010-01-19 11:31:49 +00:00
										 |  |  | 		bAnimVizSettings *avs= &ob->avs; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* setup drawing environment for paths */ | 
					
						
							| 
									
										
										
										
											2010-10-14 01:22:14 +00:00
										 |  |  | 		draw_motion_paths_init(v3d, ar); | 
					
						
							| 
									
										
										
										
											2010-01-19 11:31:49 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		/* draw motion path for object */ | 
					
						
							| 
									
										
										
										
											2010-10-14 01:22:14 +00:00
										 |  |  | 		draw_motion_path_instance(scene, ob, NULL, avs, ob->mpath); | 
					
						
							| 
									
										
										
										
											2010-01-19 11:31:49 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		/* cleanup after drawing */ | 
					
						
							| 
									
										
										
										
											2010-10-14 01:22:14 +00:00
										 |  |  | 		draw_motion_paths_cleanup(v3d); | 
					
						
							| 
									
										
										
										
											2010-01-19 11:31:49 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 	/* multiply view with object matrix.
 | 
					
						
							|  |  |  | 	 * local viewmat and persmat, to calculate projections */ | 
					
						
							| 
									
										
										
										
											2011-06-09 03:56:32 +00:00
										 |  |  | 	ED_view3d_init_mats_rv3d_gl(ob, rv3d); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* which wire color */ | 
					
						
							|  |  |  | 	if((flag & DRAW_CONSTCOLOR) == 0) { | 
					
						
							| 
									
										
										
										
											2011-09-12 01:43:20 +00:00
										 |  |  | 		/* confusing logic here, there are 2 methods of setting the color
 | 
					
						
							|  |  |  | 		 * 'colortab[colindex]' and 'theme_id', colindex overrides theme_id. | 
					
						
							|  |  |  | 		 * | 
					
						
							|  |  |  | 		 * note: no theme yet for 'colindex' */ | 
					
						
							|  |  |  | 		int theme_id= TH_WIRE; | 
					
						
							|  |  |  | 		int theme_shade= 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | 		project_short(ar, ob->obmat[3], &base->sx); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-12 01:43:20 +00:00
										 |  |  | 		if(		(scene->obedit == NULL) && | 
					
						
							|  |  |  | 		        (G.moving & G_TRANSFORM_OBJ) && | 
					
						
							|  |  |  | 		        (base->flag & (SELECT+BA_WAS_SEL))) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			theme_id= TH_TRANSFORM; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2011-09-12 01:43:20 +00:00
										 |  |  | 			/* Sets the 'colindex' */ | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			if(ob->id.lib) { | 
					
						
							| 
									
										
										
										
											2011-09-12 01:43:20 +00:00
										 |  |  | 				colindex= (base->flag & (SELECT+BA_WAS_SEL)) ? 4 : 3; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else if(warning_recursive==1) { | 
					
						
							|  |  |  | 				if(base->flag & (SELECT+BA_WAS_SEL)) { | 
					
						
							| 
									
										
										
										
											2011-09-12 01:43:20 +00:00
										 |  |  | 					colindex= (scene->basact==base) ? 8 : 7; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2011-09-12 01:43:20 +00:00
										 |  |  | 				else { | 
					
						
							|  |  |  | 					colindex = 6; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2011-09-12 01:43:20 +00:00
										 |  |  | 			/* Sets the 'theme_id' or fallback to wire */ | 
					
						
							|  |  |  | 			else { | 
					
						
							|  |  |  | 				if(ob->flag & OB_FROMGROUP) { | 
					
						
							|  |  |  | 					if(base->flag & (SELECT+BA_WAS_SEL)) { | 
					
						
							|  |  |  | 						/* uses darker active color for non-active + selected*/ | 
					
						
							|  |  |  | 						theme_id= TH_GROUP_ACTIVE; | 
					
						
							| 
									
										
										
										
											2011-11-06 05:46:45 +00:00
										 |  |  | 						 | 
					
						
							| 
									
										
										
										
											2011-09-12 01:43:20 +00:00
										 |  |  | 						if(scene->basact != base) { | 
					
						
							|  |  |  | 							theme_shade= -16; | 
					
						
							|  |  |  | 						} | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 					else { | 
					
						
							|  |  |  | 						theme_id= TH_GROUP; | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				else { | 
					
						
							|  |  |  | 					if(base->flag & (SELECT+BA_WAS_SEL)) { | 
					
						
							|  |  |  | 						theme_id= scene->basact == base ? TH_ACTIVE : TH_SELECT; | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 					else { | 
					
						
							|  |  |  | 						if(ob->type==OB_LAMP) theme_id= TH_LAMP; | 
					
						
							|  |  |  | 						else if(ob->type==OB_SPEAKER) theme_id= TH_SPEAKER; | 
					
						
							|  |  |  | 						/* fallback to TH_WIRE */ | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-12 01:43:20 +00:00
										 |  |  | 		/* finally set the color */ | 
					
						
							|  |  |  | 		if(colindex == 0) { | 
					
						
							|  |  |  | 			if(theme_shade == 0) UI_ThemeColor(theme_id); | 
					
						
							|  |  |  | 			else                 UI_ThemeColorShade(theme_id, theme_shade); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			col= colortab[colindex]; | 
					
						
							|  |  |  | 			cpack(col); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* maximum drawtype */ | 
					
						
							| 
									
										
										
										
											2011-11-02 18:20:53 +00:00
										 |  |  | 	dt= v3d->drawtype; | 
					
						
							|  |  |  | 	if(dt==OB_RENDER) dt= OB_SOLID; | 
					
						
							|  |  |  | 	dt= MIN2(dt, ob->dt); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	if(v3d->zbuf==0 && dt>OB_WIRE) dt= OB_WIRE; | 
					
						
							|  |  |  | 	dtx= 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* faceselect exception: also draw solid when dt==wire, except in editmode */ | 
					
						
							| 
									
										
										
										
											2011-12-03 20:26:53 +00:00
										 |  |  | 	if (is_obact && (ob->mode & (OB_MODE_VERTEX_PAINT|OB_MODE_WEIGHT_PAINT|OB_MODE_TEXTURE_PAINT))) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		if(ob->type==OB_MESH) { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 			if(ob->mode & OB_MODE_EDIT); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2010-01-14 12:51:17 +00:00
										 |  |  | 				if(dt<OB_SOLID) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 					zbufoff= 1; | 
					
						
							| 
									
										
										
										
											2010-01-14 12:51:17 +00:00
										 |  |  | 					dt= OB_SOLID; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				else { | 
					
						
							| 
									
										
										
										
											2011-11-02 18:20:53 +00:00
										 |  |  | 					dt= OB_PAINT; | 
					
						
							| 
									
										
										
										
											2010-01-14 12:51:17 +00:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				glEnable(GL_DEPTH_TEST); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							|  |  |  | 			if(dt<OB_SOLID) { | 
					
						
							|  |  |  | 				dt= OB_SOLID; | 
					
						
							|  |  |  | 				glEnable(GL_DEPTH_TEST); | 
					
						
							|  |  |  | 				zbufoff= 1; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* draw-extra supported for boundbox drawmode too */ | 
					
						
							|  |  |  | 	if(dt>=OB_BOUNDBOX ) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		dtx= ob->dtx; | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 		if(ob->mode & OB_MODE_EDIT) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			// the only 2 extra drawtypes alowed in editmode
 | 
					
						
							|  |  |  | 			dtx= dtx & (OB_DRAWWIRE|OB_TEXSPACE); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-08 12:16:35 +00:00
										 |  |  | 	/* bad exception, solve this! otherwise outline shows too late */ | 
					
						
							|  |  |  | 	if(ELEM3(ob->type, OB_CURVE, OB_SURF, OB_FONT)) { | 
					
						
							|  |  |  | 		/* still needed for curves hidden in other layers. depgraph doesnt handle that yet */ | 
					
						
							| 
									
										
										
										
											2011-01-05 10:40:38 +00:00
										 |  |  | 		if (ob->disp.first==NULL) makeDispListCurveTypes(scene, ob, 0); | 
					
						
							| 
									
										
										
										
											2009-02-08 12:16:35 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-11-21 14:05:18 +00:00
										 |  |  | 	/* draw outline for selected objects, mesh does itself */ | 
					
						
							| 
									
										
										
										
											2010-03-16 17:49:31 +00:00
										 |  |  | 	if((v3d->flag & V3D_SELECT_OUTLINE) && ((v3d->flag2 & V3D_RENDER_OVERRIDE)==0) && ob->type!=OB_MESH) { | 
					
						
							| 
									
										
										
										
											2010-11-21 14:05:18 +00:00
										 |  |  | 		if(dt>OB_WIRE && (ob->mode & OB_MODE_EDIT)==0 && (flag & DRAW_SCENESET)==0) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			if (!(ob->dtx&OB_DRAWWIRE) && (ob->flag&SELECT) && !(flag&DRAW_PICKING)) { | 
					
						
							| 
									
										
										
										
											2009-02-08 12:16:35 +00:00
										 |  |  | 				 | 
					
						
							| 
									
										
										
										
											2010-11-21 14:05:18 +00:00
										 |  |  | 				drawObjectSelect(scene, v3d, ar, base); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	switch( ob->type) { | 
					
						
							|  |  |  | 		case OB_MESH: | 
					
						
							| 
									
										
										
										
											2009-10-27 19:53:34 +00:00
										 |  |  | 			empty_object= draw_mesh_object(scene, ar, v3d, rv3d, base, dt, flag); | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 			if(flag!=DRAW_CONSTCOLOR) dtx &= ~OB_DRAWWIRE; // mesh draws wire itself
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case OB_FONT: | 
					
						
							|  |  |  | 			cu= ob->data; | 
					
						
							| 
									
										
										
										
											2009-01-23 14:43:25 +00:00
										 |  |  | 			if(cu->editfont) { | 
					
						
							|  |  |  | 				draw_textcurs(cu->editfont->textcurs); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				if (cu->flag & CU_FAST) { | 
					
						
							|  |  |  | 					cpack(0xFFFFFF); | 
					
						
							|  |  |  | 					set_inverted_drawing(1); | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | 					drawDispList(scene, v3d, rv3d, base, OB_WIRE); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 					set_inverted_drawing(0); | 
					
						
							|  |  |  | 				} else { | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | 					drawDispList(scene, v3d, rv3d, base, dt); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 				if (cu->linewidth != 0.0f) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 					UI_ThemeColor(TH_WIRE); | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 					copy_v3_v3(vec1, ob->orig); | 
					
						
							|  |  |  | 					copy_v3_v3(vec2, ob->orig); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 					vec1[0] += cu->linewidth; | 
					
						
							|  |  |  | 					vec2[0] += cu->linewidth; | 
					
						
							|  |  |  | 					vec1[1] += cu->linedist * cu->fsize; | 
					
						
							|  |  |  | 					vec2[1] -= cu->lines * cu->linedist * cu->fsize; | 
					
						
							|  |  |  | 					setlinestyle(3); | 
					
						
							|  |  |  | 					glBegin(GL_LINE_STRIP);  | 
					
						
							|  |  |  | 					glVertex2fv(vec1);  | 
					
						
							|  |  |  | 					glVertex2fv(vec2);  | 
					
						
							|  |  |  | 					glEnd(); | 
					
						
							|  |  |  | 					setlinestyle(0); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				setlinestyle(3); | 
					
						
							|  |  |  | 				for (i=0; i<cu->totbox; i++) { | 
					
						
							| 
									
										
										
										
											2011-03-27 15:57:27 +00:00
										 |  |  | 					if (cu->tb[i].w != 0.0f) { | 
					
						
							| 
									
										
										
										
											2011-09-12 01:43:20 +00:00
										 |  |  | 						UI_ThemeColor(i == (cu->actbox-1) ? TH_ACTIVE : TH_WIRE); | 
					
						
							| 
									
										
										
										
											2010-08-01 09:56:00 +00:00
										 |  |  | 						vec1[0] = (cu->xof * cu->fsize) + cu->tb[i].x; | 
					
						
							|  |  |  | 						vec1[1] = (cu->yof * cu->fsize) + cu->tb[i].y + cu->fsize; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 						vec1[2] = 0.001; | 
					
						
							|  |  |  | 						glBegin(GL_LINE_STRIP); | 
					
						
							|  |  |  | 						glVertex3fv(vec1); | 
					
						
							|  |  |  | 						vec1[0] += cu->tb[i].w; | 
					
						
							|  |  |  | 						glVertex3fv(vec1); | 
					
						
							|  |  |  | 						vec1[1] -= cu->tb[i].h; | 
					
						
							|  |  |  | 						glVertex3fv(vec1); | 
					
						
							|  |  |  | 						vec1[0] -= cu->tb[i].w; | 
					
						
							|  |  |  | 						glVertex3fv(vec1); | 
					
						
							|  |  |  | 						vec1[1] += cu->tb[i].h; | 
					
						
							|  |  |  | 						glVertex3fv(vec1); | 
					
						
							|  |  |  | 						glEnd(); | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				setlinestyle(0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-23 14:43:25 +00:00
										 |  |  | 				if (BKE_font_getselection(ob, &selstart, &selend) && cu->selboxes) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 					float selboxw; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					cpack(0xffffff); | 
					
						
							| 
									
										
										
										
											2009-12-26 20:23:13 +00:00
										 |  |  | 					set_inverted_drawing(1); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 					for (i=0; i<(selend-selstart+1); i++) { | 
					
						
							| 
									
										
										
										
											2009-01-23 14:43:25 +00:00
										 |  |  | 						SelBox *sb = &(cu->selboxes[i]); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 						if (i<(selend-selstart)) { | 
					
						
							| 
									
										
										
										
											2009-01-23 14:43:25 +00:00
										 |  |  | 							if (cu->selboxes[i+1].y == sb->y) | 
					
						
							|  |  |  | 								selboxw= cu->selboxes[i+1].x - sb->x; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 							else | 
					
						
							|  |  |  | 								selboxw= sb->w; | 
					
						
							|  |  |  | 						} | 
					
						
							|  |  |  | 						else { | 
					
						
							|  |  |  | 							selboxw= sb->w; | 
					
						
							|  |  |  | 						} | 
					
						
							|  |  |  | 						glBegin(GL_QUADS); | 
					
						
							|  |  |  | 						glVertex3f(sb->x, sb->y, 0.001); | 
					
						
							| 
									
										
										
										
											2009-12-26 20:23:13 +00:00
										 |  |  | 						glVertex3f(sb->x+selboxw, sb->y, 0.001); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 						glVertex3f(sb->x+selboxw, sb->y+sb->h, 0.001); | 
					
						
							|  |  |  | 						glVertex3f(sb->x, sb->y+sb->h, 0.001); | 
					
						
							|  |  |  | 						glEnd(); | 
					
						
							|  |  |  | 					} | 
					
						
							| 
									
										
										
										
											2009-12-26 20:23:13 +00:00
										 |  |  | 					set_inverted_drawing(0); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2010-05-20 09:17:49 +00:00
										 |  |  | 			else if(dt==OB_BOUNDBOX) { | 
					
						
							|  |  |  | 				if((v3d->flag2 & V3D_RENDER_OVERRIDE && v3d->drawtype >= OB_WIRE)==0) | 
					
						
							| 
									
										
										
										
											2011-11-04 15:53:34 +00:00
										 |  |  | 					draw_bounding_volume(scene, ob, ob->boundtype); | 
					
						
							| 
									
										
										
										
											2010-05-20 09:17:49 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2011-05-21 08:56:37 +00:00
										 |  |  | 			else if(ED_view3d_boundbox_clip(rv3d, ob->obmat, ob->bb ? ob->bb : cu->bb)) | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | 				empty_object= drawDispList(scene, v3d, rv3d, base, dt); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case OB_CURVE: | 
					
						
							|  |  |  | 		case OB_SURF: | 
					
						
							|  |  |  | 			cu= ob->data; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-02 19:10:35 +00:00
										 |  |  | 			if(cu->editnurb) { | 
					
						
							| 
									
										
										
										
											2011-09-14 00:37:27 +00:00
										 |  |  | 				ListBase *nurbs= curve_editnurbs(cu); | 
					
						
							| 
									
										
										
										
											2010-07-25 11:57:36 +00:00
										 |  |  | 				drawnurb(scene, v3d, rv3d, base, nurbs->first, dt); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2010-05-20 09:17:49 +00:00
										 |  |  | 			else if(dt==OB_BOUNDBOX) { | 
					
						
							|  |  |  | 				if((v3d->flag2 & V3D_RENDER_OVERRIDE && v3d->drawtype >= OB_WIRE)==0) | 
					
						
							| 
									
										
										
										
											2011-11-04 15:53:34 +00:00
										 |  |  | 					draw_bounding_volume(scene, ob, ob->boundtype); | 
					
						
							| 
									
										
										
										
											2010-05-20 09:17:49 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2011-05-21 08:56:37 +00:00
										 |  |  | 			else if(ED_view3d_boundbox_clip(rv3d, ob->obmat, ob->bb ? ob->bb : cu->bb)) { | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | 				empty_object= drawDispList(scene, v3d, rv3d, base, dt); | 
					
						
							| 
									
										
										
										
											2010-10-14 01:22:14 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | //XXX old animsys				if(cu->path)
 | 
					
						
							|  |  |  | //               					curve_draw_speed(scene, ob);
 | 
					
						
							| 
									
										
										
										
											2010-03-05 16:47:52 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			break; | 
					
						
							|  |  |  | 		case OB_MBALL: | 
					
						
							| 
									
										
										
										
											2009-01-02 19:10:35 +00:00
										 |  |  | 		{ | 
					
						
							|  |  |  | 			MetaBall *mb= ob->data; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if(mb->editelems)  | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | 				drawmball(scene, v3d, rv3d, base, dt); | 
					
						
							| 
									
										
										
										
											2010-05-20 09:17:49 +00:00
										 |  |  | 			else if(dt==OB_BOUNDBOX) { | 
					
						
							|  |  |  | 				if((v3d->flag2 & V3D_RENDER_OVERRIDE && v3d->drawtype >= OB_WIRE)==0) | 
					
						
							| 
									
										
										
										
											2011-11-04 15:53:34 +00:00
										 |  |  | 					draw_bounding_volume(scene, ob, ob->boundtype); | 
					
						
							| 
									
										
										
										
											2010-05-20 09:17:49 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			else  | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | 				empty_object= drawmball(scene, v3d, rv3d, base, dt); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2009-01-02 19:10:35 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		case OB_EMPTY: | 
					
						
							| 
									
										
										
										
											2011-05-09 16:31:54 +00:00
										 |  |  | 			if((v3d->flag2 & V3D_RENDER_OVERRIDE)==0) { | 
					
						
							|  |  |  | 				if (ob->empty_drawtype == OB_EMPTY_IMAGE) { | 
					
						
							|  |  |  | 					draw_empty_image(ob); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				else { | 
					
						
							|  |  |  | 					drawaxes(ob->empty_drawsize, ob->empty_drawtype); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			break; | 
					
						
							|  |  |  | 		case OB_LAMP: | 
					
						
							| 
									
										
										
										
											2010-03-16 17:49:31 +00:00
										 |  |  | 			if((v3d->flag2 & V3D_RENDER_OVERRIDE)==0) { | 
					
						
							|  |  |  | 				drawlamp(scene, v3d, rv3d, base, dt, flag); | 
					
						
							|  |  |  | 				if(dtx || (base->flag & SELECT)) glMultMatrixf(ob->obmat); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			break; | 
					
						
							|  |  |  | 		case OB_CAMERA: | 
					
						
							| 
									
										
										
										
											2011-12-03 20:49:41 +00:00
										 |  |  | 		if ( (v3d->flag2 & V3D_RENDER_OVERRIDE)==0 || | 
					
						
							|  |  |  | 		     (rv3d->persp==RV3D_CAMOB && v3d->camera==ob)) /* special exception for active camera */ | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			drawcamera(scene, v3d, rv3d, base, flag); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2011-12-03 20:49:41 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2011-08-01 11:44:20 +00:00
										 |  |  | 		case OB_SPEAKER: | 
					
						
							|  |  |  | 			if((v3d->flag2 & V3D_RENDER_OVERRIDE)==0) | 
					
						
							|  |  |  | 				drawspeaker(scene, v3d, rv3d, ob, flag); | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		case OB_LATTICE: | 
					
						
							| 
									
										
										
										
											2010-03-16 17:49:31 +00:00
										 |  |  | 			if((v3d->flag2 & V3D_RENDER_OVERRIDE)==0) { | 
					
						
							|  |  |  | 				drawlattice(scene, v3d, ob); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			break; | 
					
						
							|  |  |  | 		case OB_ARMATURE: | 
					
						
							| 
									
										
										
										
											2010-03-16 17:49:31 +00:00
										 |  |  | 			if((v3d->flag2 & V3D_RENDER_OVERRIDE)==0) { | 
					
						
							|  |  |  | 				if(dt>OB_WIRE) GPU_enable_material(0, NULL); // we use default material
 | 
					
						
							| 
									
										
										
										
											2011-06-17 03:17:07 +00:00
										 |  |  | 				empty_object= draw_armature(scene, v3d, ar, base, dt, flag, FALSE); | 
					
						
							| 
									
										
										
										
											2010-03-16 17:49:31 +00:00
										 |  |  | 				if(dt>OB_WIRE) GPU_disable_material(); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			break; | 
					
						
							|  |  |  | 		default: | 
					
						
							| 
									
										
										
										
											2010-03-16 17:49:31 +00:00
										 |  |  | 			if((v3d->flag2 & V3D_RENDER_OVERRIDE)==0) { | 
					
						
							| 
									
										
										
										
											2010-10-14 01:22:14 +00:00
										 |  |  | 				drawaxes(1.0, OB_ARROWS); | 
					
						
							| 
									
										
										
										
											2010-03-16 17:49:31 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-11-21 22:45:25 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-05-20 09:17:49 +00:00
										 |  |  | 	if((v3d->flag2 & V3D_RENDER_OVERRIDE) == 0) { | 
					
						
							| 
									
										
										
										
											2010-03-16 17:49:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		if(ob->soft /*&& flag & OB_SBMOTION*/){ | 
					
						
							|  |  |  | 			float mrt[3][3],msc[3][3],mtr[3][3];  | 
					
						
							| 
									
										
										
										
											2011-03-03 17:59:04 +00:00
										 |  |  | 			SoftBody *sb= NULL; | 
					
						
							| 
									
										
										
										
											2010-03-16 17:49:31 +00:00
										 |  |  | 			float tipw = 0.5f, tiph = 0.5f,drawsize = 4.0f; | 
					
						
							|  |  |  | 			if ((sb= ob->soft)){ | 
					
						
							|  |  |  | 				if(sb->solverflags & SBSO_ESTIMATEIPO){ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					glLoadMatrixf(rv3d->viewmat); | 
					
						
							|  |  |  | 					copy_m3_m3(msc,sb->lscale); | 
					
						
							|  |  |  | 					copy_m3_m3(mrt,sb->lrot); | 
					
						
							|  |  |  | 					mul_m3_m3m3(mtr,mrt,msc);  | 
					
						
							|  |  |  | 					ob_draw_RE_motion(sb->lcom,mtr,tipw,tiph,drawsize); | 
					
						
							|  |  |  | 					glMultMatrixf(ob->obmat); | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2009-11-01 00:06:53 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-22 09:30:00 +00:00
										 |  |  | 		if(ob->pd && ob->pd->forcefield) { | 
					
						
							|  |  |  | 			draw_forcefield(scene, ob, rv3d); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* code for new particle system */ | 
					
						
							|  |  |  | 	if(		(warning_recursive==0) && | 
					
						
							|  |  |  | 			(ob->particlesystem.first) && | 
					
						
							|  |  |  | 			(flag & DRAW_PICKING)==0 && | 
					
						
							| 
									
										
										
										
											2009-01-02 19:10:35 +00:00
										 |  |  | 			(ob!=scene->obedit)	 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	  ) { | 
					
						
							|  |  |  | 		ParticleSystem *psys; | 
					
						
							| 
									
										
										
										
											2009-12-07 17:55:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		if(col || (ob->flag & SELECT)) cpack(0xFFFFFF);	/* for visibility, also while wpaint */ | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 		//glDepthMask(GL_FALSE);
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-01 15:32:55 +00:00
										 |  |  | 		glLoadMatrixf(rv3d->viewmat); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 		view3d_cached_text_draw_begin(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-07 17:55:58 +00:00
										 |  |  | 		for(psys=ob->particlesystem.first; psys; psys=psys->next) { | 
					
						
							|  |  |  | 			/* run this so that possible child particles get cached */ | 
					
						
							| 
									
										
										
										
											2011-12-03 20:26:53 +00:00
										 |  |  | 			if (ob->mode & OB_MODE_PARTICLE_EDIT && is_obact) { | 
					
						
							| 
									
										
										
										
											2010-03-09 03:27:05 +00:00
										 |  |  | 				PTCacheEdit *edit = PE_create_current(scene, ob); | 
					
						
							| 
									
										
										
										
											2009-12-07 18:17:39 +00:00
										 |  |  | 				if(edit && edit->psys == psys) | 
					
						
							|  |  |  | 					draw_update_ptcache_edit(scene, ob, edit); | 
					
						
							| 
									
										
										
										
											2010-03-09 03:27:05 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2009-12-07 17:55:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | 			draw_new_particle_system(scene, v3d, rv3d, base, psys, dt); | 
					
						
							| 
									
										
										
										
											2009-12-07 17:55:58 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2010-10-19 02:41:09 +00:00
										 |  |  | 		invert_m4_m4(ob->imat, ob->obmat); | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 		view3d_cached_text_draw_end(v3d, ar, 0, NULL); | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-01 15:32:55 +00:00
										 |  |  | 		glMultMatrixf(ob->obmat); | 
					
						
							| 
									
										
										
										
											2009-07-04 03:50:12 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		//glDepthMask(GL_TRUE);
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		if(col) cpack(col); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-07 17:55:58 +00:00
										 |  |  | 	/* draw edit particles last so that they can draw over child particles */ | 
					
						
							| 
									
										
										
										
											2011-12-03 20:26:53 +00:00
										 |  |  | 	if ( (warning_recursive==0) && | 
					
						
							|  |  |  | 	     (flag & DRAW_PICKING)==0 && | 
					
						
							|  |  |  | 	     (!scene->obedit)) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2009-12-07 17:55:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-03 20:26:53 +00:00
										 |  |  | 		if (ob->mode & OB_MODE_PARTICLE_EDIT && is_obact) { | 
					
						
							| 
									
										
										
										
											2010-03-09 03:27:05 +00:00
										 |  |  | 			PTCacheEdit *edit = PE_create_current(scene, ob); | 
					
						
							| 
									
										
										
										
											2009-12-07 17:55:58 +00:00
										 |  |  | 			if(edit) { | 
					
						
							| 
									
										
										
										
											2010-02-01 15:32:55 +00:00
										 |  |  | 				glLoadMatrixf(rv3d->viewmat); | 
					
						
							| 
									
										
										
										
											2010-10-19 09:28:38 +00:00
										 |  |  | 				draw_update_ptcache_edit(scene, ob, edit); | 
					
						
							| 
									
										
										
										
											2010-10-14 01:22:14 +00:00
										 |  |  | 				draw_ptcache_edit(scene, v3d, edit); | 
					
						
							| 
									
										
										
										
											2010-02-01 15:32:55 +00:00
										 |  |  | 				glMultMatrixf(ob->obmat); | 
					
						
							| 
									
										
										
										
											2009-12-07 17:55:58 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-30 15:00:26 +00:00
										 |  |  | 	/* draw code for smoke */ | 
					
						
							| 
									
										
										
										
											2011-08-25 15:49:52 +00:00
										 |  |  | 	if((md = modifiers_findByType(ob, eModifierType_Smoke))) { | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 		SmokeModifierData *smd = (SmokeModifierData *)md; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// draw collision objects
 | 
					
						
							|  |  |  | 		if((smd->type & MOD_SMOKE_TYPE_COLL) && smd->coll) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			/*SmokeCollSettings *scs = smd->coll;
 | 
					
						
							|  |  |  | 			if(scs->points) | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				size_t i; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-01 15:32:55 +00:00
										 |  |  | 				glLoadMatrixf(rv3d->viewmat); | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				if(col || (ob->flag & SELECT)) cpack(0xFFFFFF);	 | 
					
						
							|  |  |  | 				glDepthMask(GL_FALSE); | 
					
						
							|  |  |  | 				glEnable(GL_BLEND); | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				// glPointSize(3.0);
 | 
					
						
							|  |  |  | 				bglBegin(GL_POINTS); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				for(i = 0; i < scs->numpoints; i++) | 
					
						
							|  |  |  | 				{ | 
					
						
							|  |  |  | 					bglVertex3fv(&scs->points[3*i]); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				bglEnd(); | 
					
						
							|  |  |  | 				glPointSize(1.0); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-01 15:32:55 +00:00
										 |  |  | 				glMultMatrixf(ob->obmat); | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 				glDisable(GL_BLEND); | 
					
						
							|  |  |  | 				glDepthMask(GL_TRUE); | 
					
						
							|  |  |  | 				if(col) cpack(col); | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			*/ | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// only draw domains
 | 
					
						
							|  |  |  | 		if(smd->domain && smd->domain->fluid) | 
					
						
							|  |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2010-12-14 14:45:56 +00:00
										 |  |  | 			if(CFRA < smd->domain->point_cache[0]->startframe) | 
					
						
							|  |  |  | 				; /* don't show smoke before simulation starts, this could be made an option in the future */ | 
					
						
							|  |  |  | 			else if(!smd->domain->wt || !(smd->domain->viewsettings & MOD_SMOKE_VIEW_SHOWBIG)) | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 			{ | 
					
						
							|  |  |  | // #if 0
 | 
					
						
							|  |  |  | 				smd->domain->tex = NULL; | 
					
						
							|  |  |  | 				GPU_create_smoke(smd, 0); | 
					
						
							| 
									
										
										
										
											2011-12-03 20:49:41 +00:00
										 |  |  | 				draw_volume(ar, smd->domain->tex, | 
					
						
							|  |  |  | 				            smd->domain->p0, smd->domain->p1, | 
					
						
							|  |  |  | 				            smd->domain->res, smd->domain->dx, | 
					
						
							|  |  |  | 				            smd->domain->tex_shadow); | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 				GPU_free_smoke(smd); | 
					
						
							|  |  |  | // #endif
 | 
					
						
							|  |  |  | #if 0
 | 
					
						
							|  |  |  | 				int x, y, z; | 
					
						
							|  |  |  | 				float *density = smoke_get_density(smd->domain->fluid); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-01 15:32:55 +00:00
										 |  |  | 				glLoadMatrixf(rv3d->viewmat); | 
					
						
							|  |  |  | 				// glMultMatrixf(ob->obmat);	
 | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				if(col || (ob->flag & SELECT)) cpack(0xFFFFFF);	 | 
					
						
							|  |  |  | 				glDepthMask(GL_FALSE); | 
					
						
							|  |  |  | 				glEnable(GL_BLEND); | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				// glPointSize(3.0);
 | 
					
						
							|  |  |  | 				bglBegin(GL_POINTS); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				for(x = 0; x < smd->domain->res[0]; x++) | 
					
						
							|  |  |  | 					for(y = 0; y < smd->domain->res[1]; y++) | 
					
						
							|  |  |  | 						for(z = 0; z < smd->domain->res[2]; z++) | 
					
						
							|  |  |  | 				{ | 
					
						
							|  |  |  | 					float tmp[3]; | 
					
						
							|  |  |  | 					int index = smoke_get_index(x, smd->domain->res[0], y, smd->domain->res[1], z); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					if(density[index] > FLT_EPSILON) | 
					
						
							|  |  |  | 					{ | 
					
						
							|  |  |  | 						float color[3]; | 
					
						
							| 
									
										
										
										
											2010-08-01 11:00:36 +00:00
										 |  |  | 						copy_v3_v3(tmp, smd->domain->p0); | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 						tmp[0] += smd->domain->dx * x + smd->domain->dx * 0.5; | 
					
						
							|  |  |  | 						tmp[1] += smd->domain->dx * y + smd->domain->dx * 0.5; | 
					
						
							|  |  |  | 						tmp[2] += smd->domain->dx * z + smd->domain->dx * 0.5; | 
					
						
							|  |  |  | 						color[0] = color[1] = color[2] = density[index]; | 
					
						
							|  |  |  | 						glColor3fv(color); | 
					
						
							|  |  |  | 						bglVertex3fv(tmp); | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				bglEnd(); | 
					
						
							|  |  |  | 				glPointSize(1.0); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-01 15:32:55 +00:00
										 |  |  | 				glMultMatrixf(ob->obmat); | 
					
						
							| 
									
										
										
										
											2009-09-16 17:43:09 +00:00
										 |  |  | 				glDisable(GL_BLEND); | 
					
						
							|  |  |  | 				glDepthMask(GL_TRUE); | 
					
						
							|  |  |  | 				if(col) cpack(col); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else if(smd->domain->wt && (smd->domain->viewsettings & MOD_SMOKE_VIEW_SHOWBIG)) | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				smd->domain->tex = NULL; | 
					
						
							|  |  |  | 				GPU_create_smoke(smd, 1); | 
					
						
							| 
									
										
										
										
											2011-12-03 20:49:41 +00:00
										 |  |  | 				draw_volume(ar, smd->domain->tex, | 
					
						
							|  |  |  | 				            smd->domain->p0, smd->domain->p1, | 
					
						
							|  |  |  | 				            smd->domain->res_wt, smd->domain->dx_wt, | 
					
						
							|  |  |  | 				            smd->domain->tex_shadow); | 
					
						
							| 
									
										
										
										
											2009-08-20 00:33:59 +00:00
										 |  |  | 				GPU_free_smoke(smd); | 
					
						
							| 
									
										
										
										
											2009-07-30 15:00:26 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-22 09:30:00 +00:00
										 |  |  | 	if((v3d->flag2 & V3D_RENDER_OVERRIDE)==0) { | 
					
						
							| 
									
										
										
										
											2010-03-16 17:49:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		bConstraint *con; | 
					
						
							|  |  |  | 		for(con=ob->constraints.first; con; con= con->next)  | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			if(con->type==CONSTRAINT_TYPE_RIGIDBODYJOINT)  | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				bRigidBodyJointConstraint *data = (bRigidBodyJointConstraint*)con->data; | 
					
						
							|  |  |  | 				if(data->flag&CONSTRAINT_DRAW_PIVOT) | 
					
						
							|  |  |  | 					drawRBpivot(data); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-04 15:53:34 +00:00
										 |  |  | 		if(ob->gameflag & OB_BOUNDS) { | 
					
						
							|  |  |  | 			if(ob->boundtype!=ob->collision_boundtype || (dtx & OB_BOUNDBOX)==0) { | 
					
						
							|  |  |  | 				setlinestyle(2); | 
					
						
							|  |  |  | 				draw_bounding_volume(scene, ob, ob->collision_boundtype); | 
					
						
							|  |  |  | 				setlinestyle(0); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-22 09:30:00 +00:00
										 |  |  | 		/* draw extra: after normal draw because of makeDispList */ | 
					
						
							|  |  |  | 		if(dtx && (G.f & G_RENDER_OGL)==0) { | 
					
						
							| 
									
										
										
										
											2010-07-26 21:35:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-22 09:30:00 +00:00
										 |  |  | 			if(dtx & OB_AXIS) { | 
					
						
							| 
									
										
										
										
											2010-10-14 01:22:14 +00:00
										 |  |  | 				drawaxes(1.0f, OB_ARROWS); | 
					
						
							| 
									
										
										
										
											2010-03-22 09:30:00 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2010-05-20 15:04:47 +00:00
										 |  |  | 			if(dtx & OB_BOUNDBOX) { | 
					
						
							| 
									
										
										
										
											2011-11-04 15:53:34 +00:00
										 |  |  | 				draw_bounding_volume(scene, ob, ob->boundtype); | 
					
						
							| 
									
										
										
										
											2010-05-20 15:04:47 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2010-03-22 09:30:00 +00:00
										 |  |  | 			if(dtx & OB_TEXSPACE) drawtexspace(ob); | 
					
						
							|  |  |  | 			if(dtx & OB_DRAWNAME) { | 
					
						
							|  |  |  | 				/* patch for several 3d cards (IBM mostly) that crash on glSelect with text drawing */ | 
					
						
							|  |  |  | 				/* but, we also dont draw names for sets or duplicators */ | 
					
						
							|  |  |  | 				if(flag == 0) { | 
					
						
							| 
									
										
										
										
											2010-10-24 12:45:47 +00:00
										 |  |  | 					float zero[3]= {0,0,0}; | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 					float curcol[4]; | 
					
						
							|  |  |  | 					unsigned char tcol[4]; | 
					
						
							|  |  |  | 					glGetFloatv(GL_CURRENT_COLOR, curcol); | 
					
						
							| 
									
										
										
										
											2012-01-19 09:09:00 +00:00
										 |  |  | 					rgb_float_to_uchar(tcol, curcol); | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 					tcol[3]= 255; | 
					
						
							|  |  |  | 					view3d_cached_text_draw_add(zero, ob->id.name+2, 10, 0, tcol); | 
					
						
							| 
									
										
										
										
											2010-03-22 09:30:00 +00:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2010-03-22 09:30:00 +00:00
										 |  |  | 			/*if(dtx & OB_DRAWIMAGE) drawDispListwire(&ob->disp);*/ | 
					
						
							|  |  |  | 			if((dtx & OB_DRAWWIRE) && dt>=OB_SOLID) drawWireExtra(scene, rv3d, ob); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-06-15 10:17:06 +00:00
										 |  |  | 	if(dt<=OB_SOLID && (v3d->flag2 & V3D_RENDER_OVERRIDE)==0) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		if((ob->gameflag & OB_DYNAMIC) ||  | 
					
						
							|  |  |  | 			((ob->gameflag & OB_BOUNDS) && (ob->boundtype == OB_BOUND_SPHERE))) { | 
					
						
							| 
									
										
										
										
											2010-07-31 10:58:10 +00:00
										 |  |  | 			float imat[4][4], vec[3]= {0.0f, 0.0f, 0.0f}; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-01 15:32:55 +00:00
										 |  |  | 			invert_m4_m4(imat, rv3d->viewmatob); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			setlinestyle(2); | 
					
						
							|  |  |  | 			drawcircball(GL_LINE_LOOP, vec, ob->inertia, imat); | 
					
						
							|  |  |  | 			setlinestyle(0); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-05-23 03:24:15 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* return warning, this is cached text draw */ | 
					
						
							| 
									
										
										
										
											2010-10-19 02:41:09 +00:00
										 |  |  | 	invert_m4_m4(ob->imat, ob->obmat); | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 	view3d_cached_text_draw_end(v3d, ar, 1, NULL); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-01 15:32:55 +00:00
										 |  |  | 	glLoadMatrixf(rv3d->viewmat); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if(zbufoff) glDisable(GL_DEPTH_TEST); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(warning_recursive) return; | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 	if(base->flag & OB_FROMDUPLI) return; | 
					
						
							| 
									
										
										
										
											2010-03-16 17:49:31 +00:00
										 |  |  | 	if(v3d->flag2 & V3D_RENDER_OVERRIDE) return; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* object centers, need to be drawn in viewmat space for speed, but OK for picking select */ | 
					
						
							| 
									
										
										
										
											2011-12-03 20:26:53 +00:00
										 |  |  | 	if (!is_obact || !(ob->mode & (OB_MODE_VERTEX_PAINT|OB_MODE_WEIGHT_PAINT|OB_MODE_TEXTURE_PAINT))) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		int do_draw_center= -1;	/* defines below are zero or positive... */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-16 17:49:31 +00:00
										 |  |  | 		if(v3d->flag2 & V3D_RENDER_OVERRIDE) { | 
					
						
							|  |  |  | 			/* dont draw */ | 
					
						
							|  |  |  | 		} else if((scene->basact)==base) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			do_draw_center= ACTIVE; | 
					
						
							|  |  |  | 		else if(base->flag & SELECT)  | 
					
						
							|  |  |  | 			do_draw_center= SELECT; | 
					
						
							|  |  |  | 		else if(empty_object || (v3d->flag & V3D_DRAW_CENTERS))  | 
					
						
							|  |  |  | 			do_draw_center= DESELECT; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if(do_draw_center != -1) { | 
					
						
							|  |  |  | 			if(flag & DRAW_PICKING) { | 
					
						
							|  |  |  | 				/* draw a single point for opengl selection */ | 
					
						
							|  |  |  | 				glBegin(GL_POINTS); | 
					
						
							|  |  |  | 				glVertex3fv(ob->obmat[3]); | 
					
						
							|  |  |  | 				glEnd(); | 
					
						
							|  |  |  | 			}  | 
					
						
							|  |  |  | 			else if((flag & DRAW_CONSTCOLOR)==0) { | 
					
						
							|  |  |  | 				/* we don't draw centers for duplicators and sets */ | 
					
						
							| 
									
										
										
										
											2010-01-03 01:55:20 +00:00
										 |  |  | 				if(U.obcenter_dia > 0) { | 
					
						
							| 
									
										
										
										
											2010-03-22 09:30:00 +00:00
										 |  |  | 					/* check > 0 otherwise grease pencil can draw into the circle select which is annoying. */ | 
					
						
							|  |  |  | 					drawcentercircle(v3d, rv3d, ob->obmat[3], do_draw_center, ob->id.lib || ob->id.us>1); | 
					
						
							| 
									
										
										
										
											2010-01-03 01:55:20 +00:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* not for sets, duplicators or picking */ | 
					
						
							| 
									
										
										
										
											2010-03-16 17:49:31 +00:00
										 |  |  | 	if(flag==0 && (v3d->flag & V3D_HIDE_HELPLINES)== 0 && (v3d->flag2 & V3D_RENDER_OVERRIDE)== 0) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		ListBase *list; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* draw hook center and offset line */ | 
					
						
							| 
									
										
										
										
											2009-01-02 19:10:35 +00:00
										 |  |  | 		if(ob!=scene->obedit) draw_hooks(ob); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		/* help lines and so */ | 
					
						
							| 
									
										
										
										
											2009-01-02 19:10:35 +00:00
										 |  |  | 		if(ob!=scene->obedit && ob->parent && (ob->parent->lay & v3d->lay)) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			setlinestyle(3); | 
					
						
							|  |  |  | 			glBegin(GL_LINES); | 
					
						
							|  |  |  | 			glVertex3fv(ob->obmat[3]); | 
					
						
							|  |  |  | 			glVertex3fv(ob->orig); | 
					
						
							|  |  |  | 			glEnd(); | 
					
						
							|  |  |  | 			setlinestyle(0); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* Drawing the constraint lines */ | 
					
						
							| 
									
										
										
										
											2010-12-23 13:16:56 +00:00
										 |  |  | 		if (ob->constraints.first) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			bConstraint *curcon; | 
					
						
							|  |  |  | 			bConstraintOb *cob; | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 			unsigned char col1[4], col2[4]; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2010-12-23 13:16:56 +00:00
										 |  |  | 			list = &ob->constraints; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2010-12-03 12:30:59 +00:00
										 |  |  | 			UI_GetThemeColor3ubv(TH_GRID, col1); | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 			UI_make_axis_color(col1, col2, 'Z'); | 
					
						
							|  |  |  | 			glColor3ubv(col2); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2009-01-04 14:14:06 +00:00
										 |  |  | 			cob= constraints_make_evalob(scene, ob, NULL, CONSTRAINT_OBTYPE_OBJECT); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			for (curcon = list->first; curcon; curcon=curcon->next) { | 
					
						
							|  |  |  | 				bConstraintTypeInfo *cti= constraint_get_typeinfo(curcon); | 
					
						
							|  |  |  | 				ListBase targets = {NULL, NULL}; | 
					
						
							|  |  |  | 				bConstraintTarget *ct; | 
					
						
							|  |  |  | 				 | 
					
						
							| 
									
										
										
										
											2011-12-15 20:38:23 +00:00
										 |  |  | 				if(ELEM(cti->type, CONSTRAINT_TYPE_FOLLOWTRACK, CONSTRAINT_TYPE_OBJECTSOLVER)) { | 
					
						
							|  |  |  | 					/* special case for object solver and follow track constraints because they don't fill
 | 
					
						
							|  |  |  | 					   constraint targets properly (design limitation -- scene is needed for their target | 
					
						
							|  |  |  | 					   but it can't be accessed from get_targets callvack) */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					Object *camob= NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					if(cti->type==CONSTRAINT_TYPE_FOLLOWTRACK) { | 
					
						
							|  |  |  | 						bFollowTrackConstraint *data= (bFollowTrackConstraint *)curcon->data; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 						camob= data->camera ? data->camera : scene->camera; | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 					else if(cti->type==CONSTRAINT_TYPE_OBJECTSOLVER) { | 
					
						
							|  |  |  | 						bObjectSolverConstraint *data= (bObjectSolverConstraint *)curcon->data; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 						camob= data->camera ? data->camera : scene->camera; | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					if(camob) { | 
					
						
							| 
									
										
										
										
											2011-12-15 16:09:57 +00:00
										 |  |  | 						setlinestyle(3); | 
					
						
							|  |  |  | 						glBegin(GL_LINES); | 
					
						
							| 
									
										
										
										
											2011-12-15 20:38:23 +00:00
										 |  |  | 						glVertex3fv(camob->obmat[3]); | 
					
						
							| 
									
										
										
										
											2011-12-15 16:09:57 +00:00
										 |  |  | 						glVertex3fv(ob->obmat[3]); | 
					
						
							|  |  |  | 						glEnd(); | 
					
						
							|  |  |  | 						setlinestyle(0); | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				else if ((curcon->flag & CONSTRAINT_EXPAND) && (cti) && (cti->get_constraint_targets)) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 					cti->get_constraint_targets(curcon, &targets); | 
					
						
							|  |  |  | 					 | 
					
						
							|  |  |  | 					for (ct= targets.first; ct; ct= ct->next) { | 
					
						
							|  |  |  | 						/* calculate target's matrix */ | 
					
						
							|  |  |  | 						if (cti->get_target_matrix)  | 
					
						
							| 
									
										
										
										
											2011-11-06 06:08:18 +00:00
										 |  |  | 							cti->get_target_matrix(curcon, cob, ct, BKE_curframe(scene)); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 						else | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | 							unit_m4(ct->matrix); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 						 | 
					
						
							|  |  |  | 						setlinestyle(3); | 
					
						
							|  |  |  | 						glBegin(GL_LINES); | 
					
						
							|  |  |  | 						glVertex3fv(ct->matrix[3]); | 
					
						
							|  |  |  | 						glVertex3fv(ob->obmat[3]); | 
					
						
							|  |  |  | 						glEnd(); | 
					
						
							|  |  |  | 						setlinestyle(0); | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 					 | 
					
						
							|  |  |  | 					if (cti->flush_constraint_targets) | 
					
						
							|  |  |  | 						cti->flush_constraint_targets(curcon, &targets, 1); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			constraints_clear_evalob(cob); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	free_old_images(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ***************** BACKBUF SEL (BBS) ********* */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-09 16:32:15 +00:00
										 |  |  | static void bbs_obmode_mesh_verts__mapFunc(void *userData, int index, float *co, float *UNUSED(no_f), short *UNUSED(no_s)) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-12-20 08:47:36 +00:00
										 |  |  | 	bbsObmodeMeshVerts_userData *data = userData; | 
					
						
							| 
									
										
										
										
											2011-09-19 02:43:03 +00:00
										 |  |  | 	MVert *mv = &data->mvert[index]; | 
					
						
							| 
									
										
										
										
											2011-09-18 01:09:18 +00:00
										 |  |  | 	int offset = (intptr_t) data->offset; | 
					
						
							| 
									
										
										
										
											2011-08-09 16:32:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-18 01:09:18 +00:00
										 |  |  | 	if (!(mv->flag & ME_HIDE)) { | 
					
						
							|  |  |  | 		WM_set_framebuffer_index_color(offset+index); | 
					
						
							|  |  |  | 		bglVertex3fv(co); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-08-09 16:32:15 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2011-09-18 17:10:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-18 01:09:18 +00:00
										 |  |  | static void bbs_obmode_mesh_verts(Object *ob, DerivedMesh *dm, int offset) | 
					
						
							| 
									
										
										
										
											2011-08-09 16:32:15 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-12-20 08:47:36 +00:00
										 |  |  | 	bbsObmodeMeshVerts_userData data; | 
					
						
							| 
									
										
										
										
											2011-09-18 01:09:18 +00:00
										 |  |  | 	Mesh *me = ob->data; | 
					
						
							|  |  |  | 	MVert *mvert = me->mvert; | 
					
						
							|  |  |  | 	data.mvert = mvert; | 
					
						
							|  |  |  | 	data.offset = (void*)(intptr_t) offset; | 
					
						
							| 
									
										
										
										
											2011-08-09 16:32:15 +00:00
										 |  |  | 	glPointSize( UI_GetThemeValuef(TH_VERTEX_SIZE) ); | 
					
						
							|  |  |  | 	bglBegin(GL_POINTS); | 
					
						
							| 
									
										
										
										
											2011-09-18 01:09:18 +00:00
										 |  |  | 	dm->foreachMappedVert(dm, bbs_obmode_mesh_verts__mapFunc, &data); | 
					
						
							| 
									
										
										
										
											2011-08-09 16:32:15 +00:00
										 |  |  | 	bglEnd(); | 
					
						
							|  |  |  | 	glPointSize(1.0); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-14 01:22:14 +00:00
										 |  |  | static void bbs_mesh_verts__mapFunc(void *userData, int index, float *co, float *UNUSED(no_f), short *UNUSED(no_s)) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	void **ptrs = userData; | 
					
						
							|  |  |  | 	int offset = (intptr_t) ptrs[0]; | 
					
						
							|  |  |  | 	BMVert *eve = EDBM_get_vert_for_index(ptrs[1], index); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 	if (!BM_elem_flag_test(eve, BM_ELEM_HIDDEN)) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		WM_set_framebuffer_index_color(offset+index); | 
					
						
							|  |  |  | 		bglVertex3fv(co); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-05-18 08:46:04 +00:00
										 |  |  | static void bbs_mesh_verts(BMEditMesh *em, DerivedMesh *dm, int offset) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	void *ptrs[2] = {(void*)(intptr_t) offset, em}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	glPointSize( UI_GetThemeValuef(TH_VERTEX_SIZE) ); | 
					
						
							|  |  |  | 	bglBegin(GL_POINTS); | 
					
						
							| 
									
										
										
										
											2009-05-18 08:46:04 +00:00
										 |  |  | 	dm->foreachMappedVert(dm, bbs_mesh_verts__mapFunc, ptrs); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	bglEnd(); | 
					
						
							|  |  |  | 	glPointSize(1.0); | 
					
						
							|  |  |  | }		 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int bbs_mesh_wire__setDrawOptions(void *userData, int index) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	void **ptrs = userData; | 
					
						
							|  |  |  | 	int offset = (intptr_t) ptrs[0]; | 
					
						
							|  |  |  | 	BMEdge *eed = EDBM_get_edge_for_index(ptrs[1], index); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 	if (!BM_elem_flag_test(eed, BM_ELEM_HIDDEN)) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		WM_set_framebuffer_index_color(offset+index); | 
					
						
							|  |  |  | 		return 1; | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-05-18 08:46:04 +00:00
										 |  |  | static void bbs_mesh_wire(BMEditMesh *em, DerivedMesh *dm, int offset) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	void *ptrs[2] = {(void*)(intptr_t) offset, em}; | 
					
						
							|  |  |  | 	dm->drawMappedEdges(dm, bbs_mesh_wire__setDrawOptions, ptrs); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | }		 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-14 01:22:14 +00:00
										 |  |  | static int bbs_mesh_solid__setSolidDrawOptions(void *userData, int index, int *UNUSED(drawSmooth_r)) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-06-01 19:30:19 +00:00
										 |  |  | 	BMFace *efa = EDBM_get_face_for_index(((void**)userData)[0], index); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 	if (efa && !BM_elem_flag_test(efa, BM_ELEM_HIDDEN)) { | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 		if (((void**)userData)[1]) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			WM_set_framebuffer_index_color(index+1); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		return 1; | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-27 06:19:40 +00:00
										 |  |  | static void bbs_mesh_solid__drawCenter(void *userData, int index, float *cent, float *UNUSED(no)) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	BMFace *efa = EDBM_get_face_for_index(((void**)userData)[0], index); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-12 10:51:45 +00:00
										 |  |  | 	if (!BM_elem_flag_test(efa, BM_ELEM_HIDDEN)) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		WM_set_framebuffer_index_color(index+1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		bglVertex3fv(cent); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* two options, facecolors or black */ | 
					
						
							| 
									
										
										
										
											2009-05-18 08:46:04 +00:00
										 |  |  | static void bbs_mesh_solid_EM(BMEditMesh *em, Scene *scene, View3D *v3d, | 
					
						
							| 
									
										
										
										
											2011-12-04 23:13:28 +00:00
										 |  |  |                               Object *ob, DerivedMesh *dm, int facecol) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 	void *ptrs[2] = {em, NULL}; //second one being null means to draw black
 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	cpack(0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (facecol) { | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 		ptrs[1] = (void*)(intptr_t) 1; | 
					
						
							| 
									
										
										
										
											2011-12-02 01:01:07 +00:00
										 |  |  | 		dm->drawMappedFaces(dm, bbs_mesh_solid__setSolidDrawOptions, GPU_enable_material, NULL, ptrs, 0); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-05-08 17:54:29 +00:00
										 |  |  | 		if(check_ob_drawface_dot(scene, v3d, ob->dt)) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			glPointSize(UI_GetThemeValuef(TH_FACEDOT_SIZE)); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 			bglBegin(GL_POINTS); | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 			dm->foreachMappedFaceCenter(dm, bbs_mesh_solid__drawCenter, ptrs); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			bglEnd(); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	} else { | 
					
						
							| 
									
										
										
										
											2011-12-02 01:01:07 +00:00
										 |  |  | 		dm->drawMappedFaces(dm, bbs_mesh_solid__setSolidDrawOptions, GPU_enable_material, NULL, ptrs, 0); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-09 14:32:55 +00:00
										 |  |  | static int bbs_mesh_solid__setDrawOpts(void *UNUSED(userData), int index, int *UNUSED(drawSmooth_r)) | 
					
						
							| 
									
										
										
										
											2009-11-01 00:06:53 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	WM_set_framebuffer_index_color(index+1); | 
					
						
							|  |  |  | 	return 1; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-14 01:22:14 +00:00
										 |  |  | static int bbs_mesh_solid_hide__setDrawOpts(void *userData, int index, int *UNUSED(drawSmooth_r)) | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	Mesh *me = userData; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-05 03:25:13 +00:00
										 |  |  | 	if (!(me->mpoly[index].flag&ME_HIDE)) { | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		WM_set_framebuffer_index_color(index+1); | 
					
						
							|  |  |  | 		return 1; | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-09 16:32:15 +00:00
										 |  |  | // must have called WM_set_framebuffer_index_color beforehand
 | 
					
						
							|  |  |  | static int bbs_mesh_solid_hide2__setDrawOpts(void *userData, int index, int *UNUSED(drawSmooth_r)) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	Mesh *me = userData; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-05 03:25:13 +00:00
										 |  |  | 	if (!(me->mpoly[index].flag & ME_HIDE)) { | 
					
						
							| 
									
										
										
										
											2011-08-09 16:32:15 +00:00
										 |  |  | 		return 1; | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2010-12-23 04:26:53 +00:00
										 |  |  | static void bbs_mesh_solid(Scene *scene, Object *ob) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2010-12-23 04:26:53 +00:00
										 |  |  | 	DerivedMesh *dm = mesh_get_derived_final(scene, ob, scene->customdata_mask); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	Mesh *me = (Mesh*)ob->data; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	glColor3ub(0, 0, 0); | 
					
						
							| 
									
										
										
										
											2011-12-03 20:49:41 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if((me->editflag & ME_EDIT_PAINT_MASK)) | 
					
						
							|  |  |  | 		dm->drawMappedFaces(dm, bbs_mesh_solid_hide__setDrawOpts, GPU_enable_material, NULL, me, 0); | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 		dm->drawMappedFaces(dm, bbs_mesh_solid__setDrawOpts, GPU_enable_material, NULL, me, 0); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	dm->release(dm); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | void draw_object_backbufsel(Scene *scene, View3D *v3d, RegionView3D *rv3d, Object *ob) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-06-23 00:41:55 +00:00
										 |  |  | 	ToolSettings *ts= scene->toolsettings; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-01 15:32:55 +00:00
										 |  |  | 	glMultMatrixf(ob->obmat); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	glClearDepth(1.0); glClear(GL_DEPTH_BUFFER_BIT); | 
					
						
							|  |  |  | 	glEnable(GL_DEPTH_TEST); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	switch( ob->type) { | 
					
						
							|  |  |  | 	case OB_MESH: | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 		if(ob->mode & OB_MODE_EDIT) { | 
					
						
							| 
									
										
										
										
											2009-02-19 23:53:40 +00:00
										 |  |  | 			Mesh *me= ob->data; | 
					
						
							| 
									
										
										
										
											2009-05-18 08:46:04 +00:00
										 |  |  | 			BMEditMesh *em= me->edit_btmesh; | 
					
						
							| 
									
										
										
										
											2009-02-19 23:53:40 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 			DerivedMesh *dm = editbmesh_get_derived_cage(scene, ob, em, CD_MASK_BAREMESH); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 			EDBM_init_index_arrays(em, 1, 1, 1); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-16 06:27:37 +00:00
										 |  |  | 			bbs_mesh_solid_EM(em, scene, v3d, ob, dm, ts->selectmode & SCE_SELECT_FACE); | 
					
						
							| 
									
										
										
										
											2009-06-23 00:41:55 +00:00
										 |  |  | 			if(ts->selectmode & SCE_SELECT_FACE) | 
					
						
							| 
									
										
										
										
											2009-05-18 10:29:37 +00:00
										 |  |  | 				bm_solidoffs = 1+em->bm->totface; | 
					
						
							| 
									
										
										
										
											2009-01-15 15:01:39 +00:00
										 |  |  | 			else | 
					
						
							| 
									
										
										
										
											2009-05-18 10:29:37 +00:00
										 |  |  | 				bm_solidoffs= 1; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | 			bglPolygonOffset(rv3d->dist, 1.0); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			// we draw edges always, for loop (select) tools
 | 
					
						
							| 
									
										
										
										
											2009-05-18 10:29:37 +00:00
										 |  |  | 			bbs_mesh_wire(em, dm, bm_solidoffs); | 
					
						
							|  |  |  | 			bm_wireoffs= bm_solidoffs + em->bm->totedge; | 
					
						
							| 
									
										
										
										
											2009-01-15 15:01:39 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			// we draw verts if vert select mode or if in transform (for snap).
 | 
					
						
							| 
									
										
										
										
											2009-06-23 00:41:55 +00:00
										 |  |  | 			if(ts->selectmode & SCE_SELECT_VERTEX || G.moving & G_TRANSFORM_EDIT) { | 
					
						
							| 
									
										
										
										
											2009-05-18 10:29:37 +00:00
										 |  |  | 				bbs_mesh_verts(em, dm, bm_wireoffs); | 
					
						
							|  |  |  | 				bm_vertoffs= bm_wireoffs + em->bm->totvert; | 
					
						
							| 
									
										
										
										
											2009-01-15 15:01:39 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2009-05-18 10:29:37 +00:00
										 |  |  | 			else bm_vertoffs= bm_wireoffs; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | 			bglPolygonOffset(rv3d->dist, 0.0); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			dm->release(dm); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 			EDBM_free_index_arrays(em); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2011-08-25 15:49:52 +00:00
										 |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2011-08-09 16:32:15 +00:00
										 |  |  | 			Mesh *me= ob->data; | 
					
						
							| 
									
										
										
										
											2011-10-15 01:32:49 +00:00
										 |  |  | 			if(     (me->editflag & ME_EDIT_VERT_SEL) && | 
					
						
							|  |  |  | 			        /* currently vertex select only supports weight paint */ | 
					
						
							|  |  |  | 			        (ob->mode & OB_MODE_WEIGHT_PAINT)) | 
					
						
							|  |  |  | 			{ | 
					
						
							| 
									
										
										
										
											2011-08-09 16:32:15 +00:00
										 |  |  | 				DerivedMesh *dm = mesh_get_derived_final(scene, ob, scene->customdata_mask); | 
					
						
							|  |  |  | 				glColor3ub(0, 0, 0); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-01 12:12:39 +00:00
										 |  |  | 				dm->drawMappedFaces(dm, bbs_mesh_solid_hide2__setDrawOpts, GPU_enable_material, NULL, me, 0); | 
					
						
							| 
									
										
										
										
											2011-08-09 16:32:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				 | 
					
						
							| 
									
										
										
										
											2011-09-14 05:25:43 +00:00
										 |  |  | 				bbs_obmode_mesh_verts(ob, dm, 1); | 
					
						
							| 
									
										
										
										
											2011-09-22 16:09:27 +00:00
										 |  |  | 				bm_vertoffs = me->totvert+1; | 
					
						
							| 
									
										
										
										
											2011-08-09 16:32:15 +00:00
										 |  |  | 				dm->release(dm); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2011-09-13 06:39:17 +00:00
										 |  |  | 			else { | 
					
						
							|  |  |  | 				bbs_mesh_solid(scene, ob); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2011-08-25 15:49:52 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		break; | 
					
						
							|  |  |  | 	case OB_CURVE: | 
					
						
							|  |  |  | 	case OB_SURF: | 
					
						
							|  |  |  | 		break; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-01 15:32:55 +00:00
										 |  |  | 	glLoadMatrixf(rv3d->viewmat); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************* draw object instances for bones, for example ****************** */ | 
					
						
							|  |  |  | /*               assumes all matrices/etc set OK */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* helper function for drawing object instances - meshes */ | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | static void draw_object_mesh_instance(Scene *scene, View3D *v3d, RegionView3D *rv3d,  | 
					
						
							|  |  |  | 									  Object *ob, int dt, int outline) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2008-12-31 17:11:42 +00:00
										 |  |  | 	Mesh *me= ob->data; | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	DerivedMesh *dm=NULL, *edm=NULL; | 
					
						
							|  |  |  | 	int glsl; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 	if(ob->mode & OB_MODE_EDIT) | 
					
						
							| 
									
										
										
										
											2009-05-16 16:18:08 +00:00
										 |  |  | 		edm= editbmesh_get_derived_base(ob, me->edit_btmesh); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	else  | 
					
						
							| 
									
										
										
										
											2009-01-04 14:14:06 +00:00
										 |  |  | 		dm = mesh_get_derived_final(scene, ob, CD_MASK_BAREMESH); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if(dt<=OB_WIRE) { | 
					
						
							|  |  |  | 		if(dm) | 
					
						
							| 
									
										
										
										
											2010-03-22 11:59:36 +00:00
										 |  |  | 			dm->drawEdges(dm, 1, 0); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		else if(edm) | 
					
						
							| 
									
										
										
										
											2010-03-22 11:59:36 +00:00
										 |  |  | 			edm->drawEdges(edm, 1, 0);	 | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		if(outline) | 
					
						
							|  |  |  | 			draw_mesh_object_outline(v3d, ob, dm?dm:edm); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if(dm) { | 
					
						
							|  |  |  | 			glsl = draw_glsl_material(scene, ob, v3d, dt); | 
					
						
							| 
									
										
										
										
											2009-07-13 00:40:20 +00:00
										 |  |  | 			GPU_begin_object_materials(v3d, rv3d, scene, ob, glsl, NULL); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							|  |  |  | 			glEnable(GL_COLOR_MATERIAL); | 
					
						
							|  |  |  | 			UI_ThemeColor(TH_BONE_SOLID); | 
					
						
							|  |  |  | 			glDisable(GL_COLOR_MATERIAL); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		glLightModeli(GL_LIGHT_MODEL_TWO_SIDE, 0); | 
					
						
							|  |  |  | 		glFrontFace((ob->transflag&OB_NEG_SCALE)?GL_CW:GL_CCW); | 
					
						
							|  |  |  | 		glEnable(GL_LIGHTING); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		if(dm) { | 
					
						
							| 
									
										
										
										
											2009-11-25 14:13:43 +00:00
										 |  |  | 			dm->drawFacesSolid(dm, NULL, 0, GPU_enable_material); | 
					
						
							| 
									
										
										
										
											2009-07-13 00:40:20 +00:00
										 |  |  | 			GPU_end_object_materials(); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		else if(edm) | 
					
						
							| 
									
										
										
										
											2011-12-01 12:12:39 +00:00
										 |  |  | 			edm->drawMappedFaces(edm, NULL, GPU_enable_material, NULL, NULL, 0); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		glDisable(GL_LIGHTING); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(edm) edm->release(edm); | 
					
						
							|  |  |  | 	if(dm) dm->release(dm); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | void draw_object_instance(Scene *scene, View3D *v3d, RegionView3D *rv3d, Object *ob, int dt, int outline) | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	if (ob == NULL)  | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 	switch (ob->type) { | 
					
						
							|  |  |  | 		case OB_MESH: | 
					
						
							| 
									
										
											  
											
												2.5
View3D has been split now in a local part (RegionView3D) and a
per-area part (old View3D). Currently local is:
- view transform
- camera zoom/offset
- gpencil (todo)
- custom clipping planes
Rest is in Area still, like active camera, draw type, layers,
localview, custom centers, around-settings, transform widget,
gridlines, and so on (mostly stuff as available in header).
To see it work; also added new feature for region split, 
press SHIFT+ALT+CTRL+S for four-split. 
The idea is to make a preset 4-split, configured to stick
to top/right/front views for three views.
Another cool idea to explore is to then box-clip all drawing
based on these 3 views.
Note about the code:
- currently view3d still stores some depricated settings, to
  convert from older files. Not all settings are copied over
  though, like custom clip planes or the 'lock view to object'.
- since some view3d ops are now on area level, the operators
  for it should keep track of that.
Bugfix in transform: quat initialize in operator-invoke missed
one zero.
Als brought back GE to compile for missing Ipos and channels.
											
										 
											2009-01-19 16:54:41 +00:00
										 |  |  | 			draw_object_mesh_instance(scene, v3d, rv3d, ob, dt, outline); | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			break; | 
					
						
							|  |  |  | 		case OB_EMPTY: | 
					
						
							| 
									
										
										
										
											2011-05-09 16:31:54 +00:00
										 |  |  | 			if (ob->empty_drawtype == OB_EMPTY_IMAGE) { | 
					
						
							|  |  |  | 				draw_empty_image(ob); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							|  |  |  | 				drawaxes(ob->empty_drawsize, ob->empty_drawtype); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2008-12-19 12:14:58 +00:00
										 |  |  | 			break; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } |