mirror of
https://github.com/Ttanasart-pt/Pixel-Composer.git
synced 2025-01-24 03:48:06 +01:00
234 lines
No EOL
6.4 KiB
Text
234 lines
No EOL
6.4 KiB
Text
function shader_set_i(uniform, value) {
|
|
gml_pragma("forceinline");
|
|
|
|
var shader = shader_current();
|
|
if(shader == -1) return;
|
|
|
|
if(is_array(value)) {
|
|
shader_set_i_array(shader, uniform, value);
|
|
return;
|
|
}
|
|
|
|
switch(argument_count) {
|
|
case 2 : shader_set_uniform_i(shader_get_uniform(shader, uniform), value); break;
|
|
case 3 : shader_set_uniform_i(shader_get_uniform(shader, uniform), value, argument[2]); break;
|
|
case 4 : shader_set_uniform_i(shader_get_uniform(shader, uniform), value, argument[2], argument[3]); break;
|
|
default:
|
|
var array = array_create(argument_count - 1);
|
|
for( var i = 1; i < argument_count; i++ )
|
|
array[i - 1] = argument[i];
|
|
shader_set_i_array(shader, uniform, array)
|
|
}
|
|
}
|
|
|
|
function shader_set_i_array(shader, uniform, array) {
|
|
gml_pragma("forceinline");
|
|
|
|
shader_set_uniform_i_array(shader_get_uniform(shader, uniform), array);
|
|
}
|
|
|
|
function shader_set_f(uniform, value) {
|
|
gml_pragma("forceinline");
|
|
|
|
var shader = shader_current();
|
|
if(shader == -1) return;
|
|
|
|
if(is_array(value)) {
|
|
shader_set_uniform_f_array_safe(shader_get_uniform(shader, uniform), value);
|
|
return;
|
|
}
|
|
|
|
switch(argument_count) {
|
|
case 2 : shader_set_uniform_f(shader_get_uniform(shader, uniform), value); break;
|
|
case 3 : shader_set_uniform_f(shader_get_uniform(shader, uniform), value, argument[2]); break;
|
|
case 4 : shader_set_uniform_f(shader_get_uniform(shader, uniform), value, argument[2], argument[3]); break;
|
|
case 5 : shader_set_uniform_f(shader_get_uniform(shader, uniform), value, argument[2], argument[3], argument[4]); break;
|
|
default:
|
|
var array = array_create(argument_count - 1);
|
|
for( var i = 1; i < argument_count; i++ )
|
|
array[i - 1] = argument[i];
|
|
shader_set_uniform_f_array(shader_get_uniform(shader, uniform), array)
|
|
}
|
|
|
|
if(argument_count == 2)
|
|
shader_set_uniform_f(shader_get_uniform(shader, uniform), value);
|
|
else if(argument_count == 3)
|
|
shader_set_uniform_f(shader_get_uniform(shader, uniform), value, argument[2]);
|
|
else if(argument_count == 4)
|
|
shader_set_uniform_f(shader_get_uniform(shader, uniform), value, argument[2], argument[3]);
|
|
else {
|
|
var array = array_create(argument_count - 1);
|
|
for( var i = 1; i < argument_count; i++ )
|
|
array[i - 1] = argument[i];
|
|
shader_set_uniform_f_array(shader_get_uniform(shader, uniform), array);
|
|
}
|
|
}
|
|
|
|
function shader_set_uniform_f_array_safe(uniform, array, max_length = 128) {
|
|
gml_pragma("forceinline");
|
|
|
|
if(!is_array(array)) return;
|
|
|
|
var _len = array_length(array);
|
|
if(_len == 0) return;
|
|
if(_len > max_length)
|
|
array_resize(array, max_length)
|
|
|
|
shader_set_uniform_f_array(uniform, array);
|
|
}
|
|
|
|
function shader_set_surface(sampler, surface, linear = false, _repeat = false) {
|
|
gml_pragma("forceinline");
|
|
|
|
var shader = shader_current();
|
|
if(shader == -1) return;
|
|
|
|
if(is_struct(shader) && is_instanceof(shader, dynaSurf))
|
|
shader = shader.surfaces[0];
|
|
if(!is_surface(surface)) return;
|
|
|
|
var t = shader_get_sampler_index(shader, sampler);
|
|
|
|
texture_set_stage(t, surface_get_texture(surface));
|
|
gpu_set_tex_filter_ext(t, linear);
|
|
gpu_set_tex_repeat_ext(t, _repeat);
|
|
}
|
|
|
|
//function shader_set_surface_ext(sampler, surface, linear = false, _repeat = false) {
|
|
// var shader = shader_current();
|
|
// if(!is_surface(surface)) return;
|
|
|
|
// if (!GMD3D11_IS_SUPPORTED) {
|
|
// shader_set_surface(sampler, surface, linear, _repeat);
|
|
// return;
|
|
// }
|
|
|
|
// var t = shader_get_sampler_index(shader, sampler);
|
|
// gpu_set_tex_filter_ext(t, linear);
|
|
// gpu_set_tex_repeat_ext(t, _repeat);
|
|
|
|
// d3d11_texture_set_stage_ps(t, surface_get_texture(surface));
|
|
//}
|
|
|
|
function shader_set_surface_dimension(uniform, surface) {
|
|
gml_pragma("forceinline");
|
|
|
|
var shader = shader_current();
|
|
if(!is_surface(surface)) return;
|
|
if(shader == -1) return;
|
|
|
|
var texture = surface_get_texture(surface);
|
|
var tw = texture_get_texel_width(texture);
|
|
var th = texture_get_texel_height(texture);
|
|
|
|
tw = 2048;
|
|
th = 2048;
|
|
|
|
shader_set_uniform_f(shader_get_uniform(shader, uniform), tw, th);
|
|
}
|
|
|
|
function shader_set_dim(uniform = "dimension", surf = noone) {
|
|
gml_pragma("forceinline");
|
|
|
|
if(!is_surface(surf)) return;
|
|
|
|
shader_set_f(uniform, surface_get_width_safe(surf), surface_get_height_safe(surf));
|
|
}
|
|
|
|
function shader_set_color(uniform, col, alpha = 1) {
|
|
gml_pragma("forceinline");
|
|
|
|
shader_set_f(uniform, colToVec4(col, alpha));
|
|
}
|
|
|
|
function shader_set_palette(pal, pal_uni = "palette", amo_uni = "paletteAmount", max_length = 128) {
|
|
gml_pragma("forceinline");
|
|
|
|
shader_set_i(amo_uni, min(max_length, array_length(pal)));
|
|
|
|
var _pal = [];
|
|
for( var i = 0, n = min(max_length, array_length(pal)); i < n; i++ )
|
|
array_append(_pal, colToVec4(pal[i]));
|
|
|
|
if(array_length(_pal))
|
|
shader_set_f(pal_uni, _pal);
|
|
}
|
|
|
|
#region prebuild
|
|
enum BLEND {
|
|
normal,
|
|
add,
|
|
over,
|
|
alpha,
|
|
alphamulp,
|
|
}
|
|
|
|
function shader_preset_interpolation(shader = sh_sample) {
|
|
gml_pragma("forceinline");
|
|
|
|
var intp = attributes.interpolate;
|
|
|
|
gpu_set_tex_filter(intp);
|
|
shader_set_uniform_i(shader_get_uniform(shader, "interpolation"), intp);
|
|
shader_set_uniform_i(shader_get_uniform(shader, "sampleMode"), attributes.oversample);
|
|
}
|
|
|
|
function shader_postset_interpolation() {
|
|
gml_pragma("forceinline");
|
|
|
|
gpu_set_tex_filter(false);
|
|
}
|
|
|
|
function shader_set_interpolation_surface(surface) {
|
|
gml_pragma("forceinline");
|
|
|
|
shader_set_f("sampleDimension", surface_get_width_safe(surface), surface_get_height_safe(surface));
|
|
}
|
|
|
|
function shader_set_interpolation(surface) {
|
|
gml_pragma("forceinline");
|
|
|
|
var intp = attributes.interpolate;
|
|
|
|
gpu_set_tex_filter(intp);
|
|
shader_set_i("interpolation", intp);
|
|
shader_set_f("sampleDimension", surface_get_width_safe(surface), surface_get_height_safe(surface));
|
|
shader_set_i("sampleMode", attributes.oversample);
|
|
}
|
|
|
|
function surface_set_shader(surface, shader = sh_sample, clear = true, blend = BLEND.alpha) {
|
|
if(!is_surface(surface)) {
|
|
__surface_set = false;
|
|
return;
|
|
}
|
|
|
|
__surface_set = true;
|
|
surface_set_target(surface);
|
|
if(clear) DRAW_CLEAR;
|
|
|
|
switch(blend) {
|
|
case BLEND.add : BLEND_ADD; break;
|
|
case BLEND.over: BLEND_OVERRIDE; break;
|
|
case BLEND.alpha: BLEND_ALPHA; break;
|
|
case BLEND.alphamulp: BLEND_ALPHA_MULP; break;
|
|
}
|
|
|
|
if(shader == noone)
|
|
__shader_set = false;
|
|
else {
|
|
__shader_set = true;
|
|
shader_set(shader);
|
|
}
|
|
}
|
|
|
|
function surface_reset_shader() {
|
|
if(!__surface_set) return;
|
|
|
|
BLEND_NORMAL;
|
|
surface_reset_target();
|
|
gpu_set_tex_filter(false);
|
|
|
|
if(__shader_set)
|
|
shader_reset();
|
|
}
|
|
#endregion |