Fix the PNG loading .

This commit is contained in:
dgis 2019-02-23 18:11:21 +00:00
parent ecd1452a48
commit 38d0316217
5 changed files with 46 additions and 231 deletions

View file

@ -1,2 +0,0 @@
;014A1:6300; disable 10 min auto off (internal, undocumented)
017D0:81B1; =makebeep (internal, undocumented)

View file

@ -1,3 +0,0 @@
;0148D:6300; disable 10 min auto off (internal, undocumented)
017BC:81B1; =makebeep (internal, undocumented)
0212D:000; set =BounceTiming to 0 (internal, undocumented)

View file

@ -1,2 +0,0 @@
;01477:6300; disable 10 min auto off (internal, undocumented)
017A6:81B1; =makebeep

View file

@ -1,4 +0,0 @@
;41262:6300; disable 10 min auto off (internal for 1.19-6, undocumented)
;412B9:6300; disable 10 min auto off (internal for 1.24/2.09, undocumented)
4157A:81B1; =makebeep (internal for 1.18/1.19-5/1.19-6, undocumented)
;41609:81B1; =makebeep (internal for 1.24/2.01/2.09, undocumented)

View file

@ -1234,6 +1234,7 @@ HGDIOBJ GetCurrentObject(HDC hdc, UINT type) {
return NULL; return NULL;
} }
BOOL DeleteObject(HGDIOBJ ho) { BOOL DeleteObject(HGDIOBJ ho) {
if(ho) {
switch(ho->handleType) { switch(ho->handleType) {
case HGDIOBJ_TYPE_PALETTE: { case HGDIOBJ_TYPE_PALETTE: {
ho->handleType = HGDIOBJ_TYPE_INVALID; ho->handleType = HGDIOBJ_TYPE_INVALID;
@ -1245,15 +1246,20 @@ BOOL DeleteObject(HGDIOBJ ho) {
} }
case HGDIOBJ_TYPE_BITMAP: { case HGDIOBJ_TYPE_BITMAP: {
ho->handleType = HGDIOBJ_TYPE_INVALID; ho->handleType = HGDIOBJ_TYPE_INVALID;
ho->bitmapInfoHeader = NULL; if(ho->bitmapInfo)
ho->bitmapBits = NULL; free((void *) ho->bitmapInfo);
ho->bitmapInfo = NULL; ho->bitmapInfo = NULL;
ho->bitmapInfoHeader = NULL;
if(ho->bitmapBits)
free((void *) ho->bitmapBits);
ho->bitmapBits = NULL;
free(ho); free(ho);
return TRUE; return TRUE;
} }
default: default:
break; break;
} }
}
return FALSE; return FALSE;
} }
HGDIOBJ GetStockObject(int i) { HGDIOBJ GetStockObject(int i) {
@ -1415,8 +1421,10 @@ BOOL StretchBlt(HDC hdcDest, int xDest, int yDest, int wDest, int hDest, HDC hdc
HBITMAP hBitmapDestination = NULL; HBITMAP hBitmapDestination = NULL;
void * pixelsDestination = NULL; void * pixelsDestination = NULL;
BOOL reverseHeight = hBitmapSource->bitmapInfoHeader->biHeight < 0;
int sourceWidth = hBitmapSource->bitmapInfoHeader->biWidth; int sourceWidth = hBitmapSource->bitmapInfoHeader->biWidth;
int sourceHeight = abs(hBitmapSource->bitmapInfoHeader->biHeight); int sourceHeight = abs(hBitmapSource->bitmapInfoHeader->biHeight); // Can be < 0
int destinationWidth = 0; int destinationWidth = 0;
int destinationHeight = 0; int destinationHeight = 0;
@ -1471,12 +1479,15 @@ BOOL StretchBlt(HDC hdcDest, int xDest, int yDest, int wDest, int hDest, HDC hdc
//https://softwareengineering.stackexchange.com/questions/148123/what-is-the-algorithm-to-copy-a-region-of-one-bitmap-into-a-region-in-another //https://softwareengineering.stackexchange.com/questions/148123/what-is-the-algorithm-to-copy-a-region-of-one-bitmap-into-a-region-in-another
float src_dx = (float)wSrc / (float)wDest; float src_dx = (float)wSrc / (float)wDest;
float src_dy = (float)hSrc / (float)hDest; float src_dy = (float)hSrc / (float)hDest;
float src_maxx = xSrc + wSrc;
float src_maxy = ySrc + hSrc;
float dst_maxx = xDest + wDest; float dst_maxx = xDest + wDest;
float dst_maxy = yDest + hDest; float dst_maxy = yDest + hDest;
float src_cury = ySrc; float src_cury = ySrc;
if(reverseHeight == FALSE) {
src_dy = -src_dy;
src_cury = sourceHeight - 1 - src_cury;
}
//LOGD("StretchBlt(%08x, x:%d, y:%d, w:%d, h:%d, %08x, x:%d, y:%d, w:%d, h:%d) -> sourceBytes: %d", hdcDest->hdcCompatible, xDest, yDest, wDest, hDest, hdcSrc, xSrc, ySrc, wSrc, hSrc, sourceBytesWithDecimal); //LOGD("StretchBlt(%08x, x:%d, y:%d, w:%d, h:%d, %08x, x:%d, y:%d, w:%d, h:%d) -> sourceBytes: %d", hdcDest->hdcCompatible, xDest, yDest, wDest, hDest, hdcSrc, xSrc, ySrc, wSrc, hSrc, sourceBytesWithDecimal);
HPALETTE palette = hdcSrc->realizedPalette; HPALETTE palette = hdcSrc->realizedPalette;
if(!palette) if(!palette)
@ -1553,192 +1564,6 @@ BOOL StretchBlt(HDC hdcDest, int xDest, int yDest, int wDest, int hDest, HDC hdc
return TRUE; return TRUE;
} }
return FALSE; return FALSE;
// if(hdcDest->hdcCompatible == NULL && hdcSrc->selectedBitmap && hDest && hSrc) {
// // We update the main window
//
// JNIEnv * jniEnv;
// jint ret;
// BOOL needDetach = FALSE;
// ret = (*java_machine)->GetEnv(java_machine, (void **) &jniEnv, JNI_VERSION_1_6);
// if (ret == JNI_EDETACHED) {
// // GetEnv: not attached
// ret = (*java_machine)->AttachCurrentThread(java_machine, &jniEnv, NULL);
// if (ret == JNI_OK) {
// needDetach = TRUE;
// }
// }
//
// void * pixelsDestination;
// if ((ret = AndroidBitmap_lockPixels(jniEnv, bitmapMainScreen, &pixelsDestination)) < 0) {
// LOGE("AndroidBitmap_lockPixels() failed ! error=%d", ret);
// }
//
// HBITMAP hBitmapSource = hdcSrc->selectedBitmap;
//
// void * pixelsSource = (void *) hBitmapSource->bitmapBits;
//
// int sourceWidth = hBitmapSource->bitmapInfoHeader->biWidth;
// int sourceHeight = abs(hBitmapSource->bitmapInfoHeader->biHeight);
// int destinationWidth = androidBitmapInfo.width;
// int destinationHeight = androidBitmapInfo.height;
//
// //https://softwareengineering.stackexchange.com/questions/148123/what-is-the-algorithm-to-copy-a-region-of-one-bitmap-into-a-region-in-another
// float src_dx = (float)wSrc / (float)wDest;
// float src_dy = (float)hSrc / (float)hDest;
// float src_maxx = xSrc + wSrc;
// float src_maxy = ySrc + hSrc;
// float dst_maxx = xDest + wDest;
// float dst_maxy = yDest + hDest;
// float src_cury = ySrc;
//
// int sourceBytes = (hBitmapSource->bitmapInfoHeader->biBitCount >> 3);
//// float sourceStride = sourceWidth * sourceBytes;
//// sourceStride = (float)(4 * ((sourceWidth * hBitmapSource->bitmapInfoHeader->biBitCount + 31) / 32));
// float sourceStride = (float)(4 * ((sourceWidth * hBitmapSource->bitmapInfoHeader->biBitCount + 31) / 32));
// float destinationStride = androidBitmapInfo.stride; // Destination always 4 bytes RGBA
// //LOGD("StretchBlt(%08x, x:%d, y:%d, w:%d, h:%d, %08x, x:%d, y:%d, w:%d, h:%d) -> sourceBytes: %d", hdcDest->hdcCompatible, xDest, yDest, wDest, hDest, hdcSrc, xSrc, ySrc, wSrc, hSrc, sourceBytes);
//
// HPALETTE palette = hdcSrc->realizedPalette;
// if(!palette)
// palette = hdcSrc->selectedPalette;
// PALETTEENTRY * palPalEntry = palette && palette->paletteLog && palette->paletteLog->palPalEntry ?
// palette->paletteLog->palPalEntry : NULL;
//
// for (float y = yDest; y < dst_maxy; y++)
// {
// float src_curx = xSrc;
// for (float x = xDest; x < dst_maxx; x++)
// {
// // Point sampling - you can also impl as bilinear or other
// //dst.bmp[x,y] = src.bmp[src_curx, src_cury];
//
// BYTE * destinationPixel = pixelsDestination + (int)(4.0 * x + destinationStride * y);
// BYTE * sourcePixel = pixelsSource + (int)(sourceBytes * (int)src_curx) + (int)(sourceStride * (int)src_cury);
//
// // -> ARGB_8888
// switch (sourceBytes) {
// case 1:
// if(palPalEntry) {
// BYTE colorIndex = sourcePixel[0];
// destinationPixel[0] = palPalEntry[colorIndex].peRed;
// destinationPixel[1] = palPalEntry[colorIndex].peGreen;
// destinationPixel[2] = palPalEntry[colorIndex].peBlue;
// destinationPixel[3] = 255;
// } else {
// destinationPixel[0] = sourcePixel[0];
// destinationPixel[1] = sourcePixel[0];
// destinationPixel[2] = sourcePixel[0];
// destinationPixel[3] = 255;
// }
// break;
// case 3:
// destinationPixel[0] = sourcePixel[2];
// destinationPixel[1] = sourcePixel[1];
// destinationPixel[2] = sourcePixel[0];
// destinationPixel[3] = 255;
// break;
// case 4:
// memcpy(destinationPixel, sourcePixel, (size_t) sourceBytes);
// break;
// default:
// break;
// }
//
// src_curx += src_dx;
// }
//
// src_cury += src_dy;
// }
//
// AndroidBitmap_unlockPixels(jniEnv, bitmapMainScreen);
//
//// if(needDetach)
//// ret = (*java_machine)->DetachCurrentThread(java_machine);
//
// //mainViewUpdateCallback();
// return TRUE;
// } else if(hdcDest->selectedBitmap && hdcSrc->selectedBitmap && hDest && hSrc) {
// // We update the main window
//
// HBITMAP hBitmapSource = hdcSrc->selectedBitmap;
// void * pixelsSource = (void *) hBitmapSource->bitmapBits;
//
// HBITMAP hBitmapDestination = hdcDest->selectedBitmap;
// void * pixelsDestination = (void *) hBitmapDestination->bitmapBits;
//
// int sourceWidth = hBitmapSource->bitmapInfoHeader->biWidth;
// int sourceHeight = abs(hBitmapSource->bitmapInfoHeader->biHeight);
// int destinationWidth = hBitmapDestination->bitmapInfoHeader->biWidth;
// int destinationHeight = abs(hBitmapDestination->bitmapInfoHeader->biHeight);
//
// //https://softwareengineering.stackexchange.com/questions/148123/what-is-the-algorithm-to-copy-a-region-of-one-bitmap-into-a-region-in-another
// float src_dx = (float)wSrc / (float)wDest;
// float src_dy = (float)hSrc / (float)hDest;
// float src_maxx = xSrc + wSrc;
// float src_maxy = ySrc + hSrc;
// float dst_maxx = xDest + wDest;
// float dst_maxy = yDest + hDest;
// float src_cury = ySrc;
//
// int sourceBytes = (hBitmapSource->bitmapInfoHeader->biBitCount >> 3);
// //TODO float sourceStride = (float)(sourceBytes * ((sourceWidth * hBitmapSource->bitmapInfoHeader->biBitCount + 31) / 32));
// float sourceStride = (float)(4 * ((sourceWidth * hBitmapSource->bitmapInfoHeader->biBitCount + 31) / 32));
// int destinationBytes = (hBitmapDestination->bitmapInfoHeader->biBitCount >> 3);
// float destinationStride = (float)(destinationBytes * ((destinationWidth * hBitmapDestination->bitmapInfoHeader->biBitCount + 31) / 32));
// //LOGD("StretchBlt(%08x, x:%d, y:%d, w:%d, h:%d, %08x, x:%d, y:%d, w:%d, h:%d) -> sourceBytes: %d", hdcDest->hdcCompatible, xDest, yDest, wDest, hDest, hdcSrc, xSrc, ySrc, wSrc, hSrc, sourceBytes);
//
// PALETTEENTRY * palPalEntry = hdcSrc->selectedPalette && hdcSrc->selectedPalette->paletteLog && hdcSrc->selectedPalette->paletteLog->palPalEntry ?
// hdcSrc->selectedPalette->paletteLog->palPalEntry : NULL;
//
// for (float y = yDest; y < dst_maxy; y++)
// {
// float src_curx = xSrc;
// for (float x = xDest; x < dst_maxx; x++)
// {
// // Point sampling - you can also impl as bilinear or other
// //dst.bmp[x,y] = src.bmp[src_curx, src_cury];
//
// BYTE * destinationPixel = pixelsDestination + (int)(4.0 * x + destinationStride * y);
// BYTE * sourcePixel = pixelsSource + (int)(sourceBytes * (int)src_curx) + (int)(sourceStride * (int)src_cury);
//
// // -> ARGB_8888
// switch (sourceBytes) {
// case 1:
// if(palPalEntry) {
// BYTE colorIndex = sourcePixel[0];
// destinationPixel[0] = palPalEntry[colorIndex].peBlue;
// destinationPixel[1] = palPalEntry[colorIndex].peGreen;
// destinationPixel[2] = palPalEntry[colorIndex].peRed;
// destinationPixel[3] = 255;
// } else {
// destinationPixel[0] = sourcePixel[0];
// destinationPixel[1] = sourcePixel[0];
// destinationPixel[2] = sourcePixel[0];
// destinationPixel[3] = 255;
// }
// break;
// case 3:
// destinationPixel[0] = sourcePixel[2];
// destinationPixel[1] = sourcePixel[1];
// destinationPixel[2] = sourcePixel[0];
// destinationPixel[3] = 255;
// break;
// case 4:
// memcpy(destinationPixel, sourcePixel, (size_t) sourceBytes);
// break;
// default:
// break;
// }
//
// src_curx += src_dx;
// }
//
// src_cury += src_dy;
// }
// return TRUE;
// }
// return FALSE;
} }
UINT SetDIBColorTable(HDC hdc, UINT iStart, UINT cEntries, CONST RGBQUAD *prgbq) { UINT SetDIBColorTable(HDC hdc, UINT iStart, UINT cEntries, CONST RGBQUAD *prgbq) {
if(prgbq if(prgbq
@ -1758,25 +1583,18 @@ HBITMAP CreateDIBitmap( HDC hdc, CONST BITMAPINFOHEADER *pbmih, DWORD flInit, CO
HGDIOBJ newHBITMAP = (HGDIOBJ)malloc(sizeof(_HGDIOBJ)); HGDIOBJ newHBITMAP = (HGDIOBJ)malloc(sizeof(_HGDIOBJ));
memset(newHBITMAP, 0, sizeof(_HGDIOBJ)); memset(newHBITMAP, 0, sizeof(_HGDIOBJ));
newHBITMAP->handleType = HGDIOBJ_TYPE_BITMAP; newHBITMAP->handleType = HGDIOBJ_TYPE_BITMAP;
BITMAPINFO * newBitmapInfo = malloc(sizeof(BITMAPINFO)); BITMAPINFO * newBitmapInfo = malloc(sizeof(BITMAPINFO));
memcpy(newBitmapInfo, pbmi, sizeof(BITMAPINFO)); memcpy(newBitmapInfo, pbmi, sizeof(BITMAPINFO));
newHBITMAP->bitmapInfo = newBitmapInfo; newHBITMAP->bitmapInfo = newBitmapInfo;
newHBITMAP->bitmapInfoHeader = (BITMAPINFOHEADER *)newBitmapInfo; newHBITMAP->bitmapInfoHeader = (BITMAPINFOHEADER *)newBitmapInfo;
//size_t stride = (size_t)(newBitmapInfo->bmiHeader.biWidth * (newBitmapInfo->bmiHeader.biBitCount >> 3));
size_t stride = (size_t)(4 * ((newBitmapInfo->bmiHeader.biWidth * newBitmapInfo->bmiHeader.biBitCount + 31) / 32)); size_t stride = (size_t)(4 * ((newBitmapInfo->bmiHeader.biWidth * newBitmapInfo->bmiHeader.biBitCount + 31) / 32));
size_t size = newBitmapInfo->bmiHeader.biSizeImage ? size_t size = newBitmapInfo->bmiHeader.biSizeImage ?
newBitmapInfo->bmiHeader.biSizeImage : newBitmapInfo->bmiHeader.biSizeImage :
newBitmapInfo->bmiHeader.biHeight * stride; newBitmapInfo->bmiHeader.biHeight * stride;
VOID * bitmapBits = malloc(size); VOID * bitmapBits = malloc(size);
//memcpy(bitmapBits, pjBits, size); memcpy(bitmapBits, pjBits, size);
// Switch Y
VOID * bitmapBitsSource = (VOID *)pjBits;
VOID * bitmapBitsDestination = bitmapBits + (newBitmapInfo->bmiHeader.biHeight - 1) * stride;
for(int y = 0; y < newBitmapInfo->bmiHeader.biHeight; y++) {
memcpy(bitmapBitsDestination, bitmapBitsSource, stride);
bitmapBitsSource += stride;
bitmapBitsDestination -= stride;
}
newHBITMAP->bitmapBits = bitmapBits; newHBITMAP->bitmapBits = bitmapBits;
return newHBITMAP; return newHBITMAP;
} }
@ -1784,11 +1602,19 @@ HBITMAP CreateDIBSection(HDC hdc, CONST BITMAPINFO *pbmi, UINT usage, VOID **ppv
HGDIOBJ newHBITMAP = (HGDIOBJ)malloc(sizeof(_HGDIOBJ)); HGDIOBJ newHBITMAP = (HGDIOBJ)malloc(sizeof(_HGDIOBJ));
memset(newHBITMAP, 0, sizeof(_HGDIOBJ)); memset(newHBITMAP, 0, sizeof(_HGDIOBJ));
newHBITMAP->handleType = HGDIOBJ_TYPE_BITMAP; newHBITMAP->handleType = HGDIOBJ_TYPE_BITMAP;
newHBITMAP->bitmapInfo = pbmi;
newHBITMAP->bitmapInfoHeader = (const BITMAPINFOHEADER *) pbmi; BITMAPINFO * newBitmapInfo = malloc(sizeof(BITMAPINFO));
memcpy(newBitmapInfo, pbmi, sizeof(BITMAPINFO));
newHBITMAP->bitmapInfo = newBitmapInfo;
newHBITMAP->bitmapInfoHeader = (BITMAPINFOHEADER *)newBitmapInfo;
// For DIB_RGB_COLORS only // For DIB_RGB_COLORS only
size_t size = (size_t) (pbmi->bmiHeader.biWidth * abs(pbmi->bmiHeader.biHeight) * 4); size_t stride = (size_t)(4 * ((newBitmapInfo->bmiHeader.biWidth * newBitmapInfo->bmiHeader.biBitCount + 31) / 32));
size_t size = newBitmapInfo->bmiHeader.biSizeImage ?
newBitmapInfo->bmiHeader.biSizeImage :
abs(newBitmapInfo->bmiHeader.biHeight) * stride;
newHBITMAP->bitmapBits = malloc(size); newHBITMAP->bitmapBits = malloc(size);
memset((void *) newHBITMAP->bitmapBits, 0, size); memset((void *) newHBITMAP->bitmapBits, 0, size);
*ppvBits = (void *) newHBITMAP->bitmapBits; *ppvBits = (void *) newHBITMAP->bitmapBits;
return newHBITMAP; return newHBITMAP;