X-Git-Url: https://git.sesse.net/?p=movit;a=blobdiff_plain;f=slice_effect.frag;h=e77c9fad7bf39e38444724d5879df64710f074f4;hp=84165154b3f01b7e795fee7dc9b14e0ea71dd005;hb=95edbfccb0843da3cc105dadc5bc6d8e102f6071;hpb=8c7e53028a3ef4805d2608643041a5d7e6bd1b6e diff --git a/slice_effect.frag b/slice_effect.frag index 8416515..e77c9fa 100644 --- a/slice_effect.frag +++ b/slice_effect.frag @@ -1,12 +1,13 @@ uniform float PREFIX(output_coord_to_slice_num); uniform float PREFIX(slice_num_to_input_coord); uniform float PREFIX(slice_offset_to_input_coord); +uniform float PREFIX(offset); vec4 FUNCNAME(vec2 tc) { // DIRECTION_VERTICAL will be #defined to 1 if we are expanding vertically, // and 0 otherwise. #if DIRECTION_VERTICAL - float sliced_coord = tc.y; + float sliced_coord = 1.0 - tc.y; #else float sliced_coord = tc.x; #endif @@ -16,11 +17,13 @@ vec4 FUNCNAME(vec2 tc) { float slice_offset = fract(sliced_coord * PREFIX(output_coord_to_slice_num)); // Find out where this slice begins in the input data, and then offset from that. - float input_coord = slice_num * PREFIX(slice_num_to_input_coord) + slice_offset * PREFIX(slice_offset_to_input_coord); + float input_coord = slice_num * PREFIX(slice_num_to_input_coord) + slice_offset * PREFIX(slice_offset_to_input_coord) + PREFIX(offset); #if DIRECTION_VERTICAL - return INPUT(vec2(tc.x, input_coord)); + return INPUT(vec2(tc.x, 1.0 - input_coord)); #else return INPUT(vec2(input_coord, tc.y)); #endif } + +#undef DIRECTION_VERTICAL