Merge branch 'blender-v3.0-release'
This commit is contained in:
commit
a0f50c1890
|
@ -1219,10 +1219,11 @@ static void draw_plane_marker_image(Scene *scene,
|
|||
uint texCoord = GPU_vertformat_attr_add(
|
||||
imm_format, "texCoord", GPU_COMP_F32, 2, GPU_FETCH_FLOAT);
|
||||
|
||||
immBindBuiltinProgram(GPU_SHADER_2D_IMAGE_COLOR);
|
||||
/* Use 3D image for correct display of planar tracked images. */
|
||||
immBindBuiltinProgram(GPU_SHADER_3D_IMAGE_MODULATE_ALPHA);
|
||||
|
||||
immBindTexture("image", texture);
|
||||
immUniformColor4f(1.0f, 1.0f, 1.0f, plane_track->image_opacity);
|
||||
immUniform1f("alpha", plane_track->image_opacity);
|
||||
|
||||
immBegin(GPU_PRIM_TRI_FAN, 4);
|
||||
|
||||
|
|
|
@ -226,6 +226,7 @@ data_to_c_simple(shaders/gpu_shader_image_frag.glsl SRC)
|
|||
data_to_c_simple(shaders/gpu_shader_image_desaturate_frag.glsl SRC)
|
||||
data_to_c_simple(shaders/gpu_shader_image_overlays_merge_frag.glsl SRC)
|
||||
data_to_c_simple(shaders/gpu_shader_image_overlays_stereo_merge_frag.glsl SRC)
|
||||
data_to_c_simple(shaders/gpu_shader_image_modulate_alpha_frag.glsl SRC)
|
||||
data_to_c_simple(shaders/gpu_shader_image_shuffle_color_frag.glsl SRC)
|
||||
data_to_c_simple(shaders/gpu_shader_image_color_frag.glsl SRC)
|
||||
data_to_c_simple(shaders/gpu_shader_image_varying_color_frag.glsl SRC)
|
||||
|
|
|
@ -259,6 +259,15 @@ typedef enum eGPUBuiltinShader {
|
|||
GPU_SHADER_2D_IMAGE_OVERLAYS_MERGE,
|
||||
GPU_SHADER_2D_IMAGE_OVERLAYS_STEREO_MERGE,
|
||||
GPU_SHADER_2D_IMAGE_SHUFFLE_COLOR,
|
||||
/**
|
||||
* Draw texture with alpha. Take a 3D position and a 2D texture coordinate for each vertex.
|
||||
*
|
||||
* \param alpha: uniform float
|
||||
* \param image: uniform sampler2D
|
||||
* \param texCoord: in vec2
|
||||
* \param pos: in vec3
|
||||
*/
|
||||
GPU_SHADER_3D_IMAGE_MODULATE_ALPHA,
|
||||
/* points */
|
||||
/**
|
||||
* Draw round points with a hardcoded size.
|
||||
|
|
|
@ -77,6 +77,7 @@ extern char datatoc_gpu_shader_image_overlays_merge_frag_glsl[];
|
|||
extern char datatoc_gpu_shader_image_overlays_stereo_merge_frag_glsl[];
|
||||
extern char datatoc_gpu_shader_image_color_frag_glsl[];
|
||||
extern char datatoc_gpu_shader_image_desaturate_frag_glsl[];
|
||||
extern char datatoc_gpu_shader_image_modulate_alpha_frag_glsl[];
|
||||
extern char datatoc_gpu_shader_image_varying_color_frag_glsl[];
|
||||
extern char datatoc_gpu_shader_image_shuffle_color_frag_glsl[];
|
||||
extern char datatoc_gpu_shader_3D_vert_glsl[];
|
||||
|
@ -178,7 +179,11 @@ static const GPUShaderStages builtin_shader_stages[GPU_SHADER_BUILTIN_LEN] = {
|
|||
.vert = datatoc_gpu_shader_3D_normal_vert_glsl,
|
||||
.frag = datatoc_gpu_shader_simple_lighting_frag_glsl,
|
||||
},
|
||||
|
||||
[GPU_SHADER_3D_IMAGE_MODULATE_ALPHA] =
|
||||
{
|
||||
.vert = datatoc_gpu_shader_3D_image_vert_glsl,
|
||||
.frag = datatoc_gpu_shader_image_modulate_alpha_frag_glsl,
|
||||
},
|
||||
[GPU_SHADER_2D_CHECKER] =
|
||||
{
|
||||
.name = "GPU_SHADER_2D_CHECKER",
|
||||
|
|
|
@ -0,0 +1,12 @@
|
|||
|
||||
in vec2 texCoord_interp;
|
||||
out vec4 fragColor;
|
||||
|
||||
uniform float alpha;
|
||||
uniform sampler2D image;
|
||||
|
||||
void main()
|
||||
{
|
||||
fragColor = texture(image, texCoord_interp);
|
||||
fragColor.a *= alpha;
|
||||
}
|
|
@ -261,7 +261,7 @@ static WMLinkAppendDataItem *wm_link_append_data_item_add(WMLinkAppendData *lapp
|
|||
const short idcode,
|
||||
void *customdata)
|
||||
{
|
||||
WMLinkAppendDataItem *item = BLI_memarena_alloc(lapp_data->memarena, sizeof(*item));
|
||||
WMLinkAppendDataItem *item = BLI_memarena_calloc(lapp_data->memarena, sizeof(*item));
|
||||
size_t len = strlen(idname) + 1;
|
||||
|
||||
item->name = BLI_memarena_alloc(lapp_data->memarena, len);
|
||||
|
|
Loading…
Reference in New Issue