FreeImagePlus - FreeImage 3.17.0
|
Multi-page file stream. More...
#include <FreeImagePlus.h>
Public Member Functions | |
fipMultiPage (BOOL keep_cache_in_memory=FALSE) | |
Constructor. | |
virtual | ~fipMultiPage () |
Destructor Close the file stream if not already done. | |
BOOL | isValid () const |
Returns TRUE if the multi-page stream is opened. | |
operator FIMULTIBITMAP * () | |
Returns a pointer to the FIMULTIBITMAP data. | |
BOOL | open (const char *lpszPathName, BOOL create_new, BOOL read_only, int flags=0) |
Open a multi-page file stream. | |
BOOL | open (fipMemoryIO &memIO, int flags=0) |
Open a multi-page memory stream as read/write. | |
BOOL | open (FreeImageIO *io, fi_handle handle, int flags=0) |
Open a multi-page image as read/write, using the specified FreeImageIO struct and fi_handle, and an optional flag. | |
BOOL | close (int flags=0) |
Close a file stream. | |
BOOL | saveToHandle (FREE_IMAGE_FORMAT fif, FreeImageIO *io, fi_handle handle, int flags=0) const |
Saves a multi-page image using the specified FreeImageIO struct and fi_handle, and an optional flag. | |
BOOL | saveToMemory (FREE_IMAGE_FORMAT fif, fipMemoryIO &memIO, int flags=0) const |
Saves a multi-page image using the specified memory stream and an optional flag. | |
int | getPageCount () const |
Returns the number of pages currently available in the multi-paged bitmap. | |
void | appendPage (fipImage &image) |
Appends a new page to the end of the bitmap. | |
void | insertPage (int page, fipImage &image) |
Inserts a new page before the given position in the bitmap. | |
void | deletePage (int page) |
Deletes the page on the given position. | |
BOOL | movePage (int target, int source) |
Moves the source page to the position of the target page. | |
FIBITMAP * | lockPage (int page) |
Locks a page in memory for editing. | |
void | unlockPage (fipImage &image, BOOL changed) |
Unlocks a previously locked page and gives it back to the multi-page engine. | |
BOOL | getLockedPageNumbers (int *pages, int *count) const |
Returns an array of page-numbers that are currently locked in memory. | |
Protected Attributes | |
FIMULTIBITMAP * | _mpage |
Pointer to a multi-page file stream. | |
BOOL | _bMemoryCache |
TRUE when using a memory cache, FALSE otherwise. |
Multi-page file stream.
fipMultiPage encapsulates the multi-page API. It supports reading/writing multi-page TIFF, ICO and GIF files.
fipMultiPage::fipMultiPage | ( | BOOL | keep_cache_in_memory = FALSE | ) |
Constructor.
keep_cache_in_memory | When it is TRUE, all gathered bitmap data in the page manipulation process is kept in memory, otherwise it is lazily flushed to a temporary file on the hard disk in 64 Kb blocks. |
virtual fipMultiPage::~fipMultiPage | ( | ) | [virtual] |
Destructor Close the file stream if not already done.
void fipMultiPage::appendPage | ( | fipImage & | image | ) |
Appends a new page to the end of the bitmap.
image | Image to append |
BOOL fipMultiPage::close | ( | int | flags = 0 | ) |
Close a file stream.
flags | Save flags. The signification of this flag depends on the image to be saved. |
void fipMultiPage::deletePage | ( | int | page | ) |
Deletes the page on the given position.
page | Page number |
BOOL fipMultiPage::getLockedPageNumbers | ( | int * | pages, |
int * | count | ||
) | const |
Returns an array of page-numbers that are currently locked in memory.
When the pages parameter is NULL, the size of the array is returned in the count variable. You can then allocate the array of the desired size and call getLockedPageNumbers again to populate the array.
int fipMultiPage::getPageCount | ( | ) | const |
Returns the number of pages currently available in the multi-paged bitmap.
void fipMultiPage::insertPage | ( | int | page, |
fipImage & | image | ||
) |
Inserts a new page before the given position in the bitmap.
page | Page number. Page has to be a number smaller than the current number of pages available in the bitmap. |
image | Image to insert |
BOOL fipMultiPage::isValid | ( | ) | const [virtual] |
Returns TRUE if the multi-page stream is opened.
Implements fipObject.
FIBITMAP* fipMultiPage::lockPage | ( | int | page | ) |
Locks a page in memory for editing.
You must call unlockPage to free the page
Usage :
fipMultiPage mpage; ... fipImage image; // You must declare this before image = mpage.lockPage(2); if(image.isValid()) { ... mpage.unlockPage(image, TRUE); }
page | Page number |
BOOL fipMultiPage::movePage | ( | int | target, |
int | source | ||
) |
Moves the source page to the position of the target page.
target | Target page position |
source | Source page position |
BOOL fipMultiPage::open | ( | const char * | lpszPathName, |
BOOL | create_new, | ||
BOOL | read_only, | ||
int | flags = 0 |
||
) |
Open a multi-page file stream.
lpszPathName | Name of the multi-page bitmap file |
create_new | When TRUE, it means that a new bitmap will be created rather than an existing one being opened |
read_only | When TRUE the bitmap is opened read-only |
flags | Load flags. The signification of this flag depends on the image to be loaded. |
BOOL fipMultiPage::open | ( | fipMemoryIO & | memIO, |
int | flags = 0 |
||
) |
Open a multi-page memory stream as read/write.
memIO | Memory stream. The memory stream MUST BE a wrapped user buffer. |
flags | Load flags. The signification of this flag depends on the image to be loaded. |
BOOL fipMultiPage::open | ( | FreeImageIO * | io, |
fi_handle | handle, | ||
int | flags = 0 |
||
) |
Open a multi-page image as read/write, using the specified FreeImageIO struct and fi_handle, and an optional flag.
io | FreeImageIO structure |
handle | FreeImage fi_handle |
flag | The signification of this flag depends on the image to be read. |
fipMultiPage::operator FIMULTIBITMAP * | ( | ) | [inline] |
Returns a pointer to the FIMULTIBITMAP data.
Used for direct access from FREEIMAGE functions or from your own low level C functions.
BOOL fipMultiPage::saveToHandle | ( | FREE_IMAGE_FORMAT | fif, |
FreeImageIO * | io, | ||
fi_handle | handle, | ||
int | flags = 0 |
||
) | const |
Saves a multi-page image using the specified FreeImageIO struct and fi_handle, and an optional flag.
fif | Format identifier (FreeImage format) |
io | FreeImageIO structure |
handle | FreeImage fi_handle |
flag | The signification of this flag depends on the multi-page image to be saved. |
BOOL fipMultiPage::saveToMemory | ( | FREE_IMAGE_FORMAT | fif, |
fipMemoryIO & | memIO, | ||
int | flags = 0 |
||
) | const |
Saves a multi-page image using the specified memory stream and an optional flag.
fif | Format identifier (FreeImage format) |
memIO | FreeImage memory stream |
flag | The signification of this flag depends on the image to be saved. |
void fipMultiPage::unlockPage | ( | fipImage & | image, |
BOOL | changed | ||
) |
Unlocks a previously locked page and gives it back to the multi-page engine.
image | Page to unlock |
changed | When TRUE, the page is marked changed and the new page data is applied in the multi-page bitmap. |
BOOL fipMultiPage::_bMemoryCache [protected] |
TRUE when using a memory cache, FALSE otherwise.
FIMULTIBITMAP* fipMultiPage::_mpage [protected] |
Pointer to a multi-page file stream.