2015-12-06 21:20:19 +01:00
|
|
|
/*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
2019-02-18 08:08:12 +11:00
|
|
|
/** \file
|
|
|
|
* \ingroup gpu
|
2015-12-06 21:20:19 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __GPU_TEXTURE_H__
|
|
|
|
#define __GPU_TEXTURE_H__
|
|
|
|
|
2020-07-28 16:32:30 +02:00
|
|
|
#include "BLI_utildefines.h"
|
2018-06-26 15:17:31 -06:00
|
|
|
#include "GPU_state.h"
|
|
|
|
|
2019-01-28 21:08:24 +11:00
|
|
|
struct GPUVertBuf;
|
2020-02-10 10:08:31 +11:00
|
|
|
struct ImBuf;
|
2015-12-06 21:20:19 +01:00
|
|
|
struct Image;
|
|
|
|
struct ImageUser;
|
2019-04-02 16:05:22 +02:00
|
|
|
struct MovieClip;
|
|
|
|
struct MovieClipUser;
|
2015-12-06 21:20:19 +01:00
|
|
|
struct PreviewImage;
|
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;
|
|
|
|
|
2020-06-02 10:47:45 +02:00
|
|
|
/* GPU Samplers state
|
|
|
|
* - Specify the sampler state to bind a texture with.
|
|
|
|
* - Internally used by textures.
|
|
|
|
* - All states are created at startup to avoid runtime costs.
|
|
|
|
*/
|
|
|
|
|
|
|
|
typedef enum eGPUSamplerState {
|
|
|
|
GPU_SAMPLER_FILTER = (1 << 0),
|
|
|
|
GPU_SAMPLER_MIPMAP = (1 << 1),
|
|
|
|
GPU_SAMPLER_REPEAT_S = (1 << 2),
|
|
|
|
GPU_SAMPLER_REPEAT_T = (1 << 3),
|
|
|
|
GPU_SAMPLER_REPEAT_R = (1 << 4),
|
|
|
|
GPU_SAMPLER_CLAMP_BORDER = (1 << 5), /* Clamp to border color instead of border texel. */
|
|
|
|
GPU_SAMPLER_COMPARE = (1 << 6),
|
|
|
|
GPU_SAMPLER_ANISO = (1 << 7),
|
|
|
|
/* Don't use that. */
|
|
|
|
GPU_SAMPLER_MAX = (1 << 8),
|
|
|
|
} eGPUSamplerState;
|
|
|
|
|
2020-07-28 16:32:30 +02:00
|
|
|
ENUM_OPERATORS(eGPUSamplerState)
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2020-06-02 10:47:45 +02:00
|
|
|
#define GPU_SAMPLER_DEFAULT GPU_SAMPLER_FILTER
|
|
|
|
#define GPU_SAMPLER_REPEAT (GPU_SAMPLER_REPEAT_S | GPU_SAMPLER_REPEAT_T | GPU_SAMPLER_REPEAT_R)
|
|
|
|
|
|
|
|
void GPU_samplers_init(void);
|
|
|
|
void GPU_samplers_free(void);
|
|
|
|
|
2015-12-06 21:20:19 +01:00
|
|
|
/* 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:
|
2018-11-14 12:53:15 +11:00
|
|
|
* - 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
|
2015-12-06 21:20:19 +01:00
|
|
|
*/
|
|
|
|
|
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. */
|
2019-01-23 14:15:43 +11:00
|
|
|
typedef enum eGPUTextureFormat {
|
2019-04-17 06:17:24 +02:00
|
|
|
/* Formats texture & renderbuffer */
|
|
|
|
GPU_RGBA8UI,
|
|
|
|
GPU_RGBA8I,
|
|
|
|
GPU_RGBA8,
|
|
|
|
GPU_RGBA32UI,
|
|
|
|
GPU_RGBA32I,
|
|
|
|
GPU_RGBA32F,
|
|
|
|
GPU_RGBA16UI,
|
|
|
|
GPU_RGBA16I,
|
|
|
|
GPU_RGBA16F,
|
|
|
|
GPU_RGBA16,
|
|
|
|
GPU_RG8UI,
|
|
|
|
GPU_RG8I,
|
|
|
|
GPU_RG8,
|
|
|
|
GPU_RG32UI,
|
|
|
|
GPU_RG32I,
|
|
|
|
GPU_RG32F,
|
|
|
|
GPU_RG16UI,
|
|
|
|
GPU_RG16I,
|
|
|
|
GPU_RG16F,
|
|
|
|
GPU_RG16,
|
|
|
|
GPU_R8UI,
|
|
|
|
GPU_R8I,
|
|
|
|
GPU_R8,
|
|
|
|
GPU_R32UI,
|
|
|
|
GPU_R32I,
|
|
|
|
GPU_R32F,
|
|
|
|
GPU_R16UI,
|
|
|
|
GPU_R16I,
|
|
|
|
GPU_R16F,
|
|
|
|
GPU_R16, /* Max texture buffer format. */
|
|
|
|
|
|
|
|
/* Special formats texture & renderbuffer */
|
2017-02-03 16:01:32 +01:00
|
|
|
#if 0
|
2019-04-17 06:17:24 +02:00
|
|
|
GPU_RGB10_A2,
|
|
|
|
GPU_RGB10_A2UI,
|
2020-03-09 16:27:24 +01:00
|
|
|
GPU_SRGB8_A8,
|
2017-02-03 16:01:32 +01:00
|
|
|
#endif
|
2019-04-17 06:17:24 +02:00
|
|
|
GPU_R11F_G11F_B10F,
|
|
|
|
GPU_DEPTH32F_STENCIL8,
|
|
|
|
GPU_DEPTH24_STENCIL8,
|
2020-02-11 15:18:55 +01:00
|
|
|
GPU_SRGB8_A8,
|
2017-02-03 16:01:32 +01:00
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
/* Texture only format */
|
|
|
|
GPU_RGB16F,
|
2017-02-03 16:01:32 +01:00
|
|
|
#if 0
|
2019-04-17 06:17:24 +02:00
|
|
|
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,
|
2017-02-03 16:01:32 +01:00
|
|
|
#endif
|
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
/* Special formats texture only */
|
2017-02-03 16:01:32 +01:00
|
|
|
#if 0
|
2019-04-17 06:17:24 +02:00
|
|
|
GPU_SRGB8,
|
|
|
|
GPU_RGB9_E5,
|
|
|
|
GPU_COMPRESSED_RG_RGTC2,
|
|
|
|
GPU_COMPRESSED_SIGNED_RG_RGTC2,
|
|
|
|
GPU_COMPRESSED_RED_RGTC1,
|
|
|
|
GPU_COMPRESSED_SIGNED_RED_RGTC1,
|
2017-02-03 16:01:32 +01:00
|
|
|
#endif
|
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
/* Depth Formats */
|
|
|
|
GPU_DEPTH_COMPONENT32F,
|
|
|
|
GPU_DEPTH_COMPONENT24,
|
|
|
|
GPU_DEPTH_COMPONENT16,
|
2019-01-23 14:15:43 +11:00
|
|
|
} eGPUTextureFormat;
|
2015-12-06 21:20:19 +01:00
|
|
|
|
2019-01-23 14:15:43 +11:00
|
|
|
typedef enum eGPUDataFormat {
|
2019-04-17 06:17:24 +02:00
|
|
|
GPU_DATA_FLOAT,
|
|
|
|
GPU_DATA_INT,
|
|
|
|
GPU_DATA_UNSIGNED_INT,
|
|
|
|
GPU_DATA_UNSIGNED_BYTE,
|
|
|
|
GPU_DATA_UNSIGNED_INT_24_8,
|
|
|
|
GPU_DATA_10_11_11_REV,
|
2019-01-23 14:15:43 +11:00
|
|
|
} eGPUDataFormat;
|
2018-07-10 13:17:32 +02:00
|
|
|
|
2017-05-04 21:22:41 +02:00
|
|
|
unsigned int GPU_texture_memory_usage_get(void);
|
|
|
|
|
2019-01-23 14:15:43 +11:00
|
|
|
/* TODO make it static function again. (create function with eGPUDataFormat exposed) */
|
2019-04-17 06:17:24 +02:00
|
|
|
GPUTexture *GPU_texture_create_nD(int w,
|
|
|
|
int h,
|
|
|
|
int d,
|
|
|
|
int n,
|
|
|
|
const void *pixels,
|
|
|
|
eGPUTextureFormat tex_format,
|
|
|
|
eGPUDataFormat gpu_data_format,
|
|
|
|
int samples,
|
|
|
|
const bool can_rescale,
|
|
|
|
char err_out[256]);
|
2020-03-11 17:12:01 +01:00
|
|
|
GPUTexture *GPU_texture_cube_create(int w,
|
|
|
|
int d,
|
|
|
|
const void *pixels,
|
|
|
|
eGPUTextureFormat tex_format,
|
|
|
|
eGPUDataFormat gpu_data_format,
|
|
|
|
char err_out[256]);
|
2018-07-10 13:17:32 +02:00
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
GPUTexture *GPU_texture_create_1d(int w,
|
|
|
|
eGPUTextureFormat data_type,
|
|
|
|
const float *pixels,
|
|
|
|
char err_out[256]);
|
2019-03-20 18:17:16 +11:00
|
|
|
GPUTexture *GPU_texture_create_1d_array(
|
2019-04-17 06:17:24 +02:00
|
|
|
int w, int h, eGPUTextureFormat data_type, const float *pixels, char err_out[256]);
|
2019-03-20 18:17:16 +11:00
|
|
|
GPUTexture *GPU_texture_create_2d(
|
2019-04-17 06:17:24 +02:00
|
|
|
int w, int h, eGPUTextureFormat data_type, const float *pixels, char err_out[256]);
|
|
|
|
GPUTexture *GPU_texture_create_2d_multisample(int w,
|
|
|
|
int h,
|
|
|
|
eGPUTextureFormat data_type,
|
|
|
|
const float *pixels,
|
|
|
|
int samples,
|
|
|
|
char err_out[256]);
|
2019-03-20 18:17:16 +11:00
|
|
|
GPUTexture *GPU_texture_create_2d_array(
|
2019-04-17 06:17:24 +02:00
|
|
|
int w, int h, int d, eGPUTextureFormat data_type, const float *pixels, char err_out[256]);
|
2019-03-20 18:17:16 +11:00
|
|
|
GPUTexture *GPU_texture_create_3d(
|
2019-04-17 06:17:24 +02:00
|
|
|
int w, int h, int d, eGPUTextureFormat data_type, const float *pixels, char err_out[256]);
|
|
|
|
GPUTexture *GPU_texture_create_cube(int w,
|
|
|
|
eGPUTextureFormat data_type,
|
|
|
|
const float *pixels,
|
|
|
|
char err_out[256]);
|
2020-03-11 17:12:01 +01:00
|
|
|
GPUTexture *GPU_texture_create_cube_array(
|
|
|
|
int w, int d, eGPUTextureFormat data_type, const float *pixels, char err_out[256]);
|
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
GPUTexture *GPU_texture_create_from_vertbuf(struct GPUVertBuf *vert);
|
|
|
|
GPUTexture *GPU_texture_create_buffer(eGPUTextureFormat data_type, const uint buffer);
|
2017-02-03 16:01:32 +01:00
|
|
|
|
2018-06-11 22:30:59 +02:00
|
|
|
GPUTexture *GPU_texture_from_bindcode(int textarget, int bindcode);
|
2020-01-27 16:28:55 +01:00
|
|
|
GPUTexture *GPU_texture_from_blender(struct Image *ima,
|
|
|
|
struct ImageUser *iuser,
|
|
|
|
struct ImBuf *ibuf,
|
|
|
|
int textarget);
|
2017-02-03 16:01:32 +01:00
|
|
|
|
2019-04-02 16:05:22 +02:00
|
|
|
/* movie clip drawing */
|
|
|
|
GPUTexture *GPU_texture_from_movieclip(struct MovieClip *clip,
|
|
|
|
struct MovieClipUser *cuser,
|
|
|
|
int textarget);
|
|
|
|
void GPU_free_texture_movieclip(struct MovieClip *clip);
|
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
void GPU_texture_add_mipmap(GPUTexture *tex,
|
|
|
|
eGPUDataFormat gpu_data_format,
|
|
|
|
int miplvl,
|
|
|
|
const void *pixels);
|
2018-07-10 13:17:32 +02:00
|
|
|
|
2019-01-23 14:15:43 +11:00
|
|
|
void GPU_texture_update(GPUTexture *tex, eGPUDataFormat data_format, const void *pixels);
|
2019-04-17 06:17:24 +02:00
|
|
|
void GPU_texture_update_sub(GPUTexture *tex,
|
|
|
|
eGPUDataFormat gpu_data_format,
|
|
|
|
const void *pixels,
|
|
|
|
int offset_x,
|
|
|
|
int offset_y,
|
|
|
|
int offset_z,
|
|
|
|
int width,
|
|
|
|
int height,
|
|
|
|
int depth);
|
2017-08-22 10:22:11 +02:00
|
|
|
|
2019-01-23 14:15:43 +11:00
|
|
|
void *GPU_texture_read(GPUTexture *tex, eGPUDataFormat gpu_data_format, int miplvl);
|
2020-02-15 12:17:39 -03:00
|
|
|
void GPU_texture_clear(GPUTexture *tex, eGPUDataFormat gpu_data_format, const void *color);
|
2018-07-10 13:17:32 +02:00
|
|
|
|
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);
|
|
|
|
|
|
|
|
void GPU_texture_ref(GPUTexture *tex);
|
|
|
|
void GPU_texture_bind(GPUTexture *tex, int number);
|
2020-06-03 13:03:36 +02:00
|
|
|
void GPU_texture_bind_ex(GPUTexture *tex, eGPUSamplerState state, int unit, const bool set_number);
|
2015-12-06 21:20:19 +01:00
|
|
|
void GPU_texture_unbind(GPUTexture *tex);
|
2020-06-02 18:14:28 +02:00
|
|
|
void GPU_texture_unbind_all(void);
|
2015-12-06 21:20:19 +01:00
|
|
|
|
2020-04-22 21:22:07 +02:00
|
|
|
void GPU_texture_copy(GPUTexture *dst, GPUTexture *src);
|
|
|
|
|
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);
|
2020-05-07 22:01:26 +02:00
|
|
|
void GPU_texture_wrap_mode(GPUTexture *tex, bool use_repeat, bool use_clamp);
|
2020-07-17 02:15:41 +02:00
|
|
|
void GPU_texture_swizzle_set(GPUTexture *tex, const char swizzle[4]);
|
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);
|
2019-06-24 22:09:04 +10:00
|
|
|
int GPU_texture_orig_width(const GPUTexture *tex);
|
|
|
|
int GPU_texture_orig_height(const GPUTexture *tex);
|
|
|
|
void GPU_texture_orig_size_set(GPUTexture *tex, int w, int h);
|
2018-07-10 13:17:32 +02:00
|
|
|
int GPU_texture_layers(const GPUTexture *tex);
|
2019-01-23 14:15:43 +11:00
|
|
|
eGPUTextureFormat GPU_texture_format(const GPUTexture *tex);
|
2018-03-14 03:20:39 +01:00
|
|
|
int GPU_texture_samples(const GPUTexture *tex);
|
2020-03-11 17:12:01 +01:00
|
|
|
bool GPU_texture_array(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);
|
|
|
|
|
2018-07-10 13:17:32 +02:00
|
|
|
void GPU_texture_get_mipmap_size(GPUTexture *tex, int lvl, int *size);
|
|
|
|
|
2020-07-16 20:56:17 +02:00
|
|
|
void GPU_sampler_icon_bind(int number);
|
|
|
|
|
2015-12-06 21:20:19 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
#endif /* __GPU_TEXTURE_H__ */
|