UNPKG

@zxing/library

Version:

TypeScript port of ZXing multi-format 1D/2D barcode image processing library.

39 lines (38 loc) 1.42 kB
/** * <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; }