The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.

NAME

Image::Leptonica::Func::rotateorthlow

VERSION

version 0.03

rotateorthlow.c

  rotateorthlow.c

      90-degree rotation (cw)
            void      rotate90Low()

      LR-flip
            void      flipLRLow()

      TB-flip
            void      flipTBLow()

      Byte reverse tables
            l_uint8  *makeReverseByteTab1()
            l_uint8  *makeReverseByteTab2()
            l_uint8  *makeReverseByteTab4()

FUNCTIONS

flipLRLow

void flipLRLow ( l_uint32 *data, l_int32 w, l_int32 h, l_int32 d, l_int32 wpl, l_uint8 *tab, l_uint32 *buffer )

  flipLRLow()

  Notes:
      (1) The pixel access routines allow a trivial implementation.
          However, for d < 8, it is more efficient to right-justify
          each line to a 32-bit boundary and then extract bytes and
          do pixel reversing.   In those cases, as in the 180 degree
          rotation, we right-shift the data (if necessary) to
          right-justify on the 32 bit boundary, and then read the
          bytes off each raster line in reverse order, reversing
          the pixels in each byte using a table.  These functions
          for 1, 2 and 4 bpp were tested against the "trivial"
          version (shown here for 4 bpp):
              for (i = 0; i < h; i++) {
                  line = data + i * wpl;
                  memcpy(buffer, line, bpl);
                    for (j = 0; j < w; j++) {
                      val = GET_DATA_QBIT(buffer, w - 1 - j);
                        SET_DATA_QBIT(line, j, val);
                  }
              }
      (2) This operation is in-place.

flipTBLow

void flipTBLow ( l_uint32 *data, l_int32 h, l_int32 wpl, l_uint32 *buffer )

  flipTBLow()

  Notes:
      (1) This is simple and fast.  We use the memcpy function
          to do all the work on aligned data, regardless of pixel
          depth.
      (2) This operation is in-place.

makeReverseByteTab1

l_uint8 * makeReverseByteTab1 ( void )

  makeReverseByteTab1()

  Notes:
      (1) This generates an 8 bit lookup table for reversing
          the order of eight 1-bit pixels.

makeReverseByteTab2

l_uint8 * makeReverseByteTab2 ( void )

  makeReverseByteTab2()

  Notes:
      (1) This generates an 8 bit lookup table for reversing
          the order of four 2-bit pixels.

makeReverseByteTab4

l_uint8 * makeReverseByteTab4 ( void )

  makeReverseByteTab4()

  Notes:
      (1) This generates an 8 bit lookup table for reversing
          the order of two 4-bit pixels.

rotate90Low

void rotate90Low ( l_uint32 *datad, l_int32 wd, l_int32 hd, l_int32 d, l_int32 wpld, l_uint32 *datas, l_int32 wpls, l_int32 direction )

  rotate90Low()

      direction:  1 for cw rotation
                 -1 for ccw rotation

  Notes:
      (1) The dest must be cleared in advance because not
          all source pixels are written to the destination.

AUTHOR

Zakariyya Mughal <zmughal@cpan.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2014 by Zakariyya Mughal.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.