|
|
@@ -73,6 +73,7 @@ static void apply_unsharp( uint8_t *dst, int dst_stride, |
|
|
|
|
|
|
|
int32_t res; |
|
|
|
int x, y, z; |
|
|
|
const uint8_t *src2; |
|
|
|
|
|
|
|
if (!fp->amount) { |
|
|
|
if (dst_stride == src_stride) |
|
|
@@ -87,9 +88,12 @@ static void apply_unsharp( uint8_t *dst, int dst_stride, |
|
|
|
memset(sc[y], 0, sizeof(sc[y][0]) * (width + 2 * fp->steps_x)); |
|
|
|
|
|
|
|
for (y = -fp->steps_y; y < height + fp->steps_y; y++) { |
|
|
|
if (y < height) |
|
|
|
src2 = src; |
|
|
|
|
|
|
|
memset(sr, 0, sizeof(sr[0]) * (2 * fp->steps_x - 1)); |
|
|
|
for (x = -fp->steps_x; x < width + fp->steps_x; x++) { |
|
|
|
tmp1 = x <= 0 ? src[0] : x >= width ? src[width-1] : src[x]; |
|
|
|
tmp1 = x <= 0 ? src2[0] : x >= width ? src2[width-1] : src2[x]; |
|
|
|
for (z = 0; z < fp->steps_x * 2; z += 2) { |
|
|
|
tmp2 = sr[z + 0] + tmp1; sr[z + 0] = tmp1; |
|
|
|
tmp1 = sr[z + 1] + tmp2; sr[z + 1] = tmp2; |
|
|
|