alpha compensated bilinear

This commit is contained in:
Tanasart 2024-05-17 10:19:11 +07:00
parent 2ff87ff393
commit 1b1341757d
27 changed files with 655 additions and 155 deletions

View file

@ -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,
@ -176,10 +180,10 @@ function Node_VFX_Spawner_Base(_x, _y, _group = noone) : Node(_x, _y, _group) co
array_push(attributeEditors, ["Maximum particles", function() { return attributes.part_amount; }, array_push(attributeEditors, ["Maximum particles", function() { return attributes.part_amount; },
new textBox(TEXTBOX_INPUT.number, function(val) { attributes.part_amount = val; }) ]); new textBox(TEXTBOX_INPUT.number, function(val) { attributes.part_amount = val; }) ]);
parts = array_create(attributes.part_amount); parts = array_create(attributes.part_amount);
parts_runner = 0; parts_runner = 0;
seed = 0; seed = 0;
spawn_index = 0; spawn_index = 0;
scatter_index = 0; scatter_index = 0;
def_surface = -1; def_surface = -1;
@ -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

View file

@ -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];

View file

@ -28,10 +28,13 @@ function Node_Glow(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) cons
.setDisplay(VALUE_DISPLAY.enum_button, [ "Greyscale", "Alpha" ]); .setDisplay(VALUE_DISPLAY.enum_button, [ "Greyscale", "Alpha" ]);
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();

View file

@ -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];

View file

@ -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);

View file

@ -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();
@ -232,10 +239,11 @@
map.preferences = PREFERENCES; map.preferences = PREFERENCES;
json_save_struct(DIRECTORY + "keys.json", map); json_save_struct(DIRECTORY + "keys.json", map);
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

View file

@ -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);

View file

@ -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);

View file

@ -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,12 +75,13 @@ 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 == 3) return texture2D_rsin( texture, uv ); else if(interpolation == 2) return texture2D_bicubic( texture, uv );
else if(interpolation == 3) return texture2D_rsin( texture, uv );
return texture2D( texture, uv ); return texture2D( texture, uv );
} }

View file

@ -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 == 3) return texture2D_rsin( texture, uv ); else if(interpolation == 2) return texture2D_bicubic( 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

View file

@ -14,13 +14,37 @@ uniform sampler2D strengthSurf;
#region /////////////// SAMPLING /////////////// #region /////////////// SAMPLING ///////////////
const float PI = 3.14159265358979323846; const float PI = 3.14159265358979323846;
uniform int interpolation; uniform int interpolation;
uniform vec2 sampleDimension; uniform vec2 sampleDimension;
const int RSIN_RADIUS = 1; 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,12 +72,13 @@ 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 == 3) return texture2D_rsin( texture, uv ); else if(interpolation == 2) return texture2D_bicubic( 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;
} }

View file

@ -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,12 +77,13 @@ 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 == 3) return texture2D_rsin( texture, uv ); else if(interpolation == 2) return texture2D_bicubic( texture, uv );
else if(interpolation == 3) return texture2D_rsin( texture, uv );
return texture2D( texture, uv ); return texture2D( texture, uv );
} }

View file

@ -29,58 +29,76 @@ float bright(in vec4 col) { return dot(col.rgb, vec3(0.2126, 0.7152, 0.0722)) *
const int RSIN_RADIUS = 1; 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);
vec4 sum = vec4(0.0); vec4 sum = vec4(0.0);
float weights = 0.; float weights = 0.;
for (int x = -RSIN_RADIUS; x <= RSIN_RADIUS; x++) for (int x = -RSIN_RADIUS; x <= RSIN_RADIUS; x++)
for (int y = -RSIN_RADIUS; y <= RSIN_RADIUS; y++) { for (int y = -RSIN_RADIUS; y <= RSIN_RADIUS; y++) {
float a = length(vec2(float(x), float(y))) / float(RSIN_RADIUS); float a = length(vec2(float(x), float(y))) / float(RSIN_RADIUS);
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;
} }
return sum / weights; return sum / weights;
} }
vec4 texture2D_bicubic( sampler2D texture, vec2 uv ) { vec4 texture2D_bicubic( sampler2D texture, vec2 uv ) {
uv = uv * sampleDimension + 0.5; uv = uv * sampleDimension + 0.5;
vec2 iuv = floor( uv ); vec2 iuv = floor( 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 == 3) return texture2D_rsin( texture, uv ); else if(interpolation == 2) return texture2D_bicubic( texture, uv );
else if(interpolation == 3) return texture2D_rsin( texture, uv );
return texture2D( texture, uv ); return texture2D( texture, uv );
} }
vec4 sampleTexture(vec2 pos) { vec4 sampleTexture(vec2 pos) {
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.);
} }

View file

@ -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,12 +69,13 @@ 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 == 3) return texture2D_rsin( texture, uv ); else if(interpolation == 2) return texture2D_bicubic( texture, uv );
else if(interpolation == 3) return texture2D_rsin( texture, uv );
return texture2D( texture, uv ); return texture2D( texture, uv );
} }

View file

@ -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,12 +69,13 @@ 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 == 3) return texture2D_rsin( texture, uv ); else if(interpolation == 2) return texture2D_bicubic( texture, uv );
else if(interpolation == 3) return texture2D_rsin( texture, uv );
return texture2D( texture, uv ); return texture2D( texture, uv );
} }

View file

@ -10,18 +10,18 @@ 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; }
vec4 sample(vec2 pos) { return texture2D( gm_BaseTexture, pos ); } vec4 sample(vec2 pos) { return texture2D( gm_BaseTexture, pos ); }
float round(float val) { return fract(val) > 0.5? ceil(val) : floor(val); } float round(float val) { return fract(val) > 0.5? ceil(val) : floor(val); }
vec2 round(vec2 val) { return vec2(round(val.x), round(val.y)); } 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,25 +31,38 @@ void main() {
if(mode == 1) gl_FragColor = vec4(0., 0., 0., 0.); if(mode == 1) gl_FragColor = vec4(0., 0., 0., 0.);
} }
if(mode == 0 && base.rgb == vec3(1.)) return; if(side == 0) {
if(mode == 1 && base.a == 1.) return; if(mode == 0 && base.rgb == vec3(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((mode == 0 && bright(samp) > bright(base)) || (mode == 1 && samp.a > base.a)) { if(side == 0) {
dist = i; if((mode == 0 && bright(samp) > bright(base)) || (mode == 1 && samp.a > base.a)) {
i = size; dist = i;
break; i = size;
break;
}
} else if(side == 1) {
if((mode == 0 && bright(samp) < bright(base)) || (mode == 1 && samp.a < base.a)) {
dist = i;
i = size;
break;
}
} }
} }
@ -57,10 +70,12 @@ void main() {
vec4 cc = color; vec4 cc = color;
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;
} }
} }

View file

@ -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,12 +73,13 @@ 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 == 3) return texture2D_rsin( texture, uv ); else if(interpolation == 2) return texture2D_bicubic( texture, uv );
else if(interpolation == 3) return texture2D_rsin( texture, uv );
return texture2D( texture, uv ); return texture2D( texture, uv );
} }

View file

@ -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,12 +73,13 @@ 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 == 3) return texture2D_rsin( texture, uv ); else if(interpolation == 2) return texture2D_bicubic( texture, uv );
else if(interpolation == 3) return texture2D_rsin( texture, uv );
return texture2D( texture, uv ); return texture2D( texture, uv );
} }

View file

@ -7,13 +7,37 @@ varying vec4 v_vColour;
#region /////////////// SAMPLING /////////////// #region /////////////// SAMPLING ///////////////
const float PI = 3.14159265358979323846; const float PI = 3.14159265358979323846;
uniform int interpolation; uniform int interpolation;
uniform vec2 sampleDimension; uniform vec2 sampleDimension;
const int RSIN_RADIUS = 1; 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,12 +65,13 @@ 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 == 3) return texture2D_rsin( texture, uv ); else if(interpolation == 2) return texture2D_bicubic( texture, uv );
else if(interpolation == 3) return texture2D_rsin( texture, uv );
return texture2D( texture, uv ); return texture2D( texture, uv );
} }

View file

@ -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,12 +68,13 @@ 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 == 3) return texture2D_rsin( texture, uv ); else if(interpolation == 2) return texture2D_bicubic( texture, uv );
else if(interpolation == 3) return texture2D_rsin( texture, uv );
return texture2D( texture, uv ); return texture2D( texture, uv );
} }

View file

@ -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,12 +69,13 @@ 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 == 3) return texture2D_rsin( texture, uv ); else if(interpolation == 2) return texture2D_bicubic( texture, uv );
else if(interpolation == 3) return texture2D_rsin( texture, uv );
return texture2D( texture, uv ); return texture2D( texture, uv );
} }

View file

@ -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,12 +74,13 @@ 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 == 3) return texture2D_rsin( texture, uv ); else if(interpolation == 2) return texture2D_bicubic( texture, uv );
else if(interpolation == 3) return texture2D_rsin( texture, uv );
return texture2D( texture, uv ); return texture2D( texture, uv );
} }

View file

@ -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,12 +79,13 @@ 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 == 3) return texture2D_rsin( texture, uv ); else if(interpolation == 2) return texture2D_bicubic( texture, uv );
else if(interpolation == 3) return texture2D_rsin( texture, uv );
return texture2D( texture, uv ); return texture2D( texture, uv );
} }

View file

@ -12,41 +12,67 @@ 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);
vec4 sum = vec4(0.0); vec4 sum = vec4(0.0);
float weights = 0.; float weights = 0.;
for (int x = -RSIN_RADIUS; x <= RSIN_RADIUS; x++) for (int x = -RSIN_RADIUS; x <= RSIN_RADIUS; x++)
for (int y = -RSIN_RADIUS; y <= RSIN_RADIUS; y++) { for (int y = -RSIN_RADIUS; y <= RSIN_RADIUS; y++) {
float a = length(vec2(float(x), float(y))) / float(RSIN_RADIUS); float a = length(vec2(float(x), float(y))) / float(RSIN_RADIUS);
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;
} }
return sum / weights; return sum / weights;
} }
vec4 texture2D_bicubic( sampler2D texture, vec2 uv ) { vec4 texture2D_bicubic( sampler2D texture, vec2 uv ) {
uv = uv * sampleDimension + 0.5; uv = uv * sampleDimension + 0.5;
vec2 iuv = floor( uv ); vec2 iuv = floor( 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_bilinear( texture, uv );
}
vec4 texture2Dintp( sampler2D texture, vec2 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 );
return texture2D( texture, uv ); return texture2D( texture, uv );
} }
vec4 texture2Dintp( sampler2D texture, vec2 uv ) {
if(interpolation == 2) return texture2D_bicubic( texture, uv );
else if(interpolation == 3) return texture2D_rsin( texture, uv );
return texture2D( texture, uv );
}
#endregion #endregion
void main() { void main() {

View file

@ -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,12 +77,13 @@ 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 == 3) return texture2D_rsin( texture, uv ); else if(interpolation == 2) return texture2D_bicubic( texture, uv );
else if(interpolation == 3) return texture2D_rsin( texture, uv );
return texture2D( texture, uv ); return texture2D( texture, uv );
} }

View file

@ -16,40 +16,65 @@ uniform vec2 dimension;
const int RSIN_RADIUS = 1; 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);
vec4 sum = vec4(0.0); vec4 sum = vec4(0.0);
float weights = 0.; float weights = 0.;
for (int x = -RSIN_RADIUS; x <= RSIN_RADIUS; x++) for (int x = -RSIN_RADIUS; x <= RSIN_RADIUS; x++)
for (int y = -RSIN_RADIUS; y <= RSIN_RADIUS; y++) { for (int y = -RSIN_RADIUS; y <= RSIN_RADIUS; y++) {
float a = length(vec2(float(x), float(y))) / float(RSIN_RADIUS); float a = length(vec2(float(x), float(y))) / float(RSIN_RADIUS);
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;
} }
return sum / weights; return sum / weights;
} }
vec4 texture2D_bicubic( sampler2D texture, vec2 uv ) { vec4 texture2D_bicubic( sampler2D texture, vec2 uv ) {
uv = uv * sampleDimension + 0.5; uv = uv * sampleDimension + 0.5;
vec2 iuv = floor( uv ); vec2 iuv = floor( 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 == 3) return texture2D_rsin( texture, uv ); else if(interpolation == 2) return texture2D_bicubic( texture, uv );
else if(interpolation == 3) return texture2D_rsin( texture, uv );
return texture2D( texture, uv ); return texture2D( texture, uv );
} }

View file

@ -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,12 +74,13 @@ 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 == 3) return texture2D_rsin( texture, uv ); else if(interpolation == 2) return texture2D_bicubic( texture, uv );
else if(interpolation == 3) return texture2D_rsin( texture, uv );
return texture2D( texture, uv ); return texture2D( texture, uv );
} }