|
DCMTK
Version 3.6.1 20120515
OFFIS DICOM Toolkit
|
Template class to scale images (on pixel data level). More...
Inheritance diagram for DiScaleTemplate< T >:Public Member Functions | |
| DiScaleTemplate (const int planes, const Uint16 columns, const Uint16 rows, const signed long left_pos, const signed long top_pos, const Uint16 src_cols, const Uint16 src_rows, const Uint16 dest_cols, const Uint16 dest_rows, const Uint32 frames, const int bits=0) | |
| constructor, scale clipping area. | |
| DiScaleTemplate (const int planes, const Uint16 src_cols, const Uint16 src_rows, const Uint16 dest_cols, const Uint16 dest_rows, const Uint32 frames, const int bits=0) | |
| constructor, scale whole image. | |
| virtual | ~DiScaleTemplate () |
| destructor | |
| int | isSigned () const |
| check whether template type T is signed or not | |
| void | scaleData (const T *src[], T *dest[], const int interpolate, const T value=0) |
| choose scaling/clipping algorithm depending on specified parameters. | |
Protected Attributes | |
| const signed long | Left |
| left coordinate of clipping area | |
| const signed long | Top |
| top coordinate of clipping area | |
| const Uint16 | Columns |
| width of source image | |
| const Uint16 | Rows |
| height of source image | |
Private Member Functions | |
| void | clipPixel (const T *src[], T *dest[]) |
| clip image to specified area (only inside image boundaries). | |
| void | clipBorderPixel (const T *src[], T *dest[], const T value) |
| clip image to specified area and add a border if necessary | |
| void | replicatePixel (const T *src[], T *dest[]) |
| enlarge image by an integer factor. | |
| void | suppressPixel (const T *src[], T *dest[]) |
| shrink image by an integer divisor. | |
| void | scalePixel (const T *src[], T *dest[]) |
| free scaling method without interpolation. | |
| void | interpolatePixel (const T *src[], T *dest[]) |
| free scaling method with interpolation | |
| void | expandPixel (const T *src[], T *dest[]) |
| free scaling method with interpolation (only for magnification) | |
| void | reducePixel (const T *src[], T *dest[]) |
| free scaling method with interpolation (only for reduction) | |
| void | bilinearPixel (const T *src[], T *dest[]) |
| bilinear interpolation method (only for magnification) | |
| void | bicubicPixel (const T *src[], T *dest[]) |
| bicubic interpolation method (only for magnification) | |
Template class to scale images (on pixel data level).
with and without interpolation
| DiScaleTemplate< T >::DiScaleTemplate | ( | const int | planes, |
| const Uint16 | columns, | ||
| const Uint16 | rows, | ||
| const signed long | left_pos, | ||
| const signed long | top_pos, | ||
| const Uint16 | src_cols, | ||
| const Uint16 | src_rows, | ||
| const Uint16 | dest_cols, | ||
| const Uint16 | dest_rows, | ||
| const Uint32 | frames, | ||
| const int | bits = 0 |
||
| ) | [inline] |
constructor, scale clipping area.
| planes | number of planes (1 or 3) |
| columns | width of source image |
| rows | height of source image |
| left_pos | left coordinate of clipping area |
| top_pos | top coordinate of clipping area |
| src_cols | width of clipping area |
| src_rows | height of clipping area |
| dest_cols | width of destination image (scaled image) |
| dest_rows | height of destination image |
| frames | number of frames |
| bits | number of bits per plane/pixel |
| DiScaleTemplate< T >::DiScaleTemplate | ( | const int | planes, |
| const Uint16 | src_cols, | ||
| const Uint16 | src_rows, | ||
| const Uint16 | dest_cols, | ||
| const Uint16 | dest_rows, | ||
| const Uint32 | frames, | ||
| const int | bits = 0 |
||
| ) | [inline] |
constructor, scale whole image.
| planes | number of planes (1 or 3) |
| src_cols | width of source image |
| src_rows | height of source image |
| dest_cols | width of destination image (scaled image) |
| dest_rows | height of destination image |
| frames | number of frames |
| bits | number of bits per plane/pixel |
| void DiScaleTemplate< T >::bicubicPixel | ( | const T * | src[], |
| T * | dest[] | ||
| ) | [inline, private] |
bicubic interpolation method (only for magnification)
| src | array of pointers to source image pixels |
| dest | array of pointers to destination image pixels |
| void DiScaleTemplate< T >::bilinearPixel | ( | const T * | src[], |
| T * | dest[] | ||
| ) | [inline, private] |
bilinear interpolation method (only for magnification)
| src | array of pointers to source image pixels |
| dest | array of pointers to destination image pixels |
| void DiScaleTemplate< T >::clipBorderPixel | ( | const T * | src[], |
| T * | dest[], | ||
| const T | value | ||
| ) | [inline, private] |
clip image to specified area and add a border if necessary
| src | array of pointers to source image pixels |
| dest | array of pointers to destination image pixels |
| value | value to be set outside the image boundaries |
| void DiScaleTemplate< T >::clipPixel | ( | const T * | src[], |
| T * | dest[] | ||
| ) | [inline, private] |
clip image to specified area (only inside image boundaries).
This is an optimization of the more general method clipBorderPixel().
| src | array of pointers to source image pixels |
| dest | array of pointers to destination image pixels |
| void DiScaleTemplate< T >::expandPixel | ( | const T * | src[], |
| T * | dest[] | ||
| ) | [inline, private] |
free scaling method with interpolation (only for magnification)
| src | array of pointers to source image pixels |
| dest | array of pointers to destination image pixels |
| void DiScaleTemplate< T >::interpolatePixel | ( | const T * | src[], |
| T * | dest[] | ||
| ) | [inline, private] |
free scaling method with interpolation
| src | array of pointers to source image pixels |
| dest | array of pointers to destination image pixels |
| int DiScaleTemplate< T >::isSigned | ( | ) | const [inline] |
check whether template type T is signed or not
| void DiScaleTemplate< T >::reducePixel | ( | const T * | src[], |
| T * | dest[] | ||
| ) | [inline, private] |
free scaling method with interpolation (only for reduction)
| src | array of pointers to source image pixels |
| dest | array of pointers to destination image pixels |
| void DiScaleTemplate< T >::replicatePixel | ( | const T * | src[], |
| T * | dest[] | ||
| ) | [inline, private] |
enlarge image by an integer factor.
Pixels are replicated independently in both directions.
| src | array of pointers to source image pixels |
| dest | array of pointers to destination image pixels |
| void DiScaleTemplate< T >::scaleData | ( | const T * | src[], |
| T * | dest[], | ||
| const int | interpolate, | ||
| const T | value = 0 |
||
| ) | [inline] |
choose scaling/clipping algorithm depending on specified parameters.
| src | array of pointers to source image pixels |
| dest | array of pointers to destination image pixels |
| interpolate | preferred interpolation algorithm (0 = no interpolation, 1 = pbmplus algorithm, 2 = c't algorithm, 3 = bilinear magnification, 4 = bicubic magnification) |
| value | value to be set outside the image boundaries (used for clipping, default: 0) |
| void DiScaleTemplate< T >::scalePixel | ( | const T * | src[], |
| T * | dest[] | ||
| ) | [inline, private] |
free scaling method without interpolation.
This algorithm is necessary for overlays (1 bpp).
| src | array of pointers to source image pixels |
| dest | array of pointers to destination image pixels |
| void DiScaleTemplate< T >::suppressPixel | ( | const T * | src[], |
| T * | dest[] | ||
| ) | [inline, private] |
shrink image by an integer divisor.
Pixels are suppressed independently in both directions.
| src | array of pointers to source image pixels |
| dest | array of pointers to destination image pixels |