NAME
Image::Leptonica::Func::arrayaccess
VERSION
version 0.03
arrayaccess.c
arrayaccess.c
Access within an array of 32-bit words
l_int32 l_getDataBit()
void l_setDataBit()
void l_clearDataBit()
void l_setDataBitVal()
l_int32 l_getDataDibit()
void l_setDataDibit()
void l_clearDataDibit()
l_int32 l_getDataQbit()
void l_setDataQbit()
void l_clearDataQbit()
l_int32 l_getDataByte()
void l_setDataByte()
l_int32 l_getDataTwoBytes()
void l_setDataTwoBytes()
l_int32 l_getDataFourBytes()
void l_setDataFourBytes()
Note that these all require 32-bit alignment, and hence an input
ptr to l_uint32. However, this is not enforced by the compiler.
Instead, we allow the use of a void* ptr, because the line ptrs
are an efficient way to get random access (see pixGetLinePtrs()).
It is then necessary to cast internally within each function
because ptr arithmetic requires knowing the size of the units
being referenced.
FUNCTIONS
l_clearDataBit
void l_clearDataBit ( void *line, l_int32 n )
l_clearDataBit()
Input: line (ptr to beginning of data line)
n (pixel index)
Return: void
Action: sets the (1-bit) pixel to 0
l_clearDataDibit
void l_clearDataDibit ( void *line, l_int32 n )
l_clearDataDibit()
Input: line (ptr to beginning of data line)
n (pixel index)
Return: void
Action: sets the (2-bit) pixel to 0
l_clearDataQbit
void l_clearDataQbit ( void *line, l_int32 n )
l_clearDataQbit()
Input: line (ptr to beginning of data line)
n (pixel index)
Return: void
Action: sets the (4-bit) pixel to 0
l_getDataBit
l_int32 l_getDataBit ( void *line, l_int32 n )
l_getDataBit()
Input: line (ptr to beginning of data line)
n (pixel index)
Return: val of the nth (1-bit) pixel.
l_getDataByte
l_int32 l_getDataByte ( void *line, l_int32 n )
l_getDataByte()
Input: line (ptr to beginning of data line)
n (pixel index)
Return: value of the n-th (byte) pixel
l_getDataDibit
l_int32 l_getDataDibit ( void *line, l_int32 n )
l_getDataDibit()
Input: line (ptr to beginning of data line)
n (pixel index)
Return: val of the nth (2-bit) pixel.
l_getDataFourBytes
l_int32 l_getDataFourBytes ( void *line, l_int32 n )
l_getDataFourBytes()
Input: line (ptr to beginning of data line)
n (pixel index)
Return: value of the n-th (4-byte) pixel
l_getDataQbit
l_int32 l_getDataQbit ( void *line, l_int32 n )
l_getDataQbit()
Input: line (ptr to beginning of data line)
n (pixel index)
Return: val of the nth (4-bit) pixel.
l_getDataTwoBytes
l_int32 l_getDataTwoBytes ( void *line, l_int32 n )
l_getDataTwoBytes()
Input: line (ptr to beginning of data line)
n (pixel index)
Return: value of the n-th (2-byte) pixel
l_setDataBit
void l_setDataBit ( void *line, l_int32 n )
l_setDataBit()
Input: line (ptr to beginning of data line)
n (pixel index)
Return: void
Action: sets the pixel to 1
l_setDataBitVal
void l_setDataBitVal ( void *line, l_int32 n, l_int32 val )
l_setDataBitVal()
Input: line (ptr to beginning of data line)
n (pixel index)
val (val to be inserted: 0 or 1)
Return: void
Notes:
(1) This is an accessor for a 1 bpp pix.
(2) It is actually a little slower than using:
if (val == 0)
l_ClearDataBit(line, n);
else
l_SetDataBit(line, n);
l_setDataByte
void l_setDataByte ( void *line, l_int32 n, l_int32 val )
l_setDataByte()
Input: line (ptr to beginning of data line)
n (pixel index)
val (val to be inserted: 0 - 0xff)
Return: void
l_setDataDibit
void l_setDataDibit ( void *line, l_int32 n, l_int32 val )
l_setDataDibit()
Input: line (ptr to beginning of data line)
n (pixel index)
val (val to be inserted: 0 - 3)
Return: void
l_setDataFourBytes
void l_setDataFourBytes ( void *line, l_int32 n, l_int32 val )
l_setDataFourBytes()
Input: line (ptr to beginning of data line)
n (pixel index)
val (val to be inserted: 0 - 0xffffffff)
Return: void
l_setDataQbit
void l_setDataQbit ( void *line, l_int32 n, l_int32 val )
l_setDataQbit()
Input: line (ptr to beginning of data line)
n (pixel index)
val (val to be inserted: 0 - 0xf)
Return: void
l_setDataTwoBytes
void l_setDataTwoBytes ( void *line, l_int32 n, l_int32 val )
l_setDataTwoBytes()
Input: line (ptr to beginning of data line)
n (pixel index)
val (val to be inserted: 0 - 0xffff)
Return: void
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.