@zxing/library
Version:
TypeScript port of ZXing multi-format 1D/2D barcode image processing library.
39 lines (38 loc) • 1.42 kB
TypeScript
/**
* <p>This provides an easy abstraction to read bits at a time from a sequence of bytes, where the
* number of bits read is not often a multiple of 8.</p>
*
* <p>This class is thread-safe but not reentrant -- unless the caller modifies the bytes array
* it passed in, in which case all bets are off.</p>
*
* @author Sean Owen
*/
export default class BitSource {
private bytes;
private byteOffset;
private bitOffset;
/**
* @param bytes bytes from which this will read bits. Bits will be read from the first byte first.
* Bits are read within a byte from most-significant to least-significant bit.
*/
constructor(bytes: Uint8Array);
/**
* @return index of next bit in current byte which would be read by the next call to {@link #readBits(int)}.
*/
getBitOffset(): number;
/**
* @return index of next byte in input byte array which would be read by the next call to {@link #readBits(int)}.
*/
getByteOffset(): number;
/**
* @param numBits number of bits to read
* @return int representing the bits read. The bits will appear as the least-significant
* bits of the int
* @throws IllegalArgumentException if numBits isn't in [1,32] or more than is available
*/
readBits(numBits: number): number;
/**
* @return number of bits that can be read successfully
*/
available(): number;
}