summaryrefslogtreecommitdiff
path: root/src/mir_app
diff options
context:
space:
mode:
Diffstat (limited to 'src/mir_app')
-rw-r--r--src/mir_app/src/image_utils.cpp130
-rw-r--r--src/mir_app/src/mir_app.def4
-rw-r--r--src/mir_app/src/mir_app64.def4
-rw-r--r--src/mir_app/src/utils.cpp3
4 files changed, 69 insertions, 72 deletions
diff --git a/src/mir_app/src/image_utils.cpp b/src/mir_app/src/image_utils.cpp
index 0fbafb14e8..ee4bbcf870 100644
--- a/src/mir_app/src/image_utils.cpp
+++ b/src/mir_app/src/image_utils.cpp
@@ -34,24 +34,22 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
// lParam = NULL
// return NULL on error, ResizeBitmap->hBmp if don't need to resize or a new HBITMAP if resized
-static INT_PTR serviceBmpFilterResizeBitmap(WPARAM wParam, LPARAM)
+MIR_APP_DLL(HBITMAP) Image_Resize(HBITMAP hBmp, int fit /* RESIZEBITMAP_*/, int max_width, int max_height)
{
- ResizeBitmap *info = (ResizeBitmap *)wParam;
- if (info == nullptr || info->size != sizeof(ResizeBitmap)
- || info->hBmp == nullptr
- || info->max_width < 0 || info->max_height < 0
- || (info->fit & ~RESIZEBITMAP_FLAG_DONT_GROW) < RESIZEBITMAP_STRETCH
- || (info->fit & ~RESIZEBITMAP_FLAG_DONT_GROW) > RESIZEBITMAP_MAKE_SQUARE)
+ if (hBmp == nullptr
+ || max_width < 0 || max_height < 0
+ || (fit & ~RESIZEBITMAP_FLAG_DONT_GROW) < RESIZEBITMAP_STRETCH
+ || (fit & ~RESIZEBITMAP_FLAG_DONT_GROW) > RESIZEBITMAP_MAKE_SQUARE)
return 0;
// Well, lets do it
// Calc final size
BITMAP bminfo;
- GetObject(info->hBmp, sizeof(bminfo), &bminfo);
+ GetObject(hBmp, sizeof(bminfo), &bminfo);
- int width = info->max_width == 0 ? bminfo.bmWidth : info->max_width;
- int height = info->max_height == 0 ? bminfo.bmHeight : info->max_height;
+ int width = max_width == 0 ? bminfo.bmWidth : max_width;
+ int height = max_height == 0 ? bminfo.bmHeight : max_height;
int xOrig = 0;
int yOrig = 0;
@@ -61,26 +59,26 @@ static INT_PTR serviceBmpFilterResizeBitmap(WPARAM wParam, LPARAM)
if (widthOrig == 0 || heightOrig == 0)
return 0;
- switch (info->fit & ~RESIZEBITMAP_FLAG_DONT_GROW) {
+ switch (fit & ~RESIZEBITMAP_FLAG_DONT_GROW) {
case RESIZEBITMAP_STRETCH:
// Do nothing
break;
case RESIZEBITMAP_KEEP_PROPORTIONS:
if (height * widthOrig / heightOrig <= width) {
- if (info->fit & RESIZEBITMAP_FLAG_DONT_GROW)
+ if (fit & RESIZEBITMAP_FLAG_DONT_GROW)
height = min(height, bminfo.bmHeight);
width = height * widthOrig / heightOrig;
}
else {
- if (info->fit & RESIZEBITMAP_FLAG_DONT_GROW)
+ if (fit & RESIZEBITMAP_FLAG_DONT_GROW)
width = min(width, bminfo.bmWidth);
height = width * heightOrig / widthOrig;
}
break;
case RESIZEBITMAP_MAKE_SQUARE:
- if (info->fit & RESIZEBITMAP_FLAG_DONT_GROW) {
+ if (fit & RESIZEBITMAP_FLAG_DONT_GROW) {
width = min(width, bminfo.bmWidth);
height = min(height, bminfo.bmHeight);
}
@@ -101,12 +99,12 @@ static INT_PTR serviceBmpFilterResizeBitmap(WPARAM wParam, LPARAM)
}
if ((width == bminfo.bmWidth && height == bminfo.bmHeight) ||
- ((info->fit & RESIZEBITMAP_FLAG_DONT_GROW) && !(info->fit & RESIZEBITMAP_MAKE_SQUARE) && width > bminfo.bmWidth && height > bminfo.bmHeight)) {
+ ((fit & RESIZEBITMAP_FLAG_DONT_GROW) && !(fit & RESIZEBITMAP_MAKE_SQUARE) && width > bminfo.bmWidth && height > bminfo.bmHeight)) {
// Do nothing
- return (INT_PTR)info->hBmp;
+ return hBmp;
}
- FIBITMAP *dib = FreeImage_CreateDIBFromHBITMAP(info->hBmp);
+ FIBITMAP *dib = FreeImage_CreateDIBFromHBITMAP(hBmp);
if (dib == nullptr)
return 0;
@@ -130,79 +128,81 @@ static INT_PTR serviceBmpFilterResizeBitmap(WPARAM wParam, LPARAM)
FreeImage_Unload(dib_tmp);
FreeImage_Unload(dib);
- return (INT_PTR)bitmap_new;
+ return bitmap_new;
}
///////////////////////////////////////////////////////////////////////////////
-// Load - initializes the plugin instance
+// Image_Load - initializes the plugin instance
-static INT_PTR serviceLoad(WPARAM wParam, LPARAM lParam)
+MIR_APP_DLL(HBITMAP) Image_Load(const wchar_t *pwszPath, int iFlags)
{
- char *lpszFilename = (char *)wParam;
- if (lpszFilename == nullptr)
+ if (pwszPath == nullptr)
return 0;
FREE_IMAGE_FORMAT fif = FIF_UNKNOWN;
- if (lParam & IMGL_WCHAR)
- fif = FreeImage_GetFileTypeU((wchar_t *)lpszFilename, 0);
+ if (iFlags & IMGL_WCHAR)
+ fif = FreeImage_GetFileTypeU(pwszPath, 0);
else
- fif = FreeImage_GetFileType(lpszFilename, 0);
+ fif = FreeImage_GetFileType((char*)pwszPath, 0);
if (fif == FIF_UNKNOWN) {
- if (lParam & IMGL_WCHAR)
- fif = FreeImage_GetFIFFromFilenameU((wchar_t *)lpszFilename);
+ if (iFlags & IMGL_WCHAR)
+ fif = FreeImage_GetFIFFromFilenameU(pwszPath);
else
- fif = FreeImage_GetFIFFromFilename(lpszFilename);
+ fif = FreeImage_GetFIFFromFilename((char*)pwszPath);
}
+
// check that the plugin has reading capabilities ...
-
- if ((fif != FIF_UNKNOWN) && FreeImage_FIFSupportsReading(fif)) {
+ if (fif != FIF_UNKNOWN && FreeImage_FIFSupportsReading(fif)) {
// ok, let's load the file
FIBITMAP *dib;
- if (lParam & IMGL_WCHAR)
- dib = FreeImage_LoadU(fif, (wchar_t *)lpszFilename, 0);
+ if (iFlags & IMGL_WCHAR)
+ dib = FreeImage_LoadU(fif, pwszPath, 0);
else
- dib = FreeImage_Load(fif, lpszFilename, 0);
+ dib = FreeImage_Load(fif, (char*)pwszPath, 0);
- if (dib == nullptr || (lParam & IMGL_RETURNDIB))
- return (INT_PTR)dib;
+ if (dib == nullptr || (iFlags & IMGL_RETURNDIB))
+ return HBITMAP(dib);
HBITMAP hbm = FreeImage_CreateHBITMAPFromDIB(dib);
FreeImage_Unload(dib);
FreeImage_CorrectBitmap32Alpha(hbm, FALSE);
- return (INT_PTR)hbm;
+ return hbm;
}
- return NULL;
+ return nullptr;
}
-static INT_PTR serviceLoadFromMem(WPARAM wParam, LPARAM lParam)
+/////////////////////////////////////////////////////////////////////////////////////////
+// Image_LoadFromMem - loads an image from memory
+
+MIR_APP_DLL(HBITMAP) Image_LoadFromMem(const void *pBuf, size_t cbLen, FREE_IMAGE_FORMAT fif)
{
- IMGSRVC_MEMIO *mio = (IMGSRVC_MEMIO *)wParam;
- if (mio->iLen == 0 || mio->pBuf == nullptr)
+ if (cbLen == 0 || pBuf == nullptr)
return 0;
- FIMEMORY *hmem = FreeImage_OpenMemory((BYTE *)mio->pBuf, mio->iLen);
- FREE_IMAGE_FORMAT fif = (mio->fif != FIF_UNKNOWN) ? mio->fif : mio->fif = FreeImage_GetFileTypeFromMemory(hmem, 0);
- FIBITMAP *dib = FreeImage_LoadFromMemory(fif, hmem, mio->flags);
- FreeImage_CloseMemory(hmem);
+ FIMEMORY *hmem = FreeImage_OpenMemory((BYTE *)pBuf, (DWORD)cbLen);
+ if (fif == FIF_UNKNOWN)
+ fif = FreeImage_GetFileTypeFromMemory(hmem, 0);
- if (dib == nullptr || (lParam & IMGL_RETURNDIB))
- return (INT_PTR)dib;
+ FIBITMAP *dib = FreeImage_LoadFromMemory(fif, hmem, 0);
+ FreeImage_CloseMemory(hmem);
+ if (dib == nullptr)
+ return nullptr;
HBITMAP hbm = FreeImage_CreateHBITMAPFromDIB(dib);
-
FreeImage_Unload(dib);
- return (INT_PTR)hbm;
+ return hbm;
}
-static INT_PTR serviceSave(WPARAM wParam, LPARAM lParam)
+/////////////////////////////////////////////////////////////////////////////////////////
+
+MIR_APP_DLL(int) Image_Save(const IMGSRVC_INFO *isi, int iFlags)
{
- IMGSRVC_INFO *isi = (IMGSRVC_INFO*)wParam;
if (isi == nullptr)
return 0;
if (isi->cbSize != sizeof(IMGSRVC_INFO))
return 0;
- if (isi->szName == nullptr)
+ if (isi->szName.a == nullptr)
return 0;
FREE_IMAGE_FORMAT fif;
@@ -210,10 +210,10 @@ static INT_PTR serviceSave(WPARAM wParam, LPARAM lParam)
FIBITMAP *dib = nullptr;
if (isi->fif == FIF_UNKNOWN) {
- if (lParam & IMGL_WCHAR)
- fif = FreeImage_GetFIFFromFilenameU(isi->wszName);
+ if (iFlags & IMGL_WCHAR)
+ fif = FreeImage_GetFIFFromFilenameU(isi->szName.w);
else
- fif = FreeImage_GetFIFFromFilename(isi->szName);
+ fif = FreeImage_GetFIFFromFilename(isi->szName.a);
}
else
fif = isi->fif;
@@ -233,21 +233,21 @@ static INT_PTR serviceSave(WPARAM wParam, LPARAM lParam)
if (dib == nullptr)
return 0;
- int flags = HIWORD(lParam);
+ int flags = HIWORD(iFlags);
int ret = 0;
if (fif == FIF_PNG || fif == FIF_BMP || fif == FIF_JNG) {
- if (lParam & IMGL_WCHAR)
- ret = FreeImage_SaveU(fif, dib, isi->wszName, flags);
+ if (iFlags & IMGL_WCHAR)
+ ret = FreeImage_SaveU(fif, dib, isi->szName.w, flags);
else
- ret = FreeImage_Save(fif, dib, isi->szName, flags);
+ ret = FreeImage_Save(fif, dib, isi->szName.a, flags);
}
else {
FIBITMAP *dib_new = FreeImage_ConvertTo24Bits(dib);
- if (lParam & IMGL_WCHAR)
- ret = FreeImage_SaveU(fif, dib_new, isi->wszName, flags);
+ if (iFlags & IMGL_WCHAR)
+ ret = FreeImage_SaveU(fif, dib_new, isi->szName.w, flags);
else
- ret = FreeImage_Save(fif, dib_new, isi->szName, flags);
+ ret = FreeImage_Save(fif, dib_new, isi->szName.a, flags);
FreeImage_Unload(dib_new);
}
@@ -255,11 +255,3 @@ static INT_PTR serviceSave(WPARAM wParam, LPARAM lParam)
FreeImage_Unload(dib);
return ret;
}
-
-void LoadImageUtils(void)
-{
- CreateServiceFunction(MS_IMG_LOAD, serviceLoad);
- CreateServiceFunction(MS_IMG_LOADFROMMEM, serviceLoadFromMem);
- CreateServiceFunction(MS_IMG_SAVE, serviceSave);
- CreateServiceFunction(MS_IMG_RESIZE, serviceBmpFilterResizeBitmap);
-}
diff --git a/src/mir_app/src/mir_app.def b/src/mir_app/src/mir_app.def
index 4bcd151b11..11289c7a7e 100644
--- a/src/mir_app/src/mir_app.def
+++ b/src/mir_app/src/mir_app.def
@@ -483,3 +483,7 @@ Contact_AddBySearch @499
??0PROTO_INTERFACE@@QAE@PBDPB_W@Z @501 NONAME
??1PROTO_INTERFACE@@QAE@XZ @502 NONAME
Proto_AuthRecv @503
+Image_Load @504
+Image_LoadFromMem @505
+Image_Resize @506
+Image_Save @507
diff --git a/src/mir_app/src/mir_app64.def b/src/mir_app/src/mir_app64.def
index 9939debfff..d6c4787c57 100644
--- a/src/mir_app/src/mir_app64.def
+++ b/src/mir_app/src/mir_app64.def
@@ -483,3 +483,7 @@ Contact_AddBySearch @499
??0PROTO_INTERFACE@@QEAA@PEBDPEB_W@Z @501 NONAME
??1PROTO_INTERFACE@@QEAA@XZ @502 NONAME
Proto_AuthRecv @503
+Image_Load @504
+Image_LoadFromMem @505
+Image_Resize @506
+Image_Save @507
diff --git a/src/mir_app/src/utils.cpp b/src/mir_app/src/utils.cpp
index 4125dd921f..170c7db7c2 100644
--- a/src/mir_app/src/utils.cpp
+++ b/src/mir_app/src/utils.cpp
@@ -317,8 +317,6 @@ static INT_PTR GetCountryList(WPARAM wParam, LPARAM lParam)
/////////////////////////////////////////////////////////////////////////////////////////
-void LoadImageUtils(void);
-
int LoadUtilsModule(void)
{
bModuleInitialized = TRUE;
@@ -330,7 +328,6 @@ int LoadUtilsModule(void)
CreateServiceFunction(MS_UTILS_ENTERSTRING, svcEnterString);
InitCrypt();
- LoadImageUtils();
return 0;
}