| 
									
										
										
										
											2015-12-06 21:20:19 +01:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * ***** BEGIN GPL LICENSE BLOCK ***** | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is free software; you can redistribute it and/or | 
					
						
							|  |  |  |  * modify it under the terms of the GNU General Public License | 
					
						
							|  |  |  |  * as published by the Free Software Foundation; either version 2 | 
					
						
							|  |  |  |  * of the License, or (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |  * along with this program; if not, write to the Free Software Foundation, | 
					
						
							|  |  |  |  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is Copyright (C) 2005 Blender Foundation. | 
					
						
							|  |  |  |  * All rights reserved. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is: all of this file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Contributor(s): Brecht Van Lommel. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * ***** END GPL LICENSE BLOCK ***** | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** \file GPU_texture.h
 | 
					
						
							|  |  |  |  *  \ingroup gpu | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef __GPU_TEXTURE_H__
 | 
					
						
							|  |  |  | #define __GPU_TEXTURE_H__
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | extern "C" { | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct Image; | 
					
						
							|  |  |  | struct ImageUser; | 
					
						
							|  |  |  | struct PreviewImage; | 
					
						
							| 
									
										
										
										
											2018-05-13 22:12:32 +02:00
										 |  |  | struct Gwn_VertBuf; | 
					
						
							| 
									
										
										
										
											2018-06-04 09:09:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-23 20:39:03 +01:00
										 |  |  | struct GPUFrameBuffer; | 
					
						
							| 
									
										
										
										
											2015-12-06 21:20:19 +01:00
										 |  |  | typedef struct GPUTexture GPUTexture; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* GPU Texture
 | 
					
						
							|  |  |  |  * - always returns unsigned char RGBA textures | 
					
						
							|  |  |  |  * - if texture with non square dimensions is created, depending on the | 
					
						
							|  |  |  |  *   graphics card capabilities the texture may actually be stored in a | 
					
						
							|  |  |  |  *   larger texture with power of two dimensions. | 
					
						
							|  |  |  |  * - can use reference counting: | 
					
						
							|  |  |  |  *     - reference counter after GPU_texture_create is 1 | 
					
						
							|  |  |  |  *     - GPU_texture_ref increases by one | 
					
						
							|  |  |  |  *     - GPU_texture_free decreases by one, and frees if 0 | 
					
						
							|  |  |  |  *  - if created with from_blender, will not free the texture | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-03 16:01:32 +01:00
										 |  |  | /* Wrapper to supported OpenGL/Vulkan texture internal storage
 | 
					
						
							|  |  |  |  * If you need a type just uncomment it. Be aware that some formats | 
					
						
							|  |  |  |  * are not supported by renderbuffers. All of the following formats | 
					
						
							|  |  |  |  * are part of the OpenGL 3.3 core | 
					
						
							|  |  |  |  * specification. */ | 
					
						
							|  |  |  | typedef enum GPUTextureFormat { | 
					
						
							|  |  |  | 	/* Formats texture & renderbuffer */ | 
					
						
							| 
									
										
										
										
											2018-05-13 22:12:32 +02:00
										 |  |  | 	GPU_RGBA8UI, | 
					
						
							|  |  |  | 	GPU_RGBA8I, | 
					
						
							|  |  |  | 	GPU_RGBA8, | 
					
						
							|  |  |  | 	GPU_RGBA32UI, | 
					
						
							|  |  |  | 	GPU_RGBA32I, | 
					
						
							| 
									
										
										
										
											2017-05-09 21:49:30 +02:00
										 |  |  | 	GPU_RGBA32F, | 
					
						
							| 
									
										
										
										
											2018-05-13 22:12:32 +02:00
										 |  |  | 	GPU_RGBA16UI, | 
					
						
							|  |  |  | 	GPU_RGBA16I, | 
					
						
							| 
									
										
										
										
											2017-02-03 16:01:32 +01:00
										 |  |  | 	GPU_RGBA16F, | 
					
						
							| 
									
										
										
										
											2018-05-13 22:12:32 +02:00
										 |  |  | 	GPU_RGBA16, | 
					
						
							|  |  |  | 	GPU_RG8UI, | 
					
						
							|  |  |  | 	GPU_RG8I, | 
					
						
							|  |  |  | 	GPU_RG8, | 
					
						
							|  |  |  | 	GPU_RG32UI, | 
					
						
							|  |  |  | 	GPU_RG32I, | 
					
						
							| 
									
										
										
										
											2017-02-03 16:01:32 +01:00
										 |  |  | 	GPU_RG32F, | 
					
						
							| 
									
										
										
										
											2018-05-13 22:12:32 +02:00
										 |  |  | 	GPU_RG16UI, | 
					
						
							| 
									
										
										
										
											2018-01-13 17:14:01 +01:00
										 |  |  | 	GPU_RG16I, | 
					
						
							| 
									
										
										
										
											2018-05-13 22:12:32 +02:00
										 |  |  | 	GPU_RG16F, | 
					
						
							| 
									
										
										
										
											2018-04-30 16:15:01 +02:00
										 |  |  | 	GPU_RG16, | 
					
						
							| 
									
										
										
										
											2018-05-13 22:12:32 +02:00
										 |  |  | 	GPU_R8UI, | 
					
						
							|  |  |  | 	GPU_R8I, | 
					
						
							| 
									
										
										
										
											2017-02-03 16:01:32 +01:00
										 |  |  | 	GPU_R8, | 
					
						
							| 
									
										
										
										
											2018-05-13 22:12:32 +02:00
										 |  |  | 	GPU_R32UI, | 
					
						
							| 
									
										
										
										
											2017-02-03 16:01:32 +01:00
										 |  |  | 	GPU_R32I, | 
					
						
							| 
									
										
										
										
											2018-05-13 22:12:32 +02:00
										 |  |  | 	GPU_R32F, | 
					
						
							|  |  |  | 	GPU_R16UI, | 
					
						
							|  |  |  | 	GPU_R16I, | 
					
						
							|  |  |  | 	GPU_R16F, | 
					
						
							|  |  |  | 	GPU_R16, /* Max texture buffer format. */ | 
					
						
							| 
									
										
										
										
											2017-02-03 16:01:32 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* Special formats texture & renderbuffer */ | 
					
						
							|  |  |  | #if 0
 | 
					
						
							|  |  |  | 	GPU_RGB10_A2, | 
					
						
							|  |  |  | 	GPU_RGB10_A2UI, | 
					
						
							|  |  |  | 	GPU_DEPTH32F_STENCIL8, | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2017-05-16 20:18:57 +02:00
										 |  |  | 	GPU_R11F_G11F_B10F, | 
					
						
							| 
									
										
										
										
											2017-03-18 01:26:08 +01:00
										 |  |  | 	GPU_DEPTH24_STENCIL8, | 
					
						
							| 
									
										
										
										
											2017-02-03 16:01:32 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* Texture only format */ | 
					
						
							| 
									
										
										
										
											2017-04-18 12:50:09 +02:00
										 |  |  | 	GPU_RGB16F, | 
					
						
							| 
									
										
										
										
											2017-02-03 16:01:32 +01:00
										 |  |  | #if 0
 | 
					
						
							|  |  |  | 	GPU_RGBA16_SNORM, | 
					
						
							|  |  |  | 	GPU_RGBA8_SNORM, | 
					
						
							|  |  |  | 	GPU_RGB32F, | 
					
						
							|  |  |  | 	GPU_RGB32I, | 
					
						
							|  |  |  | 	GPU_RGB32UI, | 
					
						
							|  |  |  | 	GPU_RGB16_SNORM, | 
					
						
							|  |  |  | 	GPU_RGB16I, | 
					
						
							|  |  |  | 	GPU_RGB16UI, | 
					
						
							|  |  |  | 	GPU_RGB16, | 
					
						
							|  |  |  | 	GPU_RGB8_SNORM, | 
					
						
							|  |  |  | 	GPU_RGB8, | 
					
						
							|  |  |  | 	GPU_RGB8I, | 
					
						
							|  |  |  | 	GPU_RGB8UI, | 
					
						
							|  |  |  | 	GPU_RG16_SNORM, | 
					
						
							|  |  |  | 	GPU_RG8_SNORM, | 
					
						
							|  |  |  | 	GPU_R16_SNORM, | 
					
						
							|  |  |  | 	GPU_R8_SNORM, | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Special formats texture only */ | 
					
						
							|  |  |  | #if 0
 | 
					
						
							|  |  |  | 	GPU_SRGB8_A8, | 
					
						
							|  |  |  | 	GPU_SRGB8, | 
					
						
							|  |  |  | 	GPU_RGB9_E5, | 
					
						
							|  |  |  | 	GPU_COMPRESSED_RG_RGTC2, | 
					
						
							|  |  |  | 	GPU_COMPRESSED_SIGNED_RG_RGTC2, | 
					
						
							|  |  |  | 	GPU_COMPRESSED_RED_RGTC1, | 
					
						
							|  |  |  | 	GPU_COMPRESSED_SIGNED_RED_RGTC1, | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Depth Formats */ | 
					
						
							|  |  |  | 	GPU_DEPTH_COMPONENT32F, | 
					
						
							|  |  |  | 	GPU_DEPTH_COMPONENT24, | 
					
						
							|  |  |  | 	GPU_DEPTH_COMPONENT16, | 
					
						
							|  |  |  | } GPUTextureFormat; | 
					
						
							| 
									
										
										
										
											2015-12-06 21:20:19 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-04 21:22:41 +02:00
										 |  |  | unsigned int GPU_texture_memory_usage_get(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-30 16:02:24 +02:00
										 |  |  | GPUTexture *GPU_texture_create_1D( | 
					
						
							|  |  |  |         int w, GPUTextureFormat data_type, const float *pixels, char err_out[256]); | 
					
						
							|  |  |  | GPUTexture *GPU_texture_create_2D( | 
					
						
							|  |  |  |         int w, int h, GPUTextureFormat data_type, const float *pixels, char err_out[256]); | 
					
						
							|  |  |  | GPUTexture *GPU_texture_create_2D_multisample( | 
					
						
							|  |  |  |         int w, int h, GPUTextureFormat data_type, const float *pixels, int samples, char err_out[256]); | 
					
						
							|  |  |  | GPUTexture *GPU_texture_create_2D_array( | 
					
						
							|  |  |  |         int w, int h, int d, GPUTextureFormat data_type, const float *pixels, char err_out[256]); | 
					
						
							|  |  |  | GPUTexture *GPU_texture_create_3D( | 
					
						
							|  |  |  |         int w, int h, int d, GPUTextureFormat data_type, const float *pixels, char err_out[256]); | 
					
						
							|  |  |  | GPUTexture *GPU_texture_create_cube( | 
					
						
							|  |  |  |         int w, GPUTextureFormat data_type, const float *pixels, char err_out[256]); | 
					
						
							| 
									
										
										
										
											2018-05-31 18:34:17 +02:00
										 |  |  | GPUTexture *GPU_texture_create_from_vertbuf( | 
					
						
							|  |  |  |         struct Gwn_VertBuf *vert); | 
					
						
							|  |  |  | GPUTexture *GPU_texture_create_buffer( | 
					
						
							|  |  |  |         GPUTextureFormat data_type, const uint buffer); | 
					
						
							| 
									
										
										
										
											2017-02-03 16:01:32 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-10 07:12:10 +11:00
										 |  |  | GPUTexture *GPU_texture_from_blender( | 
					
						
							| 
									
										
										
										
											2016-01-28 17:23:12 +11:00
										 |  |  |         struct Image *ima, struct ImageUser *iuser, int textarget, bool is_data, double time, int mipmap); | 
					
						
							| 
									
										
										
										
											2015-12-06 21:20:19 +01:00
										 |  |  | GPUTexture *GPU_texture_from_preview(struct PreviewImage *prv, int mipmap); | 
					
						
							| 
									
										
										
										
											2017-02-03 16:01:32 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-22 10:22:11 +02:00
										 |  |  | void GPU_texture_update(GPUTexture *tex, const float *pixels); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-06 21:20:19 +01:00
										 |  |  | void GPU_invalid_tex_init(void); | 
					
						
							|  |  |  | void GPU_invalid_tex_bind(int mode); | 
					
						
							|  |  |  | void GPU_invalid_tex_free(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void GPU_texture_free(GPUTexture *tex); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-02 21:16:23 +02:00
										 |  |  | void GPU_texture_init_orphans(void); | 
					
						
							|  |  |  | void GPU_texture_exit_orphans(void); | 
					
						
							|  |  |  | /* This has to be called from a thread with an ogl context bound. */ | 
					
						
							|  |  |  | void GPU_texture_delete_orphans(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-06 21:20:19 +01:00
										 |  |  | void GPU_texture_ref(GPUTexture *tex); | 
					
						
							|  |  |  | void GPU_texture_bind(GPUTexture *tex, int number); | 
					
						
							|  |  |  | void GPU_texture_unbind(GPUTexture *tex); | 
					
						
							|  |  |  | int GPU_texture_bound_number(GPUTexture *tex); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-18 11:21:17 +02:00
										 |  |  | void GPU_texture_generate_mipmap(GPUTexture *tex); | 
					
						
							| 
									
										
										
										
											2017-02-03 16:01:32 +01:00
										 |  |  | void GPU_texture_compare_mode(GPUTexture *tex, bool use_compare); | 
					
						
							|  |  |  | void GPU_texture_filter_mode(GPUTexture *tex, bool use_filter); | 
					
						
							| 
									
										
										
										
											2017-06-22 01:53:51 +02:00
										 |  |  | void GPU_texture_mipmap_mode(GPUTexture *tex, bool use_mipmap, bool use_filter); | 
					
						
							| 
									
										
										
										
											2017-02-03 16:01:32 +01:00
										 |  |  | void GPU_texture_wrap_mode(GPUTexture *tex, bool use_repeat); | 
					
						
							| 
									
										
										
										
											2015-12-06 21:20:19 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-25 17:46:48 +02:00
										 |  |  | void GPU_texture_attach_framebuffer(GPUTexture *tex, struct GPUFrameBuffer *fb, int attachment); | 
					
						
							|  |  |  | int GPU_texture_detach_framebuffer(GPUTexture *tex, struct GPUFrameBuffer *fb); | 
					
						
							| 
									
										
										
										
											2015-12-06 21:20:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | int GPU_texture_target(const GPUTexture *tex); | 
					
						
							|  |  |  | int GPU_texture_width(const GPUTexture *tex); | 
					
						
							|  |  |  | int GPU_texture_height(const GPUTexture *tex); | 
					
						
							| 
									
										
										
										
											2018-03-24 20:27:39 +01:00
										 |  |  | GPUTextureFormat GPU_texture_format(const GPUTexture *tex); | 
					
						
							| 
									
										
										
										
											2018-03-14 03:20:39 +01:00
										 |  |  | int GPU_texture_samples(const GPUTexture *tex); | 
					
						
							| 
									
										
										
										
											2018-03-24 20:27:39 +01:00
										 |  |  | bool GPU_texture_cube(const GPUTexture *tex); | 
					
						
							| 
									
										
										
										
											2017-03-18 01:26:08 +01:00
										 |  |  | bool GPU_texture_depth(const GPUTexture *tex); | 
					
						
							|  |  |  | bool GPU_texture_stencil(const GPUTexture *tex); | 
					
						
							| 
									
										
										
										
											2018-03-24 20:27:39 +01:00
										 |  |  | bool GPU_texture_integer(const GPUTexture *tex); | 
					
						
							| 
									
										
										
										
											2015-12-06 21:20:19 +01:00
										 |  |  | int GPU_texture_opengl_bindcode(const GPUTexture *tex); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif  /* __GPU_TEXTURE_H__ */
 |