2017-12-06 21:43:47 +08:00
|
|
|
#include "../core_include/api.h"
|
2018-10-04 14:30:29 +08:00
|
|
|
#include "../core_include/resource.h"
|
2017-12-06 21:43:47 +08:00
|
|
|
#include "../core_include/rect.h"
|
|
|
|
#include "../core_include/bitmap.h"
|
|
|
|
#include "../core_include/surface.h"
|
|
|
|
|
2019-02-20 12:55:27 +08:00
|
|
|
void c_bitmap::draw_bitmap(c_surface* surface, int z_order, const BITMAP_INFO *pBitmap, int x, int y, unsigned int mask_rgb)
|
2017-12-06 21:43:47 +08:00
|
|
|
{
|
2019-02-20 12:55:27 +08:00
|
|
|
if (0 == pBitmap) { return; }
|
2017-12-06 21:43:47 +08:00
|
|
|
draw_bitmap_565(surface, z_order, x, y, pBitmap->XSize, pBitmap->YSize,
|
2019-02-20 12:55:27 +08:00
|
|
|
(unsigned char const *)pBitmap->pData, mask_rgb);
|
2017-12-06 21:43:47 +08:00
|
|
|
}
|
|
|
|
|
2019-02-20 12:55:27 +08:00
|
|
|
void c_bitmap::draw_bitmap_in_rect(c_surface* surface, int z_order, const BITMAP_INFO *pBitmap, c_rect rect, unsigned int align_type, unsigned int mask_rgb)
|
2017-12-06 21:43:47 +08:00
|
|
|
{
|
2019-02-20 12:55:27 +08:00
|
|
|
if (0 == pBitmap) { return; }
|
2017-12-06 21:43:47 +08:00
|
|
|
int x, y;
|
|
|
|
get_bitmap_pos(pBitmap, rect, align_type, x, y);
|
2018-11-09 15:01:48 +08:00
|
|
|
draw_bitmap_565_in_rect(surface, z_order, rect.m_left + x, rect.m_top + y,
|
2017-12-06 21:43:47 +08:00
|
|
|
(rect.m_right - rect.m_left + 1), (rect.m_bottom - rect.m_top + 1),
|
2019-02-20 12:55:27 +08:00
|
|
|
pBitmap->XSize, pBitmap->YSize, (unsigned char const *)pBitmap->pData, mask_rgb);
|
2017-12-06 21:43:47 +08:00
|
|
|
}
|
|
|
|
|
2018-10-04 14:30:29 +08:00
|
|
|
void c_bitmap::get_bitmap_pos(const BITMAP_INFO *pBitmap, c_rect rect, unsigned int align_type, int &x, int &y)
|
2017-12-06 21:43:47 +08:00
|
|
|
{
|
|
|
|
int x_size = pBitmap->XSize;
|
|
|
|
int y_size = pBitmap->YSize;
|
|
|
|
|
|
|
|
int height = rect.m_bottom - rect.m_top + 1;
|
|
|
|
int width = rect.m_right - rect.m_left + 1;
|
|
|
|
|
|
|
|
x = y = 0;
|
|
|
|
|
|
|
|
switch (align_type & ALIGN_HMASK)
|
|
|
|
{
|
|
|
|
case ALIGN_HCENTER:
|
|
|
|
if (width > x_size)
|
|
|
|
{
|
|
|
|
x = (width - x_size)/2;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case ALIGN_LEFT:
|
|
|
|
x = 0;
|
|
|
|
break;
|
|
|
|
case ALIGN_RIGHT:
|
|
|
|
if (width > x_size)
|
|
|
|
{
|
|
|
|
x = width - x_size;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
ASSERT(0);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
switch (align_type & ALIGN_VMASK)
|
|
|
|
{
|
|
|
|
case ALIGN_VCENTER:
|
|
|
|
if (height > y_size)
|
|
|
|
{
|
|
|
|
y = (height - y_size)/2;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case ALIGN_TOP:
|
|
|
|
y = 0;
|
|
|
|
break;
|
|
|
|
case ALIGN_BOTTOM:
|
|
|
|
if (height > y_size)
|
|
|
|
{
|
|
|
|
y = height - y_size;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
ASSERT(0);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-02-20 12:55:27 +08:00
|
|
|
void c_bitmap::draw_bitmap_565(c_surface* surface, int z_order, int x, int y, int xsize, int ysize, const unsigned char* pPixel, unsigned int mask_rgb)
|
2017-12-06 21:43:47 +08:00
|
|
|
{
|
2019-02-20 12:55:27 +08:00
|
|
|
unsigned short* lower_fb = NULL;
|
|
|
|
int lower_fb_width = surface->m_width;
|
|
|
|
if (z_order >= Z_ORDER_LEVEL_1)
|
|
|
|
{
|
|
|
|
lower_fb = surface->m_frame_layers[z_order - 1].fb;
|
|
|
|
}
|
|
|
|
unsigned int mask_rgb_16 = GL_RGB_32_to_16(mask_rgb);
|
2018-11-09 15:01:48 +08:00
|
|
|
const unsigned short* pData = (const unsigned short*)pPixel;
|
2017-12-06 21:43:47 +08:00
|
|
|
for (int j = 0; j < ysize; j++)
|
|
|
|
{
|
|
|
|
const unsigned short * p = pData;
|
|
|
|
for (int i = 0; i < xsize; i++)
|
|
|
|
{
|
2017-12-13 22:29:28 +08:00
|
|
|
unsigned int rgb = *p++;
|
2019-02-20 12:55:27 +08:00
|
|
|
if (mask_rgb_16 == rgb)
|
|
|
|
{
|
|
|
|
if (lower_fb)
|
|
|
|
{//restore lower layer
|
|
|
|
surface->draw_pixel(x + i, y + j, GL_RGB_16_to_32(lower_fb[(y + j) * lower_fb_width + x + i]), z_order);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
surface->draw_pixel(x + i, y + j, GL_RGB_16_to_32(rgb), z_order);
|
|
|
|
}
|
2017-12-06 21:43:47 +08:00
|
|
|
}
|
2018-11-09 15:01:48 +08:00
|
|
|
pData += xsize;
|
2017-12-06 21:43:47 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-02-20 12:55:27 +08:00
|
|
|
void c_bitmap::draw_bitmap_565_in_rect(c_surface* surface, int z_order, int x, int y, int width, int height, int xsize, int ysize, const unsigned char* pPixel, unsigned int mask_rgb)
|
2017-12-06 21:43:47 +08:00
|
|
|
{
|
2019-02-20 12:55:27 +08:00
|
|
|
unsigned short* lower_fb = NULL;
|
|
|
|
int lower_fb_width = surface->m_width;
|
|
|
|
if (z_order >= Z_ORDER_LEVEL_1)
|
|
|
|
{
|
|
|
|
lower_fb = surface->m_frame_layers[z_order - 1].fb;
|
|
|
|
}
|
|
|
|
unsigned int mask_rgb_16 = GL_RGB_32_to_16(mask_rgb);
|
2018-11-09 15:01:48 +08:00
|
|
|
const unsigned short* pData = (const unsigned short*)pPixel;
|
2017-12-06 21:43:47 +08:00
|
|
|
for (int j = 0; j < ysize; j++)
|
|
|
|
{
|
2019-02-20 12:55:27 +08:00
|
|
|
if (j >= height) { break; }
|
2017-12-06 21:43:47 +08:00
|
|
|
const unsigned short * p = pData;
|
|
|
|
for (int i = 0; i < xsize; i++)
|
|
|
|
{
|
2019-02-20 12:55:27 +08:00
|
|
|
if (i >= width) { break; }
|
|
|
|
unsigned int rgb = *p++;
|
|
|
|
if (mask_rgb_16 == rgb)
|
2017-12-13 22:29:28 +08:00
|
|
|
{
|
2019-02-20 12:55:27 +08:00
|
|
|
if (lower_fb)
|
|
|
|
{//restore lower layer
|
|
|
|
surface->draw_pixel(x + i, y + j, GL_RGB_16_to_32(lower_fb[(y + j) * lower_fb_width + x + i]), z_order);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
surface->draw_pixel(x + i, y + j, GL_RGB_16_to_32(rgb), z_order);
|
2017-12-13 22:29:28 +08:00
|
|
|
}
|
2017-12-06 21:43:47 +08:00
|
|
|
}
|
2018-11-09 15:01:48 +08:00
|
|
|
pData += xsize;
|
2017-12-06 21:43:47 +08:00
|
|
|
}
|
|
|
|
}
|