blob: 40463937b046d9b4fb03aed215173edd37da070d [file] [log] [blame]
// ==========================================================
// fipMultiPage class implementation
//
// Design and implementation by
// - Hervé Drolon (drolon@infonie.fr)
//
// This file is part of FreeImage 3
//
// COVERED CODE IS PROVIDED UNDER THIS LICENSE ON AN "AS IS" BASIS, WITHOUT WARRANTY
// OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, WITHOUT LIMITATION, WARRANTIES
// THAT THE COVERED CODE IS FREE OF DEFECTS, MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE
// OR NON-INFRINGING. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE COVERED
// CODE IS WITH YOU. SHOULD ANY COVERED CODE PROVE DEFECTIVE IN ANY RESPECT, YOU (NOT
// THE INITIAL DEVELOPER OR ANY OTHER CONTRIBUTOR) ASSUME THE COST OF ANY NECESSARY
// SERVICING, REPAIR OR CORRECTION. THIS DISCLAIMER OF WARRANTY CONSTITUTES AN ESSENTIAL
// PART OF THIS LICENSE. NO USE OF ANY COVERED CODE IS AUTHORIZED HEREUNDER EXCEPT UNDER
// THIS DISCLAIMER.
//
// Use at your own risk!
// ==========================================================
#include "FreeImagePlus.h"
fipMultiPage::fipMultiPage(BOOL keep_cache_in_memory) : _mpage(NULL), _bMemoryCache(keep_cache_in_memory) {
}
fipMultiPage::~fipMultiPage() {
if(_mpage) {
// close the stream
close(0);
}
}
BOOL fipMultiPage::isValid() const {
return (NULL != _mpage) ? TRUE : FALSE;
}
BOOL fipMultiPage::open(const char* lpszPathName, BOOL create_new, BOOL read_only, int flags) {
// try to guess the file format from the filename
FREE_IMAGE_FORMAT fif = FreeImage_GetFIFFromFilename(lpszPathName);
// check for supported file types
if((fif == FIF_UNKNOWN) || (fif != FIF_TIFF) && (fif != FIF_ICO) && (fif != FIF_GIF) && (fif != FIF_PSD))
return FALSE;
// open the stream
_mpage = FreeImage_OpenMultiBitmap(fif, lpszPathName, create_new, read_only, _bMemoryCache, flags);
return (NULL != _mpage ) ? TRUE : FALSE;
}
BOOL fipMultiPage::open(fipMemoryIO& memIO, int flags) {
// try to guess the file format from the filename
FREE_IMAGE_FORMAT fif = memIO.getFileType();
// check for supported file types
if((fif == FIF_UNKNOWN) || (fif != FIF_TIFF) && (fif != FIF_ICO) && (fif != FIF_GIF))
return FALSE;
// open the stream
_mpage = FreeImage_LoadMultiBitmapFromMemory(fif, memIO, flags);
return (NULL != _mpage ) ? TRUE : FALSE;
}
BOOL fipMultiPage::close(int flags) {
BOOL bSuccess = FALSE;
if(_mpage) {
// close the stream
bSuccess = FreeImage_CloseMultiBitmap(_mpage, flags);
_mpage = NULL;
}
return bSuccess;
}
int fipMultiPage::getPageCount() const {
return _mpage ? FreeImage_GetPageCount(_mpage) : 0;
}
void fipMultiPage::appendPage(fipImage& image) {
if(_mpage)
FreeImage_AppendPage(_mpage, image);
}
void fipMultiPage::insertPage(int page, fipImage& image) {
if(_mpage)
FreeImage_InsertPage(_mpage, page, image);
}
void fipMultiPage::deletePage(int page) {
if(_mpage)
FreeImage_DeletePage(_mpage, page);
}
BOOL fipMultiPage::movePage(int target, int source) {
return _mpage ? FreeImage_MovePage(_mpage, target, source) : FALSE;
}
FIBITMAP* fipMultiPage::lockPage(int page) {
return _mpage ? FreeImage_LockPage(_mpage, page) : NULL;
}
void fipMultiPage::unlockPage(fipImage& image, BOOL changed) {
if(_mpage) {
FreeImage_UnlockPage(_mpage, image, changed);
// clear the image so that it becomes invalid.
// this is possible because of the friend declaration
image._dib = NULL;
image._bHasChanged = FALSE;
}
}
BOOL fipMultiPage::getLockedPageNumbers(int *pages, int *count) const {
return _mpage ? FreeImage_GetLockedPageNumbers(_mpage, pages, count) : FALSE;
}