mirror of
https://github.com/Ttanasart-pt/Pixel-Composer.git
synced 2025-01-25 20:38:07 +01:00
alpha compensated bilinear
This commit is contained in:
parent
2ff87ff393
commit
1b1341757d
27 changed files with 655 additions and 155 deletions
|
@ -156,9 +156,13 @@ function Node_VFX_Spawner_Base(_x, _y, _group = noone) : Node(_x, _y, _group) co
|
||||||
inputs[| 47] = nodeValue("Path Deviation", self, JUNCTION_CONNECT.input, VALUE_TYPE.curve, CURVE_DEF_11 )
|
inputs[| 47] = nodeValue("Path Deviation", self, JUNCTION_CONNECT.input, VALUE_TYPE.curve, CURVE_DEF_11 )
|
||||||
.rejectArray();
|
.rejectArray();
|
||||||
|
|
||||||
|
inputs[| 48] = nodeValue("Reset Seed", self, JUNCTION_CONNECT.input, VALUE_TYPE.trigger, false )
|
||||||
|
.setDisplay(VALUE_DISPLAY.button, { name: "Trigger" })
|
||||||
|
.rejectArray();
|
||||||
|
|
||||||
input_len = ds_list_size(inputs);
|
input_len = ds_list_size(inputs);
|
||||||
|
|
||||||
input_display_list = [ 32,
|
input_display_list = [ 32, 48,
|
||||||
["Sprite", false], 0, 22, 23, 26,
|
["Sprite", false], 0, 22, 23, 26,
|
||||||
["Spawn", true], 27, 16, 44, 1, 2, 3, 4, 30, 24, 5,
|
["Spawn", true], 27, 16, 44, 1, 2, 3, 4, 30, 24, 5,
|
||||||
["Movement", true], 29, 6, 18,
|
["Movement", true], 29, 6, 18,
|
||||||
|
@ -521,6 +525,9 @@ function Node_VFX_Spawner_Base(_x, _y, _group = noone) : Node(_x, _y, _group) co
|
||||||
static onDrawOverlay = -1;
|
static onDrawOverlay = -1;
|
||||||
|
|
||||||
static update = function(frame = CURRENT_FRAME) { #region
|
static update = function(frame = CURRENT_FRAME) { #region
|
||||||
|
var _resetSeed = getInputData(48);
|
||||||
|
if(_resetSeed) resetSeed();
|
||||||
|
|
||||||
checkPartPool();
|
checkPartPool();
|
||||||
onUpdate(frame);
|
onUpdate(frame);
|
||||||
} #endregion
|
} #endregion
|
||||||
|
|
|
@ -16,6 +16,9 @@ function Node_Find_Pixel(_x, _y, _group = noone) : Node_Processor(_x, _y, _group
|
||||||
inputs[| 5] = nodeValue("Alpha tolerance", self, JUNCTION_CONNECT.input, VALUE_TYPE.float, 0.2)
|
inputs[| 5] = nodeValue("Alpha tolerance", self, JUNCTION_CONNECT.input, VALUE_TYPE.float, 0.2)
|
||||||
.setDisplay(VALUE_DISPLAY.slider);
|
.setDisplay(VALUE_DISPLAY.slider);
|
||||||
|
|
||||||
|
// inputs[| 6] = nodeValue("Axis", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, 1)
|
||||||
|
// .setDisplay(VALUE_DISPLAY.enum_button, [ "X", "Y" ]);
|
||||||
|
|
||||||
outputs[| 0] = nodeValue("Position", self, JUNCTION_CONNECT.output, VALUE_TYPE.integer, [ 0, 0 ])
|
outputs[| 0] = nodeValue("Position", self, JUNCTION_CONNECT.output, VALUE_TYPE.integer, [ 0, 0 ])
|
||||||
.setDisplay(VALUE_DISPLAY.vector);
|
.setDisplay(VALUE_DISPLAY.vector);
|
||||||
|
|
||||||
|
@ -28,6 +31,12 @@ function Node_Find_Pixel(_x, _y, _group = noone) : Node_Processor(_x, _y, _group
|
||||||
|
|
||||||
temp_surface = [ surface_create(1, 1) ];
|
temp_surface = [ surface_create(1, 1) ];
|
||||||
|
|
||||||
|
static step = function() { #region
|
||||||
|
// var _all = getInputData(3);
|
||||||
|
|
||||||
|
// inputs[| 6].setVisible(_all);
|
||||||
|
} #endregion
|
||||||
|
|
||||||
static processData = function(_output, _data, _output_index, _array_index = 0) { #region
|
static processData = function(_output, _data, _output_index, _array_index = 0) { #region
|
||||||
var _surf = _data[0];
|
var _surf = _data[0];
|
||||||
var _col = _data[1];
|
var _col = _data[1];
|
||||||
|
@ -36,6 +45,7 @@ function Node_Find_Pixel(_x, _y, _group = noone) : Node_Processor(_x, _y, _group
|
||||||
|
|
||||||
var _alp = _data[4];
|
var _alp = _data[4];
|
||||||
var _alpT = _data[5];
|
var _alpT = _data[5];
|
||||||
|
// var _axis = _data[6];
|
||||||
|
|
||||||
if(!is_surface(_surf)) return [0, 0];
|
if(!is_surface(_surf)) return [0, 0];
|
||||||
|
|
||||||
|
|
|
@ -29,9 +29,12 @@ function Node_Glow(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) cons
|
||||||
|
|
||||||
inputs[| 11] = nodeValue("Draw original", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, true);
|
inputs[| 11] = nodeValue("Draw original", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, true);
|
||||||
|
|
||||||
|
inputs[| 12] = nodeValue("Side", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, 0)
|
||||||
|
.setDisplay(VALUE_DISPLAY.enum_button, [ "Outer", "Inner" ]);
|
||||||
|
|
||||||
input_display_list = [ 7,
|
input_display_list = [ 7,
|
||||||
["Surfaces", true], 0, 5, 6, 8, 9,
|
["Surfaces", true], 0, 5, 6, 8, 9,
|
||||||
["Glow", false], 10, 2, 3,
|
["Glow", false], 10, 12, 2, 3,
|
||||||
["Render", false], 4, 11,
|
["Render", false], 4, 11,
|
||||||
]
|
]
|
||||||
|
|
||||||
|
@ -48,6 +51,7 @@ function Node_Glow(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) cons
|
||||||
var _color = _data[4];
|
var _color = _data[4];
|
||||||
var _mode = _data[10];
|
var _mode = _data[10];
|
||||||
var _render = _data[11];
|
var _render = _data[11];
|
||||||
|
var _side = _data[12];
|
||||||
|
|
||||||
surface_set_shader(_outSurf, sh_glow);
|
surface_set_shader(_outSurf, sh_glow);
|
||||||
shader_set_dim("dimension", _data[0]);
|
shader_set_dim("dimension", _data[0]);
|
||||||
|
@ -57,6 +61,7 @@ function Node_Glow(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) cons
|
||||||
shader_set_f("strength", _strength);
|
shader_set_f("strength", _strength);
|
||||||
shader_set_color("color", _color);
|
shader_set_color("color", _color);
|
||||||
shader_set_i("render", _render);
|
shader_set_i("render", _render);
|
||||||
|
shader_set_i("side", _side);
|
||||||
|
|
||||||
draw_surface_safe(_data[0]);
|
draw_surface_safe(_data[0]);
|
||||||
surface_reset_shader();
|
surface_reset_shader();
|
||||||
|
|
|
@ -180,8 +180,8 @@ function Node_Transform(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
|
||||||
}
|
}
|
||||||
} #endregion
|
} #endregion
|
||||||
|
|
||||||
static processData_prebatch = function() { shader_preset_interpolation(); }
|
// static processData_prebatch = function() { shader_preset_interpolation(); }
|
||||||
static processData_postbatch = function() { shader_postset_interpolation(); }
|
// static processData_postbatch = function() { shader_postset_interpolation(); }
|
||||||
|
|
||||||
static processData = function(_outSurf, _data, _output_index, _array_index) { #region
|
static processData = function(_outSurf, _data, _output_index, _array_index) { #region
|
||||||
var ins = _data[0];
|
var ins = _data[0];
|
||||||
|
|
|
@ -1583,8 +1583,8 @@ function Panel_Preview() : PanelContent() constructor {
|
||||||
|
|
||||||
if(sample_color != noone) {
|
if(sample_color != noone) {
|
||||||
draw_set_color(sample_color);
|
draw_set_color(sample_color);
|
||||||
draw_rectangle(cx, cy, cx + cw, cy + ch, false);
|
|
||||||
draw_set_alpha(1);
|
draw_set_alpha(1);
|
||||||
|
draw_rectangle(cx, cy, cx + cw, cy + ch, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
draw_set_color(COLORS.panel_toolbar_outline);
|
draw_set_color(COLORS.panel_toolbar_outline);
|
||||||
|
|
|
@ -144,13 +144,20 @@
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region ///////////////////////////////////////////////////////////////////////// DATA //////////////////////////////////////////////////////////////////////////
|
|
||||||
PREFERENCES.attr_palette = [ cola(c_black), cola(c_white) ];
|
|
||||||
#endregion
|
|
||||||
|
|
||||||
PREFERENCES_DEF = variable_clone(PREFERENCES);
|
PREFERENCES_DEF = variable_clone(PREFERENCES);
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
#region project attributes
|
||||||
|
globalvar PROJECT_ATTRIBUTES;
|
||||||
|
|
||||||
|
PROJECT_ATTRIBUTES = {}
|
||||||
|
|
||||||
|
PROJECT_ATTRIBUTES.strict = false;
|
||||||
|
PROJECT_ATTRIBUTES.surface_dimension = [ 32, 32 ];
|
||||||
|
PROJECT_ATTRIBUTES.palette = [ cola(c_white), cola(c_black) ];
|
||||||
|
PROJECT_ATTRIBUTES.palette_fix = false;
|
||||||
|
#endregion
|
||||||
|
|
||||||
#region recent files
|
#region recent files
|
||||||
globalvar RECENT_FILES, RECENT_FILE_DATA;
|
globalvar RECENT_FILES, RECENT_FILE_DATA;
|
||||||
RECENT_FILES = ds_list_create();
|
RECENT_FILES = ds_list_create();
|
||||||
|
@ -236,6 +243,7 @@
|
||||||
json_save_struct(DIRECTORY + "Nodes/fav.json", global.FAV_NODES);
|
json_save_struct(DIRECTORY + "Nodes/fav.json", global.FAV_NODES);
|
||||||
json_save_struct(DIRECTORY + "Nodes/recent.json", global.RECENT_NODES);
|
json_save_struct(DIRECTORY + "Nodes/recent.json", global.RECENT_NODES);
|
||||||
json_save_struct(DIRECTORY + "key_nodes.json", HOTKEYS_CUSTOM);
|
json_save_struct(DIRECTORY + "key_nodes.json", HOTKEYS_CUSTOM);
|
||||||
|
json_save_struct(DIRECTORY + "default_project.json", PROJECT_ATTRIBUTES);
|
||||||
} #endregion
|
} #endregion
|
||||||
|
|
||||||
function PREF_LOAD() { #region
|
function PREF_LOAD() { #region
|
||||||
|
@ -257,9 +265,6 @@
|
||||||
|
|
||||||
struct_override(PREFERENCES, map.preferences);
|
struct_override(PREFERENCES, map.preferences);
|
||||||
|
|
||||||
if(!is_array(PREFERENCES.attr_palette))
|
|
||||||
PREFERENCES.attr_palette = PREFERENCES_DEF.attr_palette;
|
|
||||||
|
|
||||||
if(!directory_exists($"{DIRECTORY}Themes/{PREFERENCES.theme}"))
|
if(!directory_exists($"{DIRECTORY}Themes/{PREFERENCES.theme}"))
|
||||||
PREFERENCES.theme = "default";
|
PREFERENCES.theme = "default";
|
||||||
|
|
||||||
|
@ -273,6 +278,10 @@
|
||||||
directory_verify(filepath_resolve(PREFERENCES.temp_path));
|
directory_verify(filepath_resolve(PREFERENCES.temp_path));
|
||||||
|
|
||||||
if(PREFERENCES.move_directory) directory_set_current_working(DIRECTORY);
|
if(PREFERENCES.move_directory) directory_set_current_working(DIRECTORY);
|
||||||
|
|
||||||
|
var f = json_load_struct(DIRECTORY + "default_project.json");
|
||||||
|
struct_override(PROJECT_ATTRIBUTES, f);
|
||||||
|
|
||||||
} #endregion
|
} #endregion
|
||||||
|
|
||||||
function PREF_APPLY() { #region
|
function PREF_APPLY() { #region
|
||||||
|
|
|
@ -59,15 +59,16 @@
|
||||||
}; #endregion
|
}; #endregion
|
||||||
|
|
||||||
#region =================== ATTRIBUTES ===================
|
#region =================== ATTRIBUTES ===================
|
||||||
attributes = {
|
attributes = variable_clone(PROJECT_ATTRIBUTES);
|
||||||
strict : false,
|
|
||||||
surface_dimension : [ 32, 32 ],
|
|
||||||
palette : array_clone(PREFERENCES.attr_palette),
|
|
||||||
palette_fix : false,
|
|
||||||
}
|
|
||||||
|
|
||||||
attributeEditor = [
|
attributeEditor = [
|
||||||
[ "Default Surface", "surface_dimension", new vectorBox(2, function(ind, val) { attributes.surface_dimension[ind] = val; RENDER_ALL return true; }),
|
[ "Default Surface", "surface_dimension", new vectorBox(2,
|
||||||
|
function(ind, val) {
|
||||||
|
attributes.surface_dimension[ind] = val;
|
||||||
|
PROJECT_ATTRIBUTES.surface_dimension = array_clone(attributes.surface_dimension);
|
||||||
|
RENDER_ALL
|
||||||
|
return true;
|
||||||
|
}),
|
||||||
function(junc) {
|
function(junc) {
|
||||||
if(!is_struct(junc)) return;
|
if(!is_struct(junc)) return;
|
||||||
if(!is_instanceof(junc, NodeValue)) return;
|
if(!is_instanceof(junc, NodeValue)) return;
|
||||||
|
@ -113,8 +114,13 @@
|
||||||
];
|
];
|
||||||
|
|
||||||
static setPalette = function(pal = noone) {
|
static setPalette = function(pal = noone) {
|
||||||
if(pal != noone) attributes.palette = pal;
|
if(pal != noone) {
|
||||||
PREFERENCES.attr_palette = array_clone(pal);
|
for (var i = 0, n = array_length(pal); i < n; i++)
|
||||||
|
pal[i] = cola(pal[i], _color_get_alpha(pal[i]));
|
||||||
|
|
||||||
|
attributes.palette = pal;
|
||||||
|
PROJECT_ATTRIBUTES.palette = array_clone(pal);
|
||||||
|
}
|
||||||
|
|
||||||
palettes = paletteToArray(attributes.palette);
|
palettes = paletteToArray(attributes.palette);
|
||||||
|
|
||||||
|
|
|
@ -191,7 +191,7 @@ function shader_set_palette(pal, pal_uni = "palette", amo_uni = "paletteAmount",
|
||||||
|
|
||||||
var intp = attributes.interpolate;
|
var intp = attributes.interpolate;
|
||||||
|
|
||||||
gpu_set_tex_filter(intp);
|
// gpu_set_tex_filter(intp);
|
||||||
shader_set_i("interpolation", intp);
|
shader_set_i("interpolation", intp);
|
||||||
shader_set_f("sampleDimension", _dim == noone? surface_get_dimension(surface) : _dim);
|
shader_set_f("sampleDimension", _dim == noone? surface_get_dimension(surface) : _dim);
|
||||||
shader_set_i("sampleMode", attributes.oversample);
|
shader_set_i("sampleMode", attributes.oversample);
|
||||||
|
|
|
@ -24,6 +24,30 @@ const int RSIN_RADIUS = 1;
|
||||||
|
|
||||||
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
||||||
|
|
||||||
|
vec4 texture2D_bilinear( sampler2D texture, vec2 uv ) {
|
||||||
|
uv = uv * sampleDimension - .5;
|
||||||
|
vec2 iuv = floor( uv );
|
||||||
|
vec2 fuv = fract( uv );
|
||||||
|
|
||||||
|
vec4 mixed = mix(
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 0.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 0.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 1.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 1.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
fuv.y
|
||||||
|
);
|
||||||
|
|
||||||
|
mixed.rgb /= mixed.a;
|
||||||
|
|
||||||
|
return mixed;
|
||||||
|
}
|
||||||
|
|
||||||
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
vec2 tx = 1.0 / sampleDimension;
|
vec2 tx = 1.0 / sampleDimension;
|
||||||
vec2 p = uv * sampleDimension - vec2(0.5);
|
vec2 p = uv * sampleDimension - vec2(0.5);
|
||||||
|
@ -37,7 +61,7 @@ vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
if(a > 1.) continue;
|
if(a > 1.) continue;
|
||||||
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
||||||
vec2 offset = vec2(float(x), float(y)) * tx;
|
vec2 offset = vec2(float(x), float(y)) * tx;
|
||||||
vec4 sample = texture2D(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
vec4 sample = texture2D_bilinear(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
||||||
sum += w * sample;
|
sum += w * sample;
|
||||||
weights += w;
|
weights += w;
|
||||||
}
|
}
|
||||||
|
@ -51,11 +75,12 @@ vec4 texture2D_bicubic( sampler2D texture, vec2 uv ) {
|
||||||
vec2 fuv = fract( uv );
|
vec2 fuv = fract( uv );
|
||||||
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
||||||
uv = (uv - 0.5) / sampleDimension;
|
uv = (uv - 0.5) / sampleDimension;
|
||||||
return texture2D( texture, uv );
|
return texture2D_bilinear( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
||||||
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
||||||
if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
if(interpolation == 1) return texture2D_bilinear( texture, uv );
|
||||||
|
else if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
||||||
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
||||||
return texture2D( texture, uv );
|
return texture2D( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,6 +26,30 @@ vec2 txMap;
|
||||||
|
|
||||||
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
||||||
|
|
||||||
|
vec4 texture2D_bilinear( sampler2D texture, vec2 uv ) {
|
||||||
|
uv = uv * sampleDimension - .5;
|
||||||
|
vec2 iuv = floor( uv );
|
||||||
|
vec2 fuv = fract( uv );
|
||||||
|
|
||||||
|
vec4 mixed = mix(
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 0.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 0.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 1.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 1.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
fuv.y
|
||||||
|
);
|
||||||
|
|
||||||
|
mixed.rgb /= mixed.a;
|
||||||
|
|
||||||
|
return mixed;
|
||||||
|
}
|
||||||
|
|
||||||
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
vec2 tx = 1.0 / sampleDimension;
|
vec2 tx = 1.0 / sampleDimension;
|
||||||
vec2 p = uv * sampleDimension - vec2(0.5);
|
vec2 p = uv * sampleDimension - vec2(0.5);
|
||||||
|
@ -39,7 +63,7 @@ vec2 txMap;
|
||||||
if(a > 1.) continue;
|
if(a > 1.) continue;
|
||||||
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
||||||
vec2 offset = vec2(float(x), float(y)) * tx;
|
vec2 offset = vec2(float(x), float(y)) * tx;
|
||||||
vec4 sample = texture2D(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
vec4 sample = texture2D_bilinear(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
||||||
sum += w * sample;
|
sum += w * sample;
|
||||||
weights += w;
|
weights += w;
|
||||||
}
|
}
|
||||||
|
@ -53,14 +77,16 @@ vec2 txMap;
|
||||||
vec2 fuv = fract( uv );
|
vec2 fuv = fract( uv );
|
||||||
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
||||||
uv = (uv - 0.5) / sampleDimension;
|
uv = (uv - 0.5) / sampleDimension;
|
||||||
return texture2D( texture, uv );
|
return texture2D_bilinear( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
||||||
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
||||||
if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
if(interpolation == 1) return texture2D_bilinear( texture, uv );
|
||||||
|
else if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
||||||
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
||||||
return texture2D( texture, uv );
|
return texture2D( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
vec4 sampleTexture(sampler2D texture, vec2 pos) { #region
|
vec4 sampleTexture(sampler2D texture, vec2 pos) { #region
|
||||||
|
|
|
@ -21,6 +21,30 @@ const int RSIN_RADIUS = 1;
|
||||||
|
|
||||||
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
||||||
|
|
||||||
|
vec4 texture2D_bilinear( sampler2D texture, vec2 uv ) {
|
||||||
|
uv = uv * sampleDimension - .5;
|
||||||
|
vec2 iuv = floor( uv );
|
||||||
|
vec2 fuv = fract( uv );
|
||||||
|
|
||||||
|
vec4 mixed = mix(
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 0.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 0.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 1.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 1.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
fuv.y
|
||||||
|
);
|
||||||
|
|
||||||
|
mixed.rgb /= mixed.a;
|
||||||
|
|
||||||
|
return mixed;
|
||||||
|
}
|
||||||
|
|
||||||
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
vec2 tx = 1.0 / sampleDimension;
|
vec2 tx = 1.0 / sampleDimension;
|
||||||
vec2 p = uv * sampleDimension - vec2(0.5);
|
vec2 p = uv * sampleDimension - vec2(0.5);
|
||||||
|
@ -34,7 +58,7 @@ vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
if(a > 1.) continue;
|
if(a > 1.) continue;
|
||||||
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
||||||
vec2 offset = vec2(float(x), float(y)) * tx;
|
vec2 offset = vec2(float(x), float(y)) * tx;
|
||||||
vec4 sample = texture2D(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
vec4 sample = texture2D_bilinear(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
||||||
sum += w * sample;
|
sum += w * sample;
|
||||||
weights += w;
|
weights += w;
|
||||||
}
|
}
|
||||||
|
@ -48,11 +72,12 @@ vec4 texture2D_bicubic( sampler2D texture, vec2 uv ) {
|
||||||
vec2 fuv = fract( uv );
|
vec2 fuv = fract( uv );
|
||||||
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
||||||
uv = (uv - 0.5) / sampleDimension;
|
uv = (uv - 0.5) / sampleDimension;
|
||||||
return texture2D( texture, uv );
|
return texture2D_bilinear( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
||||||
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
||||||
if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
if(interpolation == 1) return texture2D_bilinear( texture, uv );
|
||||||
|
else if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
||||||
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
||||||
return texture2D( texture, uv );
|
return texture2D( texture, uv );
|
||||||
}
|
}
|
||||||
|
@ -75,12 +100,15 @@ void main() {
|
||||||
vec2 uvB = v_vTexcoord + texel.xy * precompute;
|
vec2 uvB = v_vTexcoord + texel.xy * precompute;
|
||||||
|
|
||||||
vec4 color;
|
vec4 color;
|
||||||
color.r = texture2Dintp(gm_BaseTexture, uvR).r;
|
|
||||||
color.g = texture2Dintp(gm_BaseTexture, v_vTexcoord).g;
|
vec4 cr = texture2Dintp(gm_BaseTexture, uvR);
|
||||||
color.b = texture2Dintp(gm_BaseTexture, uvB).b;
|
vec4 cb = texture2Dintp(gm_BaseTexture, uvB);
|
||||||
color.a = texture2Dintp(gm_BaseTexture, v_vTexcoord).a +
|
vec4 cv = texture2Dintp(gm_BaseTexture, v_vTexcoord);
|
||||||
texture2Dintp(gm_BaseTexture, uvR).a +
|
|
||||||
texture2Dintp(gm_BaseTexture, uvB).a;
|
color.r = cr.r;
|
||||||
|
color.g = cv.g;
|
||||||
|
color.b = cb.b;
|
||||||
|
color.a = cv.a + cr.a + cb.a;
|
||||||
|
|
||||||
gl_FragColor = color;
|
gl_FragColor = color;
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,6 +26,30 @@ const int RSIN_RADIUS = 1;
|
||||||
|
|
||||||
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
||||||
|
|
||||||
|
vec4 texture2D_bilinear( sampler2D texture, vec2 uv ) {
|
||||||
|
uv = uv * sampleDimension - .5;
|
||||||
|
vec2 iuv = floor( uv );
|
||||||
|
vec2 fuv = fract( uv );
|
||||||
|
|
||||||
|
vec4 mixed = mix(
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 0.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 0.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 1.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 1.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
fuv.y
|
||||||
|
);
|
||||||
|
|
||||||
|
mixed.rgb /= mixed.a;
|
||||||
|
|
||||||
|
return mixed;
|
||||||
|
}
|
||||||
|
|
||||||
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
vec2 tx = 1.0 / sampleDimension;
|
vec2 tx = 1.0 / sampleDimension;
|
||||||
vec2 p = uv * sampleDimension - vec2(0.5);
|
vec2 p = uv * sampleDimension - vec2(0.5);
|
||||||
|
@ -39,7 +63,7 @@ vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
if(a > 1.) continue;
|
if(a > 1.) continue;
|
||||||
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
||||||
vec2 offset = vec2(float(x), float(y)) * tx;
|
vec2 offset = vec2(float(x), float(y)) * tx;
|
||||||
vec4 sample = texture2D(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
vec4 sample = texture2D_bilinear(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
||||||
sum += w * sample;
|
sum += w * sample;
|
||||||
weights += w;
|
weights += w;
|
||||||
}
|
}
|
||||||
|
@ -53,11 +77,12 @@ vec4 texture2D_bicubic( sampler2D texture, vec2 uv ) {
|
||||||
vec2 fuv = fract( uv );
|
vec2 fuv = fract( uv );
|
||||||
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
||||||
uv = (uv - 0.5) / sampleDimension;
|
uv = (uv - 0.5) / sampleDimension;
|
||||||
return texture2D( texture, uv );
|
return texture2D_bilinear( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
||||||
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
||||||
if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
if(interpolation == 1) return texture2D_bilinear( texture, uv );
|
||||||
|
else if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
||||||
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
||||||
return texture2D( texture, uv );
|
return texture2D( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
|
@ -30,6 +30,30 @@ float bright(in vec4 col) { return dot(col.rgb, vec3(0.2126, 0.7152, 0.0722)) *
|
||||||
|
|
||||||
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
||||||
|
|
||||||
|
vec4 texture2D_bilinear( sampler2D texture, vec2 uv ) {
|
||||||
|
uv = uv * sampleDimension - .5;
|
||||||
|
vec2 iuv = floor( uv );
|
||||||
|
vec2 fuv = fract( uv );
|
||||||
|
|
||||||
|
vec4 mixed = mix(
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 0.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 0.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 1.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 1.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
fuv.y
|
||||||
|
);
|
||||||
|
|
||||||
|
mixed.rgb /= mixed.a;
|
||||||
|
|
||||||
|
return mixed;
|
||||||
|
}
|
||||||
|
|
||||||
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
vec2 tx = 1.0 / sampleDimension;
|
vec2 tx = 1.0 / sampleDimension;
|
||||||
vec2 p = uv * sampleDimension - vec2(0.5);
|
vec2 p = uv * sampleDimension - vec2(0.5);
|
||||||
|
@ -43,7 +67,7 @@ float bright(in vec4 col) { return dot(col.rgb, vec3(0.2126, 0.7152, 0.0722)) *
|
||||||
if(a > 1.) continue;
|
if(a > 1.) continue;
|
||||||
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
||||||
vec2 offset = vec2(float(x), float(y)) * tx;
|
vec2 offset = vec2(float(x), float(y)) * tx;
|
||||||
vec4 sample = texture2D(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
vec4 sample = texture2D_bilinear(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
||||||
sum += w * sample;
|
sum += w * sample;
|
||||||
weights += w;
|
weights += w;
|
||||||
}
|
}
|
||||||
|
@ -57,11 +81,12 @@ float bright(in vec4 col) { return dot(col.rgb, vec3(0.2126, 0.7152, 0.0722)) *
|
||||||
vec2 fuv = fract( uv );
|
vec2 fuv = fract( uv );
|
||||||
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
||||||
uv = (uv - 0.5) / sampleDimension;
|
uv = (uv - 0.5) / sampleDimension;
|
||||||
return texture2D( texture, uv );
|
return texture2D_bilinear( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
||||||
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
||||||
if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
if(interpolation == 1) return texture2D_bilinear( texture, uv );
|
||||||
|
else if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
||||||
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
||||||
return texture2D( texture, uv );
|
return texture2D( texture, uv );
|
||||||
}
|
}
|
||||||
|
@ -70,17 +95,10 @@ float bright(in vec4 col) { return dot(col.rgb, vec3(0.2126, 0.7152, 0.0722)) *
|
||||||
if(pos.x >= 0. && pos.y >= 0. && pos.x <= 1. && pos.y <= 1.)
|
if(pos.x >= 0. && pos.y >= 0. && pos.x <= 1. && pos.y <= 1.)
|
||||||
return texture2Dintp(gm_BaseTexture, pos);
|
return texture2Dintp(gm_BaseTexture, pos);
|
||||||
|
|
||||||
if(sampleMode == 0)
|
if(sampleMode == 0) return vec4(0.);
|
||||||
return vec4(0.);
|
else if(sampleMode == 1) return texture2Dintp(gm_BaseTexture, clamp(pos, 0., 1.));
|
||||||
|
else if(sampleMode == 2) return texture2Dintp(gm_BaseTexture, fract(pos));
|
||||||
else if(sampleMode == 1)
|
else if(sampleMode == 3) return vec4(vec3(0.), 1.);
|
||||||
return texture2Dintp(gm_BaseTexture, clamp(pos, 0., 1.));
|
|
||||||
|
|
||||||
else if(sampleMode == 2)
|
|
||||||
return texture2Dintp(gm_BaseTexture, fract(pos));
|
|
||||||
|
|
||||||
else if(sampleMode == 3)
|
|
||||||
return vec4(vec3(0.), 1.);
|
|
||||||
|
|
||||||
return vec4(0.);
|
return vec4(0.);
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,6 +18,30 @@ const int RSIN_RADIUS = 1;
|
||||||
|
|
||||||
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
||||||
|
|
||||||
|
vec4 texture2D_bilinear( sampler2D texture, vec2 uv ) {
|
||||||
|
uv = uv * sampleDimension - .5;
|
||||||
|
vec2 iuv = floor( uv );
|
||||||
|
vec2 fuv = fract( uv );
|
||||||
|
|
||||||
|
vec4 mixed = mix(
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 0.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 0.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 1.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 1.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
fuv.y
|
||||||
|
);
|
||||||
|
|
||||||
|
mixed.rgb /= mixed.a;
|
||||||
|
|
||||||
|
return mixed;
|
||||||
|
}
|
||||||
|
|
||||||
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
vec2 tx = 1.0 / sampleDimension;
|
vec2 tx = 1.0 / sampleDimension;
|
||||||
vec2 p = uv * sampleDimension - vec2(0.5);
|
vec2 p = uv * sampleDimension - vec2(0.5);
|
||||||
|
@ -31,7 +55,7 @@ vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
if(a > 1.) continue;
|
if(a > 1.) continue;
|
||||||
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
||||||
vec2 offset = vec2(float(x), float(y)) * tx;
|
vec2 offset = vec2(float(x), float(y)) * tx;
|
||||||
vec4 sample = texture2D(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
vec4 sample = texture2D_bilinear(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
||||||
sum += w * sample;
|
sum += w * sample;
|
||||||
weights += w;
|
weights += w;
|
||||||
}
|
}
|
||||||
|
@ -45,11 +69,12 @@ vec4 texture2D_bicubic( sampler2D texture, vec2 uv ) {
|
||||||
vec2 fuv = fract( uv );
|
vec2 fuv = fract( uv );
|
||||||
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
||||||
uv = (uv - 0.5) / sampleDimension;
|
uv = (uv - 0.5) / sampleDimension;
|
||||||
return texture2D( texture, uv );
|
return texture2D_bilinear( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
||||||
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
||||||
if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
if(interpolation == 1) return texture2D_bilinear( texture, uv );
|
||||||
|
else if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
||||||
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
||||||
return texture2D( texture, uv );
|
return texture2D( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,6 +18,30 @@ const int RSIN_RADIUS = 1;
|
||||||
|
|
||||||
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
||||||
|
|
||||||
|
vec4 texture2D_bilinear( sampler2D texture, vec2 uv ) {
|
||||||
|
uv = uv * sampleDimension - .5;
|
||||||
|
vec2 iuv = floor( uv );
|
||||||
|
vec2 fuv = fract( uv );
|
||||||
|
|
||||||
|
vec4 mixed = mix(
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 0.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 0.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 1.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 1.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
fuv.y
|
||||||
|
);
|
||||||
|
|
||||||
|
mixed.rgb /= mixed.a;
|
||||||
|
|
||||||
|
return mixed;
|
||||||
|
}
|
||||||
|
|
||||||
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
vec2 tx = 1.0 / sampleDimension;
|
vec2 tx = 1.0 / sampleDimension;
|
||||||
vec2 p = uv * sampleDimension - vec2(0.5);
|
vec2 p = uv * sampleDimension - vec2(0.5);
|
||||||
|
@ -31,7 +55,7 @@ vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
if(a > 1.) continue;
|
if(a > 1.) continue;
|
||||||
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
||||||
vec2 offset = vec2(float(x), float(y)) * tx;
|
vec2 offset = vec2(float(x), float(y)) * tx;
|
||||||
vec4 sample = texture2D(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
vec4 sample = texture2D_bilinear(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
||||||
sum += w * sample;
|
sum += w * sample;
|
||||||
weights += w;
|
weights += w;
|
||||||
}
|
}
|
||||||
|
@ -45,11 +69,12 @@ vec4 texture2D_bicubic( sampler2D texture, vec2 uv ) {
|
||||||
vec2 fuv = fract( uv );
|
vec2 fuv = fract( uv );
|
||||||
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
||||||
uv = (uv - 0.5) / sampleDimension;
|
uv = (uv - 0.5) / sampleDimension;
|
||||||
return texture2D( texture, uv );
|
return texture2D_bilinear( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
||||||
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
||||||
if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
if(interpolation == 1) return texture2D_bilinear( texture, uv );
|
||||||
|
else if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
||||||
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
||||||
return texture2D( texture, uv );
|
return texture2D( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,6 +10,7 @@ uniform float size;
|
||||||
uniform float strength;
|
uniform float strength;
|
||||||
uniform vec4 color;
|
uniform vec4 color;
|
||||||
|
|
||||||
|
uniform int side;
|
||||||
uniform int render;
|
uniform int render;
|
||||||
|
|
||||||
float bright(in vec4 col) { return dot(col.rgb, vec3(0.2126, 0.7152, 0.0722)) * col.a; }
|
float bright(in vec4 col) { return dot(col.rgb, vec3(0.2126, 0.7152, 0.0722)) * col.a; }
|
||||||
|
@ -21,7 +22,6 @@ vec2 round(vec2 val) { return vec2(round(val.x), round(val.y)); }
|
||||||
void main() {
|
void main() {
|
||||||
vec2 tx = 1. / dimension;
|
vec2 tx = 1. / dimension;
|
||||||
vec2 px = round(v_vTexcoord * dimension);
|
vec2 px = round(v_vTexcoord * dimension);
|
||||||
|
|
||||||
vec4 base = sample(v_vTexcoord);
|
vec4 base = sample(v_vTexcoord);
|
||||||
|
|
||||||
if(render == 1) {
|
if(render == 1) {
|
||||||
|
@ -31,26 +31,39 @@ void main() {
|
||||||
if(mode == 1) gl_FragColor = vec4(0., 0., 0., 0.);
|
if(mode == 1) gl_FragColor = vec4(0., 0., 0., 0.);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(side == 0) {
|
||||||
if(mode == 0 && base.rgb == vec3(1.)) return;
|
if(mode == 0 && base.rgb == vec3(1.)) return;
|
||||||
if(mode == 1 && base.a == 1.) return;
|
if(mode == 1 && base.a == 1.) return;
|
||||||
|
|
||||||
|
} else if(side == 1) {
|
||||||
|
if(mode == 0 && base.rgb == vec3(0.)) return;
|
||||||
|
if(mode == 1 && base.a == 0.) return;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
float dist = 0.;
|
float dist = 0.;
|
||||||
float astp = max(64., size * 4.);
|
float astp = max(64., size * 4.);
|
||||||
|
|
||||||
for(float i = 1.; i < size; i++)
|
for(float i = 1.; i < size; i++)
|
||||||
for(float j = 0.; j <= astp; j++) {
|
for(float j = 0.; j <= astp; j++) {
|
||||||
|
|
||||||
float angle = j / astp * TAU;
|
float angle = j / astp * TAU;
|
||||||
vec2 smPos = v_vTexcoord + vec2(cos(angle), sin(angle)) * i * tx;
|
vec2 smPos = v_vTexcoord + vec2(cos(angle), sin(angle)) * i * tx;
|
||||||
//vec2 smPx = round(smPos * dimension);
|
|
||||||
//if(i < 4. && distance(px, smPx) > i) continue;
|
|
||||||
|
|
||||||
vec4 samp = sample(smPos);
|
vec4 samp = sample(smPos);
|
||||||
|
|
||||||
|
if(side == 0) {
|
||||||
if((mode == 0 && bright(samp) > bright(base)) || (mode == 1 && samp.a > base.a)) {
|
if((mode == 0 && bright(samp) > bright(base)) || (mode == 1 && samp.a > base.a)) {
|
||||||
dist = i;
|
dist = i;
|
||||||
i = size;
|
i = size;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
} else if(side == 1) {
|
||||||
|
if((mode == 0 && bright(samp) < bright(base)) || (mode == 1 && samp.a < base.a)) {
|
||||||
|
dist = i;
|
||||||
|
i = size;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if(dist > 0.) {
|
if(dist > 0.) {
|
||||||
|
@ -58,9 +71,11 @@ void main() {
|
||||||
float str = (1. - dist / size) * strength;
|
float str = (1. - dist / size) * strength;
|
||||||
|
|
||||||
if(mode == 0) cc.rgb *= str;
|
if(mode == 0) cc.rgb *= str;
|
||||||
if(mode == 1) cc.a *= str;
|
else if(side == 0) cc.a *= str;
|
||||||
|
else if(side == 1) cc.rgb *= str;
|
||||||
|
|
||||||
if(render == 1) gl_FragColor = base + cc;
|
if(render == 1) gl_FragColor = base + cc;
|
||||||
else gl_FragColor = cc;
|
else if(side == 0) gl_FragColor = cc;
|
||||||
|
else if(side == 1) gl_FragColor = base + cc;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,6 +22,30 @@ const int RSIN_RADIUS = 1;
|
||||||
|
|
||||||
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
||||||
|
|
||||||
|
vec4 texture2D_bilinear( sampler2D texture, vec2 uv ) {
|
||||||
|
uv = uv * sampleDimension - .5;
|
||||||
|
vec2 iuv = floor( uv );
|
||||||
|
vec2 fuv = fract( uv );
|
||||||
|
|
||||||
|
vec4 mixed = mix(
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 0.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 0.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 1.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 1.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
fuv.y
|
||||||
|
);
|
||||||
|
|
||||||
|
mixed.rgb /= mixed.a;
|
||||||
|
|
||||||
|
return mixed;
|
||||||
|
}
|
||||||
|
|
||||||
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
vec2 tx = 1.0 / sampleDimension;
|
vec2 tx = 1.0 / sampleDimension;
|
||||||
vec2 p = uv * sampleDimension - vec2(0.5);
|
vec2 p = uv * sampleDimension - vec2(0.5);
|
||||||
|
@ -35,7 +59,7 @@ vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
if(a > 1.) continue;
|
if(a > 1.) continue;
|
||||||
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
||||||
vec2 offset = vec2(float(x), float(y)) * tx;
|
vec2 offset = vec2(float(x), float(y)) * tx;
|
||||||
vec4 sample = texture2D(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
vec4 sample = texture2D_bilinear(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
||||||
sum += w * sample;
|
sum += w * sample;
|
||||||
weights += w;
|
weights += w;
|
||||||
}
|
}
|
||||||
|
@ -49,11 +73,12 @@ vec4 texture2D_bicubic( sampler2D texture, vec2 uv ) {
|
||||||
vec2 fuv = fract( uv );
|
vec2 fuv = fract( uv );
|
||||||
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
||||||
uv = (uv - 0.5) / sampleDimension;
|
uv = (uv - 0.5) / sampleDimension;
|
||||||
return texture2D( texture, uv );
|
return texture2D_bilinear( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
||||||
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
||||||
if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
if(interpolation == 1) return texture2D_bilinear( texture, uv );
|
||||||
|
else if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
||||||
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
||||||
return texture2D( texture, uv );
|
return texture2D( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,6 +22,30 @@ const int RSIN_RADIUS = 1;
|
||||||
|
|
||||||
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
||||||
|
|
||||||
|
vec4 texture2D_bilinear( sampler2D texture, vec2 uv ) {
|
||||||
|
uv = uv * sampleDimension - .5;
|
||||||
|
vec2 iuv = floor( uv );
|
||||||
|
vec2 fuv = fract( uv );
|
||||||
|
|
||||||
|
vec4 mixed = mix(
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 0.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 0.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 1.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 1.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
fuv.y
|
||||||
|
);
|
||||||
|
|
||||||
|
mixed.rgb /= mixed.a;
|
||||||
|
|
||||||
|
return mixed;
|
||||||
|
}
|
||||||
|
|
||||||
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
vec2 tx = 1.0 / sampleDimension;
|
vec2 tx = 1.0 / sampleDimension;
|
||||||
vec2 p = uv * sampleDimension - vec2(0.5);
|
vec2 p = uv * sampleDimension - vec2(0.5);
|
||||||
|
@ -35,7 +59,7 @@ vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
if(a > 1.) continue;
|
if(a > 1.) continue;
|
||||||
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
||||||
vec2 offset = vec2(float(x), float(y)) * tx;
|
vec2 offset = vec2(float(x), float(y)) * tx;
|
||||||
vec4 sample = texture2D(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
vec4 sample = texture2D_bilinear(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
||||||
sum += w * sample;
|
sum += w * sample;
|
||||||
weights += w;
|
weights += w;
|
||||||
}
|
}
|
||||||
|
@ -49,11 +73,12 @@ vec4 texture2D_bicubic( sampler2D texture, vec2 uv ) {
|
||||||
vec2 fuv = fract( uv );
|
vec2 fuv = fract( uv );
|
||||||
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
||||||
uv = (uv - 0.5) / sampleDimension;
|
uv = (uv - 0.5) / sampleDimension;
|
||||||
return texture2D( texture, uv );
|
return texture2D_bilinear( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
||||||
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
||||||
if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
if(interpolation == 1) return texture2D_bilinear( texture, uv );
|
||||||
|
else if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
||||||
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
||||||
return texture2D( texture, uv );
|
return texture2D( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,6 +14,30 @@ const int RSIN_RADIUS = 1;
|
||||||
|
|
||||||
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
||||||
|
|
||||||
|
vec4 texture2D_bilinear( sampler2D texture, vec2 uv ) {
|
||||||
|
uv = uv * sampleDimension - .5;
|
||||||
|
vec2 iuv = floor( uv );
|
||||||
|
vec2 fuv = fract( uv );
|
||||||
|
|
||||||
|
vec4 mixed = mix(
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 0.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 0.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 1.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 1.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
fuv.y
|
||||||
|
);
|
||||||
|
|
||||||
|
mixed.rgb /= mixed.a;
|
||||||
|
|
||||||
|
return mixed;
|
||||||
|
}
|
||||||
|
|
||||||
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
vec2 tx = 1.0 / sampleDimension;
|
vec2 tx = 1.0 / sampleDimension;
|
||||||
vec2 p = uv * sampleDimension - vec2(0.5);
|
vec2 p = uv * sampleDimension - vec2(0.5);
|
||||||
|
@ -27,7 +51,7 @@ vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
if(a > 1.) continue;
|
if(a > 1.) continue;
|
||||||
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
||||||
vec2 offset = vec2(float(x), float(y)) * tx;
|
vec2 offset = vec2(float(x), float(y)) * tx;
|
||||||
vec4 sample = texture2D(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
vec4 sample = texture2D_bilinear(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
||||||
sum += w * sample;
|
sum += w * sample;
|
||||||
weights += w;
|
weights += w;
|
||||||
}
|
}
|
||||||
|
@ -41,11 +65,12 @@ vec4 texture2D_bicubic( sampler2D texture, vec2 uv ) {
|
||||||
vec2 fuv = fract( uv );
|
vec2 fuv = fract( uv );
|
||||||
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
||||||
uv = (uv - 0.5) / sampleDimension;
|
uv = (uv - 0.5) / sampleDimension;
|
||||||
return texture2D( texture, uv );
|
return texture2D_bilinear( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
||||||
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
||||||
if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
if(interpolation == 1) return texture2D_bilinear( texture, uv );
|
||||||
|
else if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
||||||
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
||||||
return texture2D( texture, uv );
|
return texture2D( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,6 +17,30 @@ uniform float angle;
|
||||||
|
|
||||||
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
||||||
|
|
||||||
|
vec4 texture2D_bilinear( sampler2D texture, vec2 uv ) {
|
||||||
|
uv = uv * sampleDimension - .5;
|
||||||
|
vec2 iuv = floor( uv );
|
||||||
|
vec2 fuv = fract( uv );
|
||||||
|
|
||||||
|
vec4 mixed = mix(
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 0.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 0.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 1.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 1.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
fuv.y
|
||||||
|
);
|
||||||
|
|
||||||
|
mixed.rgb /= mixed.a;
|
||||||
|
|
||||||
|
return mixed;
|
||||||
|
}
|
||||||
|
|
||||||
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
vec2 tx = 1.0 / sampleDimension;
|
vec2 tx = 1.0 / sampleDimension;
|
||||||
vec2 p = uv * sampleDimension - vec2(0.5);
|
vec2 p = uv * sampleDimension - vec2(0.5);
|
||||||
|
@ -30,7 +54,7 @@ uniform float angle;
|
||||||
if(a > 1.) continue;
|
if(a > 1.) continue;
|
||||||
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
||||||
vec2 offset = vec2(float(x), float(y)) * tx;
|
vec2 offset = vec2(float(x), float(y)) * tx;
|
||||||
vec4 sample = texture2D(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
vec4 sample = texture2D_bilinear(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
||||||
sum += w * sample;
|
sum += w * sample;
|
||||||
weights += w;
|
weights += w;
|
||||||
}
|
}
|
||||||
|
@ -44,11 +68,12 @@ uniform float angle;
|
||||||
vec2 fuv = fract( uv );
|
vec2 fuv = fract( uv );
|
||||||
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
||||||
uv = (uv - 0.5) / sampleDimension;
|
uv = (uv - 0.5) / sampleDimension;
|
||||||
return texture2D( texture, uv );
|
return texture2D_bilinear( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
||||||
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
||||||
if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
if(interpolation == 1) return texture2D_bilinear( texture, uv );
|
||||||
|
else if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
||||||
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
||||||
return texture2D( texture, uv );
|
return texture2D( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,6 +18,30 @@ uniform float angle;
|
||||||
|
|
||||||
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
||||||
|
|
||||||
|
vec4 texture2D_bilinear( sampler2D texture, vec2 uv ) {
|
||||||
|
uv = uv * sampleDimension - .5;
|
||||||
|
vec2 iuv = floor( uv );
|
||||||
|
vec2 fuv = fract( uv );
|
||||||
|
|
||||||
|
vec4 mixed = mix(
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 0.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 0.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 1.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 1.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
fuv.y
|
||||||
|
);
|
||||||
|
|
||||||
|
mixed.rgb /= mixed.a;
|
||||||
|
|
||||||
|
return mixed;
|
||||||
|
}
|
||||||
|
|
||||||
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
vec2 tx = 1.0 / sampleDimension;
|
vec2 tx = 1.0 / sampleDimension;
|
||||||
vec2 p = uv * sampleDimension - vec2(0.5);
|
vec2 p = uv * sampleDimension - vec2(0.5);
|
||||||
|
@ -31,7 +55,7 @@ uniform float angle;
|
||||||
if(a > 1.) continue;
|
if(a > 1.) continue;
|
||||||
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
||||||
vec2 offset = vec2(float(x), float(y)) * tx;
|
vec2 offset = vec2(float(x), float(y)) * tx;
|
||||||
vec4 sample = texture2D(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
vec4 sample = texture2D_bilinear(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
||||||
sum += w * sample;
|
sum += w * sample;
|
||||||
weights += w;
|
weights += w;
|
||||||
}
|
}
|
||||||
|
@ -45,11 +69,12 @@ uniform float angle;
|
||||||
vec2 fuv = fract( uv );
|
vec2 fuv = fract( uv );
|
||||||
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
||||||
uv = (uv - 0.5) / sampleDimension;
|
uv = (uv - 0.5) / sampleDimension;
|
||||||
return texture2D( texture, uv );
|
return texture2D_bilinear( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
||||||
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
||||||
if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
if(interpolation == 1) return texture2D_bilinear( texture, uv );
|
||||||
|
else if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
||||||
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
||||||
return texture2D( texture, uv );
|
return texture2D( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,6 +23,30 @@ const int RSIN_RADIUS = 1;
|
||||||
|
|
||||||
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
||||||
|
|
||||||
|
vec4 texture2D_bilinear( sampler2D texture, vec2 uv ) {
|
||||||
|
uv = uv * sampleDimension - .5;
|
||||||
|
vec2 iuv = floor( uv );
|
||||||
|
vec2 fuv = fract( uv );
|
||||||
|
|
||||||
|
vec4 mixed = mix(
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 0.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 0.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 1.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 1.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
fuv.y
|
||||||
|
);
|
||||||
|
|
||||||
|
mixed.rgb /= mixed.a;
|
||||||
|
|
||||||
|
return mixed;
|
||||||
|
}
|
||||||
|
|
||||||
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
vec2 tx = 1.0 / sampleDimension;
|
vec2 tx = 1.0 / sampleDimension;
|
||||||
vec2 p = uv * sampleDimension - vec2(0.5);
|
vec2 p = uv * sampleDimension - vec2(0.5);
|
||||||
|
@ -36,7 +60,7 @@ vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
if(a > 1.) continue;
|
if(a > 1.) continue;
|
||||||
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
||||||
vec2 offset = vec2(float(x), float(y)) * tx;
|
vec2 offset = vec2(float(x), float(y)) * tx;
|
||||||
vec4 sample = texture2D(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
vec4 sample = texture2D_bilinear(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
||||||
sum += w * sample;
|
sum += w * sample;
|
||||||
weights += w;
|
weights += w;
|
||||||
}
|
}
|
||||||
|
@ -50,11 +74,12 @@ vec4 texture2D_bicubic( sampler2D texture, vec2 uv ) {
|
||||||
vec2 fuv = fract( uv );
|
vec2 fuv = fract( uv );
|
||||||
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
||||||
uv = (uv - 0.5) / sampleDimension;
|
uv = (uv - 0.5) / sampleDimension;
|
||||||
return texture2D( texture, uv );
|
return texture2D_bilinear( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
||||||
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
||||||
if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
if(interpolation == 1) return texture2D_bilinear( texture, uv );
|
||||||
|
else if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
||||||
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
||||||
return texture2D( texture, uv );
|
return texture2D( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
|
@ -28,6 +28,30 @@ const int RSIN_RADIUS = 1;
|
||||||
|
|
||||||
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
||||||
|
|
||||||
|
vec4 texture2D_bilinear( sampler2D texture, vec2 uv ) {
|
||||||
|
uv = uv * sampleDimension - .5;
|
||||||
|
vec2 iuv = floor( uv );
|
||||||
|
vec2 fuv = fract( uv );
|
||||||
|
|
||||||
|
vec4 mixed = mix(
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 0.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 0.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 1.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 1.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
fuv.y
|
||||||
|
);
|
||||||
|
|
||||||
|
mixed.rgb /= mixed.a;
|
||||||
|
|
||||||
|
return mixed;
|
||||||
|
}
|
||||||
|
|
||||||
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
vec2 tx = 1.0 / sampleDimension;
|
vec2 tx = 1.0 / sampleDimension;
|
||||||
vec2 p = uv * sampleDimension - vec2(0.5);
|
vec2 p = uv * sampleDimension - vec2(0.5);
|
||||||
|
@ -41,7 +65,7 @@ vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
if(a > 1.) continue;
|
if(a > 1.) continue;
|
||||||
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
||||||
vec2 offset = vec2(float(x), float(y)) * tx;
|
vec2 offset = vec2(float(x), float(y)) * tx;
|
||||||
vec4 sample = texture2D(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
vec4 sample = texture2D_bilinear(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
||||||
sum += w * sample;
|
sum += w * sample;
|
||||||
weights += w;
|
weights += w;
|
||||||
}
|
}
|
||||||
|
@ -55,11 +79,12 @@ vec4 texture2D_bicubic( sampler2D texture, vec2 uv ) {
|
||||||
vec2 fuv = fract( uv );
|
vec2 fuv = fract( uv );
|
||||||
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
||||||
uv = (uv - 0.5) / sampleDimension;
|
uv = (uv - 0.5) / sampleDimension;
|
||||||
return texture2D( texture, uv );
|
return texture2D_bilinear( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
||||||
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
||||||
if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
if(interpolation == 1) return texture2D_bilinear( texture, uv );
|
||||||
|
else if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
||||||
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
||||||
return texture2D( texture, uv );
|
return texture2D( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,6 +12,30 @@ uniform sampler2D map;
|
||||||
|
|
||||||
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
||||||
|
|
||||||
|
vec4 texture2D_bilinear( sampler2D texture, vec2 uv ) {
|
||||||
|
uv = uv * sampleDimension - .5;
|
||||||
|
vec2 iuv = floor( uv );
|
||||||
|
vec2 fuv = fract( uv );
|
||||||
|
|
||||||
|
vec4 mixed = mix(
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 0.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 0.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 1.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 1.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
fuv.y
|
||||||
|
);
|
||||||
|
|
||||||
|
mixed.rgb /= mixed.a;
|
||||||
|
|
||||||
|
return mixed;
|
||||||
|
}
|
||||||
|
|
||||||
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
vec2 tx = 1.0 / sampleDimension;
|
vec2 tx = 1.0 / sampleDimension;
|
||||||
vec2 p = uv * sampleDimension - vec2(0.5);
|
vec2 p = uv * sampleDimension - vec2(0.5);
|
||||||
|
@ -25,7 +49,7 @@ uniform sampler2D map;
|
||||||
if(a > 1.) continue;
|
if(a > 1.) continue;
|
||||||
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
||||||
vec2 offset = vec2(float(x), float(y)) * tx;
|
vec2 offset = vec2(float(x), float(y)) * tx;
|
||||||
vec4 sample = texture2D(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
vec4 sample = texture2D_bilinear(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
||||||
sum += w * sample;
|
sum += w * sample;
|
||||||
weights += w;
|
weights += w;
|
||||||
}
|
}
|
||||||
|
@ -39,14 +63,16 @@ uniform sampler2D map;
|
||||||
vec2 fuv = fract( uv );
|
vec2 fuv = fract( uv );
|
||||||
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
||||||
uv = (uv - 0.5) / sampleDimension;
|
uv = (uv - 0.5) / sampleDimension;
|
||||||
return texture2D( texture, uv );
|
return texture2D_bilinear( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
||||||
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
||||||
if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
if(interpolation == 1) return texture2D_bilinear( texture, uv );
|
||||||
|
else if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
||||||
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
||||||
return texture2D( texture, uv );
|
return texture2D( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
void main() {
|
void main() {
|
||||||
|
|
|
@ -26,6 +26,30 @@ const int RSIN_RADIUS = 1;
|
||||||
|
|
||||||
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
||||||
|
|
||||||
|
vec4 texture2D_bilinear( sampler2D texture, vec2 uv ) {
|
||||||
|
uv = uv * sampleDimension - .5;
|
||||||
|
vec2 iuv = floor( uv );
|
||||||
|
vec2 fuv = fract( uv );
|
||||||
|
|
||||||
|
vec4 mixed = mix(
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 0.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 0.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 1.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 1.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
fuv.y
|
||||||
|
);
|
||||||
|
|
||||||
|
mixed.rgb /= mixed.a;
|
||||||
|
|
||||||
|
return mixed;
|
||||||
|
}
|
||||||
|
|
||||||
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
vec2 tx = 1.0 / sampleDimension;
|
vec2 tx = 1.0 / sampleDimension;
|
||||||
vec2 p = uv * sampleDimension - vec2(0.5);
|
vec2 p = uv * sampleDimension - vec2(0.5);
|
||||||
|
@ -39,7 +63,7 @@ vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
if(a > 1.) continue;
|
if(a > 1.) continue;
|
||||||
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
||||||
vec2 offset = vec2(float(x), float(y)) * tx;
|
vec2 offset = vec2(float(x), float(y)) * tx;
|
||||||
vec4 sample = texture2D(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
vec4 sample = texture2D_bilinear(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
||||||
sum += w * sample;
|
sum += w * sample;
|
||||||
weights += w;
|
weights += w;
|
||||||
}
|
}
|
||||||
|
@ -53,11 +77,12 @@ vec4 texture2D_bicubic( sampler2D texture, vec2 uv ) {
|
||||||
vec2 fuv = fract( uv );
|
vec2 fuv = fract( uv );
|
||||||
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
||||||
uv = (uv - 0.5) / sampleDimension;
|
uv = (uv - 0.5) / sampleDimension;
|
||||||
return texture2D( texture, uv );
|
return texture2D_bilinear( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
||||||
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
||||||
if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
if(interpolation == 1) return texture2D_bilinear( texture, uv );
|
||||||
|
else if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
||||||
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
||||||
return texture2D( texture, uv );
|
return texture2D( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,6 +17,30 @@ uniform vec2 dimension;
|
||||||
|
|
||||||
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
||||||
|
|
||||||
|
vec4 texture2D_bilinear( sampler2D texture, vec2 uv ) {
|
||||||
|
uv = uv * sampleDimension - .5;
|
||||||
|
vec2 iuv = floor( uv );
|
||||||
|
vec2 fuv = fract( uv );
|
||||||
|
|
||||||
|
vec4 mixed = mix(
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 0.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 0.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 1.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 1.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
fuv.y
|
||||||
|
);
|
||||||
|
|
||||||
|
mixed.rgb /= mixed.a;
|
||||||
|
|
||||||
|
return mixed;
|
||||||
|
}
|
||||||
|
|
||||||
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
vec2 tx = 1.0 / sampleDimension;
|
vec2 tx = 1.0 / sampleDimension;
|
||||||
vec2 p = uv * sampleDimension - vec2(0.5);
|
vec2 p = uv * sampleDimension - vec2(0.5);
|
||||||
|
@ -30,7 +54,7 @@ uniform vec2 dimension;
|
||||||
if(a > 1.) continue;
|
if(a > 1.) continue;
|
||||||
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
||||||
vec2 offset = vec2(float(x), float(y)) * tx;
|
vec2 offset = vec2(float(x), float(y)) * tx;
|
||||||
vec4 sample = texture2D(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
vec4 sample = texture2D_bilinear(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
||||||
sum += w * sample;
|
sum += w * sample;
|
||||||
weights += w;
|
weights += w;
|
||||||
}
|
}
|
||||||
|
@ -44,11 +68,12 @@ uniform vec2 dimension;
|
||||||
vec2 fuv = fract( uv );
|
vec2 fuv = fract( uv );
|
||||||
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
||||||
uv = (uv - 0.5) / sampleDimension;
|
uv = (uv - 0.5) / sampleDimension;
|
||||||
return texture2D( texture, uv );
|
return texture2D_bilinear( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
||||||
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
||||||
if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
if(interpolation == 1) return texture2D_bilinear( texture, uv );
|
||||||
|
else if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
||||||
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
||||||
return texture2D( texture, uv );
|
return texture2D( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,6 +23,30 @@ const int RSIN_RADIUS = 1;
|
||||||
|
|
||||||
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
float sinc ( float x ) { return x == 0.? 1. : sin(x * PI) / (x * PI); }
|
||||||
|
|
||||||
|
vec4 texture2D_bilinear( sampler2D texture, vec2 uv ) {
|
||||||
|
uv = uv * sampleDimension - .5;
|
||||||
|
vec2 iuv = floor( uv );
|
||||||
|
vec2 fuv = fract( uv );
|
||||||
|
|
||||||
|
vec4 mixed = mix(
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 0.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 0.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
mix(
|
||||||
|
texture2D( texture, (iuv + vec2(0., 1.)) / sampleDimension ),
|
||||||
|
texture2D( texture, (iuv + vec2(1., 1.)) / sampleDimension ),
|
||||||
|
fuv.x
|
||||||
|
),
|
||||||
|
fuv.y
|
||||||
|
);
|
||||||
|
|
||||||
|
mixed.rgb /= mixed.a;
|
||||||
|
|
||||||
|
return mixed;
|
||||||
|
}
|
||||||
|
|
||||||
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
vec2 tx = 1.0 / sampleDimension;
|
vec2 tx = 1.0 / sampleDimension;
|
||||||
vec2 p = uv * sampleDimension - vec2(0.5);
|
vec2 p = uv * sampleDimension - vec2(0.5);
|
||||||
|
@ -36,7 +60,7 @@ vec4 texture2D_rsin( sampler2D texture, vec2 uv ) {
|
||||||
if(a > 1.) continue;
|
if(a > 1.) continue;
|
||||||
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
float w = sinc(a * PI * tx.x) * sinc(a * PI * tx.y);
|
||||||
vec2 offset = vec2(float(x), float(y)) * tx;
|
vec2 offset = vec2(float(x), float(y)) * tx;
|
||||||
vec4 sample = texture2D(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
vec4 sample = texture2D_bilinear(texture, (p + offset + vec2(0.5)) / sampleDimension);
|
||||||
sum += w * sample;
|
sum += w * sample;
|
||||||
weights += w;
|
weights += w;
|
||||||
}
|
}
|
||||||
|
@ -50,11 +74,12 @@ vec4 texture2D_bicubic( sampler2D texture, vec2 uv ) {
|
||||||
vec2 fuv = fract( uv );
|
vec2 fuv = fract( uv );
|
||||||
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
uv = iuv + fuv * fuv * (3.0 - 2.0 * fuv);
|
||||||
uv = (uv - 0.5) / sampleDimension;
|
uv = (uv - 0.5) / sampleDimension;
|
||||||
return texture2D( texture, uv );
|
return texture2D_bilinear( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
||||||
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
|
||||||
if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
if(interpolation == 1) return texture2D_bilinear( texture, uv );
|
||||||
|
else if(interpolation == 2) return texture2D_bicubic( texture, uv );
|
||||||
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
else if(interpolation == 3) return texture2D_rsin( texture, uv );
|
||||||
return texture2D( texture, uv );
|
return texture2D( texture, uv );
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue