The London Perl and Raku Workshop takes place on 26th Oct 2024. If your company depends on Perl, please consider sponsoring and/or attending.

NAME

Image::Leptonica::Func::spixio

VERSION

version 0.04

spixio.c

spixio.c

  This does fast serialization of a pix in memory to file,
  copying the raw data for maximum speed.  The underlying
  function serializes it to memory, and it is wrapped to be
  callable from standard pixRead and pixWrite functions.

    Reading spix from file
         PIX        *pixReadStreamSpix()
         l_int32     readHeaderSpix()
         l_int32     freadHeaderSpix()
         l_int32     sreadHeaderSpix()

    Writing spix to file
         l_int32     pixWriteStreamSpix()

    Low-level serialization of pix to/from memory (uncompressed)
         PIX        *pixReadMemSpix()
         l_int32     pixWriteMemSpix()
         l_int32     pixSerializeToMemory()
         PIX        *pixDeserializeFromMemory()

FUNCTIONS

freadHeaderSpix

l_int32 freadHeaderSpix ( FILE *fp, l_int32 *pwidth, l_int32 *pheight, l_int32 *pbps, l_int32 *pspp, l_int32 *piscmap )

freadHeaderSpix()

    Input:  stream
            &width (<return>)
            &height (<return>)
            &bps (<return>, bits/sample)
            &spp (<return>, samples/pixel)
            &iscmap (<optional return>; input NULL to ignore)
    Return: 0 if OK, 1 on error

Notes:
    (1) If there is a colormap, iscmap is returned as 1; else 0.

pixDeserializeFromMemory

PIX * pixDeserializeFromMemory ( const l_uint32 *data, size_t nbytes )

pixDeserializeFromMemory()

    Input:  data (serialized data in memory)
            nbytes (number of bytes in data string)
    Return: pix, or NULL on error

Notes:
    (1) See pixSerializeToMemory() for the binary format.

pixReadMemSpix

PIX * pixReadMemSpix ( const l_uint8 *data, size_t size )

pixReadMemSpix()

    Input:  data (const; uncompressed)
            size (of data)
    Return: pix, or null on error

pixReadStreamSpix

PIX * pixReadStreamSpix ( FILE *fp )

pixReadStreamSpix()

    Input:  stream
    Return: pix, or null on error.

Notes:
    (1) If called from pixReadStream(), the stream is positioned
        at the beginning of the file.

pixSerializeToMemory

l_int32 pixSerializeToMemory ( PIX *pixs, l_uint32 **pdata, size_t *pnbytes )

pixSerializeToMemory()

    Input:  pixs (all depths, colormap OK)
            &data (<return> serialized data in memory)
            &nbytes (<return> number of bytes in data string)
    Return: 0 if OK, 1 on error

Notes:
    (1) This does a fast serialization of the principal elements
        of the pix, as follows:
          "spix"    (4 bytes) -- ID for file type
          w         (4 bytes)
          h         (4 bytes)
          d         (4 bytes)
          wpl       (4 bytes)
          ncolors   (4 bytes) -- in colormap; 0 if there is no colormap
          cdata     (4 * ncolors)  -- size of serialized colormap array
          rdatasize (4 bytes) -- size of serialized raster data
                                 = 4 * wpl * h
          rdata     (rdatasize)

pixWriteMemSpix

l_int32 pixWriteMemSpix ( l_uint8 **pdata, size_t *psize, PIX *pix )

pixWriteMemSpix()

    Input:  &data (<return> data of serialized, uncompressed pix)
            &size (<return> size of returned data)
            pix (all depths; colormap OK)
    Return: 0 if OK, 1 on error

pixWriteStreamSpix

l_int32 pixWriteStreamSpix ( FILE *fp, PIX *pix )

pixWriteStreamSpix()

    Input:  stream
            pix
    Return: 0 if OK; 1 on error

readHeaderSpix

l_int32 readHeaderSpix ( const char *filename, l_int32 *pwidth, l_int32 *pheight, l_int32 *pbps, l_int32 *pspp, l_int32 *piscmap )

readHeaderSpix()

    Input:  filename
            &width (<return>)
            &height (<return>)
            &bps (<return>, bits/sample)
            &spp (<return>, samples/pixel)
            &iscmap (<optional return>; input NULL to ignore)
    Return: 0 if OK, 1 on error

Notes:
    (1) If there is a colormap, iscmap is returned as 1; else 0.

sreadHeaderSpix

l_int32 sreadHeaderSpix ( const l_uint32 *data, l_int32 *pwidth, l_int32 *pheight, l_int32 *pbps, l_int32 *pspp, l_int32 *piscmap )

sreadHeaderSpix()

    Input:  data
            &width (<return>)
            &height (<return>)
            &bps (<return>, bits/sample)
            &spp (<return>, samples/pixel)
            &iscmap (<optional return>; input NULL to ignore)
    Return: 0 if OK, 1 on error

Notes:
    (1) If there is a colormap, iscmap is returned as 1; else 0.

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.