This commit is contained in:
John Cupitt 2009-03-23 17:38:14 +00:00
parent 56573a82e8
commit 6f2e74de81
4 changed files with 18 additions and 8 deletions

View File

@ -6,6 +6,8 @@
- saner im_buildlut() behaviour - saner im_buildlut() behaviour
- added im_gauss_imask_sep() - added im_gauss_imask_sep()
- allow open of truncated images, but block pixel access - allow open of truncated images, but block pixel access
- revising rounding on im_affine*() coordinate transforms to make them more
stable
3/3/09 started 7.17.2 3/3/09 started 7.17.2
- im_magick2vips.c: allow funky bit depths, like 14 (thanks Mikkel) - im_magick2vips.c: allow funky bit depths, like 14 (thanks Mikkel)

7
TODO
View File

@ -1,3 +1,10 @@
- try
vips im_affinei_all ~/in.v ~/out.v bilinear 1.0928961748633881 0 0 1 0 0
where in.v is a 366 pixel wide image, and 1.092... is (400 / 366)
- mask subscript in Pythion seems to be broken - mask subscript in Pythion seems to be broken
>>> from vipsCC import * >>> from vipsCC import *

View File

@ -231,9 +231,9 @@ affinei_gen( REGION *or, void *seq, void *a, void *b )
need.left += iarea->left; need.left += iarea->left;
need.top += iarea->top; need.top += iarea->top;
/* Add a border for interpolation. /* Add a border for interpolation. Plus one for rounding errors.
*/ */
im_rect_marginadjust( &need, half_window_size ); im_rect_marginadjust( &need, half_window_size + 1 );
/* Clip against the size of (2). /* Clip against the size of (2).
*/ */

View File

@ -197,17 +197,18 @@ transform_rect( const Transformation *trn, transform_fn transform,
transform( trn, IM_RECT_RIGHT( in ), in->top, &x2, &y2 ); transform( trn, IM_RECT_RIGHT( in ), in->top, &x2, &y2 );
transform( trn, IM_RECT_RIGHT( in ), IM_RECT_BOTTOM( in ), &x4, &y4 ); transform( trn, IM_RECT_RIGHT( in ), IM_RECT_BOTTOM( in ), &x4, &y4 );
/* Find bounding box for these four corners. /* Find bounding box for these four corners. Round-to-nearest to try
* to stop rounding errors growing images.
*/ */
left = IM_MIN( x1, IM_MIN( x2, IM_MIN( x3, x4 ) ) ); left = IM_MIN( x1, IM_MIN( x2, IM_MIN( x3, x4 ) ) );
right = IM_MAX( x1, IM_MAX( x2, IM_MAX( x3, x4 ) ) ); right = IM_MAX( x1, IM_MAX( x2, IM_MAX( x3, x4 ) ) );
top = IM_MIN( y1, IM_MIN( y2, IM_MIN( y3, y4 ) ) ); top = IM_MIN( y1, IM_MIN( y2, IM_MIN( y3, y4 ) ) );
bottom = IM_MAX( y1, IM_MAX( y2, IM_MAX( y3, y4 ) ) ); bottom = IM_MAX( y1, IM_MAX( y2, IM_MAX( y3, y4 ) ) );
out->left = floor( left ); out->left = IM_RINT( left );
out->top = floor( top ); out->top = IM_RINT( top );
out->width = ceil( right ) - out->left; out->width = IM_RINT( right - left );
out->height = ceil( bottom ) - out->top; out->height = IM_RINT( bottom - top );
} }
/* Given an area in the input image, calculate the bounding box for those /* Given an area in the input image, calculate the bounding box for those