| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Copyright 2016, Blender Foundation. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is free software; you can redistribute it and/or | 
					
						
							|  |  |  |  * modify it under the terms of the GNU General Public License | 
					
						
							|  |  |  |  * as published by the Free Software Foundation; either version 2 | 
					
						
							|  |  |  |  * of the License, or (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |  * along with this program; if not, write to the Free Software Foundation, | 
					
						
							|  |  |  |  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Contributor(s): Blender Institute | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** \file blender/draw/modes/edit_metaball_mode.c
 | 
					
						
							|  |  |  |  *  \ingroup draw | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "DRW_engine.h"
 | 
					
						
							|  |  |  | #include "DRW_render.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* If builtin shaders are needed */ | 
					
						
							|  |  |  | #include "GPU_shader.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "draw_common.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "draw_mode_engines.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-18 22:14:53 +01:00
										 |  |  | /* If needed, contains all global/Theme colors
 | 
					
						
							|  |  |  |  * Add needed theme colors / values to DRW_globals_update() and update UBO | 
					
						
							|  |  |  |  * Not needed for constant color. */ | 
					
						
							|  |  |  | extern struct GPUUniformBuffer *globals_ubo; /* draw_common.c */ | 
					
						
							|  |  |  | extern struct GlobalsUboStorage ts; /* draw_common.c */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | /* *********** LISTS *********** */ | 
					
						
							|  |  |  | /* All lists are per viewport specific datas.
 | 
					
						
							|  |  |  |  * They are all free when viewport changes engines | 
					
						
							|  |  |  |  * or is free itself. Use EDIT_METABALL_engine_init() to | 
					
						
							|  |  |  |  * initialize most of them and EDIT_METABALL_cache_init() | 
					
						
							|  |  |  |  * for EDIT_METABALL_PassList */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* keep it under MAX_PASSES */ | 
					
						
							|  |  |  | typedef struct EDIT_METABALL_PassList { | 
					
						
							|  |  |  | 	/* Declare all passes here and init them in
 | 
					
						
							|  |  |  | 	 * EDIT_METABALL_cache_init(). | 
					
						
							|  |  |  | 	 * Only contains (DRWPass *) */ | 
					
						
							|  |  |  | 	struct DRWPass *pass; | 
					
						
							|  |  |  | } EDIT_METABALL_PassList; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* keep it under MAX_BUFFERS */ | 
					
						
							|  |  |  | typedef struct EDIT_METABALL_FramebufferList { | 
					
						
							|  |  |  | 	/* Contains all framebuffer objects needed by this engine.
 | 
					
						
							|  |  |  | 	 * Only contains (GPUFrameBuffer *) */ | 
					
						
							| 
									
										
										
										
											2017-03-13 11:39:41 +01:00
										 |  |  | 	struct GPUFrameBuffer *fb; | 
					
						
							| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | } EDIT_METABALL_FramebufferList; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* keep it under MAX_TEXTURES */ | 
					
						
							|  |  |  | typedef struct EDIT_METABALL_TextureList { | 
					
						
							|  |  |  | 	/* Contains all framebuffer textures / utility textures
 | 
					
						
							|  |  |  | 	 * needed by this engine. Only viewport specific textures | 
					
						
							|  |  |  | 	 * (not per object). Only contains (GPUTexture *) */ | 
					
						
							| 
									
										
										
										
											2017-03-13 11:39:41 +01:00
										 |  |  | 	struct GPUTexture *texture; | 
					
						
							| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | } EDIT_METABALL_TextureList; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* keep it under MAX_STORAGE */ | 
					
						
							|  |  |  | typedef struct EDIT_METABALL_StorageList { | 
					
						
							|  |  |  | 	/* Contains any other memory block that the engine needs.
 | 
					
						
							|  |  |  | 	 * Only directly MEM_(m/c)allocN'ed blocks because they are | 
					
						
							|  |  |  | 	 * free with MEM_freeN() when viewport is freed. | 
					
						
							|  |  |  | 	 * (not per object) */ | 
					
						
							| 
									
										
										
										
											2017-03-13 11:39:41 +01:00
										 |  |  | 	struct CustomStruct *block; | 
					
						
							| 
									
										
										
										
											2017-03-26 20:13:34 +02:00
										 |  |  | 	struct g_data *g_data; | 
					
						
							| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | } EDIT_METABALL_StorageList; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct EDIT_METABALL_Data { | 
					
						
							|  |  |  | 	/* Struct returned by DRW_viewport_engine_data_get.
 | 
					
						
							|  |  |  | 	 * If you don't use one of these, just make it a (void *) */ | 
					
						
							|  |  |  | 	// void *fbl;
 | 
					
						
							| 
									
										
										
										
											2017-04-03 19:32:05 +02:00
										 |  |  | 	void *engine_type; /* Required */ | 
					
						
							| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | 	EDIT_METABALL_FramebufferList *fbl; | 
					
						
							|  |  |  | 	EDIT_METABALL_TextureList *txl; | 
					
						
							|  |  |  | 	EDIT_METABALL_PassList *psl; | 
					
						
							|  |  |  | 	EDIT_METABALL_StorageList *stl; | 
					
						
							|  |  |  | } EDIT_METABALL_Data; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* *********** STATIC *********** */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-18 22:14:53 +01:00
										 |  |  | static struct { | 
					
						
							|  |  |  | 	/* Custom shaders :
 | 
					
						
							|  |  |  | 	 * Add sources to source/blender/draw/modes/shaders | 
					
						
							|  |  |  | 	 * init in EDIT_METABALL_engine_init(); | 
					
						
							|  |  |  | 	 * free in EDIT_METABALL_engine_free(); */ | 
					
						
							|  |  |  | 	struct GPUShader *custom_shader; | 
					
						
							|  |  |  | } e_data = {NULL}; /* Engine data */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-26 20:13:34 +02:00
										 |  |  | typedef struct g_data { | 
					
						
							| 
									
										
										
										
											2017-03-18 22:14:53 +01:00
										 |  |  | 	/* This keeps the references of the shading groups for
 | 
					
						
							|  |  |  | 	 * easy access in EDIT_METABALL_cache_populate() */ | 
					
						
							|  |  |  | 	DRWShadingGroup *group; | 
					
						
							| 
									
										
										
										
											2017-03-26 20:13:34 +02:00
										 |  |  | } g_data; /* Transient data */ | 
					
						
							| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* *********** FUNCTIONS *********** */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Init Textures, Framebuffers, Storage and Shaders.
 | 
					
						
							|  |  |  |  * It is called for every frames. | 
					
						
							| 
									
										
										
										
											2017-03-14 18:40:23 +11:00
										 |  |  |  * (Optional) */ | 
					
						
							| 
									
										
										
										
											2017-03-26 19:10:53 +02:00
										 |  |  | static void EDIT_METABALL_engine_init(void *vedata) | 
					
						
							| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2017-03-26 20:13:34 +02:00
										 |  |  | 	EDIT_METABALL_TextureList *txl = ((EDIT_METABALL_Data *)vedata)->txl; | 
					
						
							| 
									
										
										
										
											2017-03-26 19:10:53 +02:00
										 |  |  | 	EDIT_METABALL_FramebufferList *fbl = ((EDIT_METABALL_Data *)vedata)->fbl; | 
					
						
							| 
									
										
										
										
											2017-03-26 20:13:34 +02:00
										 |  |  | 	EDIT_METABALL_StorageList *stl = ((EDIT_METABALL_Data *)vedata)->stl; | 
					
						
							| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-14 18:40:23 +11:00
										 |  |  | 	UNUSED_VARS(txl, fbl, stl); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | 	/* Init Framebuffers like this: order is attachment order (for color texs) */ | 
					
						
							|  |  |  | 	/*
 | 
					
						
							|  |  |  | 	 * DRWFboTexture tex[2] = {{&txl->depth, DRW_BUF_DEPTH_24}, | 
					
						
							|  |  |  | 	 *                         {&txl->color, DRW_BUF_RGBA_8}}; | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* DRW_framebuffer_init takes care of checking if
 | 
					
						
							|  |  |  | 	 * the framebuffer is valid and has the right size*/ | 
					
						
							|  |  |  | 	/*
 | 
					
						
							|  |  |  | 	 * float *viewport_size = DRW_viewport_size_get(); | 
					
						
							|  |  |  | 	 * DRW_framebuffer_init(&fbl->occlude_wire_fb, | 
					
						
							|  |  |  | 	 *                     (int)viewport_size[0], (int)viewport_size[1], | 
					
						
							|  |  |  | 	 *                     tex, 2); | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-18 22:14:53 +01:00
										 |  |  | 	if (!e_data.custom_shader) { | 
					
						
							|  |  |  | 		e_data.custom_shader = GPU_shader_get_builtin_shader(GPU_SHADER_3D_UNIFORM_COLOR); | 
					
						
							| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Here init all passes and shading groups
 | 
					
						
							|  |  |  |  * Assume that all Passes are NULL */ | 
					
						
							| 
									
										
										
										
											2017-03-26 19:10:53 +02:00
										 |  |  | static void EDIT_METABALL_cache_init(void *vedata) | 
					
						
							| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2017-03-26 19:10:53 +02:00
										 |  |  | 	EDIT_METABALL_PassList *psl = ((EDIT_METABALL_Data *)vedata)->psl; | 
					
						
							|  |  |  | 	EDIT_METABALL_StorageList *stl = ((EDIT_METABALL_Data *)vedata)->stl; | 
					
						
							| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-26 20:13:34 +02:00
										 |  |  | 	if (!stl->g_data) { | 
					
						
							|  |  |  | 		/* Alloc transient pointers */ | 
					
						
							|  |  |  | 		stl->g_data = MEM_mallocN(sizeof(g_data), "g_data"); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2017-03-14 18:40:23 +11:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		/* Create a pass */ | 
					
						
							|  |  |  | 		DRWState state = DRW_STATE_WRITE_COLOR | DRW_STATE_WRITE_DEPTH | DRW_STATE_DEPTH_LESS | DRW_STATE_BLEND | DRW_STATE_WIRE; | 
					
						
							|  |  |  | 		psl->pass = DRW_pass_create("My Pass", state); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* Create a shadingGroup using a function in draw_common.c or custom one */ | 
					
						
							|  |  |  | 		/*
 | 
					
						
							| 
									
										
										
										
											2017-03-26 20:13:34 +02:00
										 |  |  | 		 * stl->g_data->group = shgroup_dynlines_uniform_color(psl->pass, ts.colorWire); | 
					
						
							| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | 		 * -- or -- | 
					
						
							| 
									
										
										
										
											2017-03-26 20:13:34 +02:00
										 |  |  | 		 * stl->g_data->group = DRW_shgroup_create(e_data.custom_shader, psl->pass); | 
					
						
							| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | 		 */ | 
					
						
							| 
									
										
										
										
											2017-03-26 20:13:34 +02:00
										 |  |  | 		stl->g_data->group = DRW_shgroup_create(e_data.custom_shader, psl->pass); | 
					
						
							| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* Uniforms need a pointer to it's value so be sure it's accessible at
 | 
					
						
							|  |  |  | 		 * any given time (i.e. use static vars) */ | 
					
						
							|  |  |  | 		static float color[4] = {0.0f, 1.0f, 0.0f, 1.0}; | 
					
						
							| 
									
										
										
										
											2017-03-26 20:13:34 +02:00
										 |  |  | 		DRW_shgroup_uniform_vec4(stl->g_data->group, "color", color, 1); | 
					
						
							| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Add geometry to shadingGroups. Execute for each objects */ | 
					
						
							| 
									
										
										
										
											2017-03-26 19:10:53 +02:00
										 |  |  | static void EDIT_METABALL_cache_populate(void *vedata, Object *ob) | 
					
						
							| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2017-03-26 19:10:53 +02:00
										 |  |  | 	EDIT_METABALL_PassList *psl = ((EDIT_METABALL_Data *)vedata)->psl; | 
					
						
							|  |  |  | 	EDIT_METABALL_StorageList *stl = ((EDIT_METABALL_Data *)vedata)->stl; | 
					
						
							| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-14 18:40:23 +11:00
										 |  |  | 	UNUSED_VARS(psl, stl); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | 	if (ob->type == OB_MESH) { | 
					
						
							|  |  |  | 		/* Get geometry cache */ | 
					
						
							|  |  |  | 		struct Batch *geom = DRW_cache_surface_get(ob); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* Add geom to a shading group */ | 
					
						
							| 
									
										
										
										
											2017-03-26 20:13:34 +02:00
										 |  |  | 		DRW_shgroup_call_add(stl->g_data->group, geom, ob->obmat); | 
					
						
							| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-14 18:40:23 +11:00
										 |  |  | /* Optional: Post-cache_populate callback */ | 
					
						
							| 
									
										
										
										
											2017-03-26 19:10:53 +02:00
										 |  |  | static void EDIT_METABALL_cache_finish(void *vedata) | 
					
						
							| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2017-03-26 19:10:53 +02:00
										 |  |  | 	EDIT_METABALL_PassList *psl = ((EDIT_METABALL_Data *)vedata)->psl; | 
					
						
							|  |  |  | 	EDIT_METABALL_StorageList *stl = ((EDIT_METABALL_Data *)vedata)->stl; | 
					
						
							| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* Do something here! dependant on the objects gathered */ | 
					
						
							| 
									
										
										
										
											2017-03-14 18:40:23 +11:00
										 |  |  | 	UNUSED_VARS(psl, stl); | 
					
						
							| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Draw time ! Control rendering pipeline from here */ | 
					
						
							| 
									
										
										
										
											2017-03-26 19:10:53 +02:00
										 |  |  | static void EDIT_METABALL_draw_scene(void *vedata) | 
					
						
							| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2017-03-26 19:10:53 +02:00
										 |  |  | 	EDIT_METABALL_PassList *psl = ((EDIT_METABALL_Data *)vedata)->psl; | 
					
						
							|  |  |  | 	EDIT_METABALL_FramebufferList *fbl = ((EDIT_METABALL_Data *)vedata)->fbl; | 
					
						
							| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* Default framebuffer and texture */ | 
					
						
							|  |  |  | 	DefaultFramebufferList *dfbl = DRW_viewport_framebuffer_list_get(); | 
					
						
							|  |  |  | 	DefaultTextureList *dtxl = DRW_viewport_texture_list_get(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-14 18:40:23 +11:00
										 |  |  | 	UNUSED_VARS(fbl, dfbl, dtxl); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | 	/* Show / hide entire passes, swap framebuffers ... whatever you fancy */ | 
					
						
							|  |  |  | 	/*
 | 
					
						
							|  |  |  | 	 * DRW_framebuffer_texture_detach(dtxl->depth); | 
					
						
							|  |  |  | 	 * DRW_framebuffer_bind(fbl->custom_fb); | 
					
						
							|  |  |  | 	 * DRW_draw_pass(psl->pass); | 
					
						
							|  |  |  | 	 * DRW_framebuffer_texture_attach(dfbl->default_fb, dtxl->depth, 0); | 
					
						
							|  |  |  | 	 * DRW_framebuffer_bind(dfbl->default_fb); | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* ... or just render passes on default framebuffer. */ | 
					
						
							|  |  |  | 	DRW_draw_pass(psl->pass); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* If you changed framebuffer, double check you rebind
 | 
					
						
							|  |  |  | 	 * the default one with its textures attached before finishing */ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Cleanup when destroying the engine.
 | 
					
						
							|  |  |  |  * This is not per viewport ! only when quitting blender. | 
					
						
							|  |  |  |  * Mostly used for freeing shaders */ | 
					
						
							|  |  |  | static void EDIT_METABALL_engine_free(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	// if (custom_shader)
 | 
					
						
							|  |  |  | 	// 	DRW_shader_free(custom_shader);
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Create collection settings here.
 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Be sure to add this function there : | 
					
						
							|  |  |  |  * source/blender/draw/DRW_engine.h | 
					
						
							|  |  |  |  * source/blender/blenkernel/intern/layer.c | 
					
						
							|  |  |  |  * source/blenderplayer/bad_level_call_stubs/stubs.c | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * And relevant collection settings to : | 
					
						
							|  |  |  |  * source/blender/makesrna/intern/rna_scene.c | 
					
						
							|  |  |  |  * source/blender/blenkernel/intern/layer.c | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-03-14 18:40:23 +11:00
										 |  |  | #if 0
 | 
					
						
							| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | void EDIT_METABALL_collection_settings_create(CollectionEngineSettings *ces) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	BLI_assert(ces); | 
					
						
							|  |  |  | 	// BKE_collection_engine_property_add_int(ces, "my_bool_prop", false);
 | 
					
						
							|  |  |  | 	// BKE_collection_engine_property_add_int(ces, "my_int_prop", 0);
 | 
					
						
							|  |  |  | 	// BKE_collection_engine_property_add_float(ces, "my_float_prop", 0.0f);
 | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2017-03-14 18:40:23 +11:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2017-03-12 21:16:03 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | DrawEngineType draw_engine_edit_metaball_type = { | 
					
						
							|  |  |  | 	NULL, NULL, | 
					
						
							|  |  |  | 	N_("EditMetaballMode"), | 
					
						
							|  |  |  | 	&EDIT_METABALL_engine_init, | 
					
						
							|  |  |  | 	&EDIT_METABALL_engine_free, | 
					
						
							|  |  |  | 	&EDIT_METABALL_cache_init, | 
					
						
							|  |  |  | 	&EDIT_METABALL_cache_populate, | 
					
						
							|  |  |  | 	&EDIT_METABALL_cache_finish, | 
					
						
							|  |  |  | 	NULL, /* draw_background but not needed by mode engines */ | 
					
						
							|  |  |  | 	&EDIT_METABALL_draw_scene | 
					
						
							|  |  |  | }; |