Does buffer-to-buffer RLE compression of 1-bit image data. Use this function to process multiple lines of image data.
#include "l_bitmap.h"
L_LTKRN_API L_INT L_CompressRows(pRunBuffer, pBuffer, nWidth, nRows)
Pointer to the output buffer, which will be filled with 1-bit compressed image data. Calculate the required size of this buffer as follows: bytes required = ((nWidth + 3) * 2) * nRows.
Pointer to the input buffer, which contains the 1-bit image data to be compressed. The size of each row must be rounded up to a multiple of 4 bytes. Use integer math to calculate the required size of this buffer as follows: bytes required = (((nWidth + 31) &~31)/ 8) * nRows.
The number of pixels in each row.
The number of rows to process.
| Value | Meaning | 
|---|---|
| > 0 | The number of pixels processed. | 
| < 1 | An error occurred. Refer to Return Codes. | 
The output buffer must be larger than the input buffer to accommodate the worst possible case with run-length encoding, where there are alternating black and white pixels. In most cases, however, the actual compressed data will be much smaller than the input data.
This function is useful for working with 1-bit images that are loaded in their compressed formats for faster loading and display. For more information, refer to Speeding Up 1-Bit Documents.
Win32, x64, Linux.
For an example, refer to L_GetBitmapRowCompressed.
Help Collections
Raster .NET | C API | C++ Class Library | HTML5 JavaScript
Document .NET | C API | C++ Class Library | HTML5 JavaScript
Medical .NET | C API | C++ Class Library | HTML5 JavaScript
Medical Web Viewer .NET
Multimedia
Direct Show .NET | C API | Filters
Media Foundation .NET | C API | Transforms
Supported Platforms
.NET, Java, Android, and iOS/macOS Assemblies
Imaging, Medical, and Document
C API/C++ Class Libraries
Imaging, Medical, and Document
HTML5 JavaScript Libraries
Imaging, Medical, and Document
