2002-04-27 15:20:53 +00:00
|
|
|
/***************************************************************************
|
|
|
|
* __________ __ ___.
|
|
|
|
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
|
|
|
|
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
|
|
|
|
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
|
|
|
|
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
|
|
|
|
* \/ \/ \/ \/ \/
|
|
|
|
* $Id$
|
|
|
|
*
|
|
|
|
* Copyright (C) 2002 by Felix Arends
|
|
|
|
*
|
|
|
|
* All files in this archive are subject to the GNU General Public License.
|
|
|
|
* See the file COPYING in the source tree root for full license agreement.
|
|
|
|
*
|
|
|
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
|
|
* KIND, either express or implied.
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#include <windows.h>
|
|
|
|
#include <process.h>
|
|
|
|
#include "uisw32.h"
|
|
|
|
#include "lcd.h"
|
2003-04-19 13:15:33 +00:00
|
|
|
#include "lcd-playersim.h"
|
2002-04-27 15:20:53 +00:00
|
|
|
|
2003-12-23 23:41:45 +00:00
|
|
|
unsigned char lcd_framebuffer[LCD_HEIGHT/8][LCD_WIDTH]; /* the display */
|
2002-08-07 11:10:06 +00:00
|
|
|
char bitmap[LCD_HEIGHT][LCD_WIDTH]; /* the ui display */
|
2002-04-27 15:20:53 +00:00
|
|
|
|
|
|
|
BITMAPINFO2 bmi =
|
|
|
|
{
|
2002-08-02 14:00:52 +00:00
|
|
|
{sizeof (BITMAPINFOHEADER),
|
|
|
|
LCD_WIDTH, -LCD_HEIGHT, 1, 8,
|
|
|
|
BI_RGB, 0, 0, 0, 2, 2,
|
|
|
|
},
|
|
|
|
{
|
2003-04-19 13:15:33 +00:00
|
|
|
//{UI_LCD_BGCOLOR, 0}, /* green background color */
|
|
|
|
{UI_LCD_BGCOLORLIGHT, 0}, /* green background color */
|
2002-09-10 07:19:40 +00:00
|
|
|
{UI_LCD_BLACK, 0} /* black color */
|
2002-08-02 14:00:52 +00:00
|
|
|
}
|
|
|
|
|
2002-09-10 07:19:40 +00:00
|
|
|
}; /* bitmap information */
|
2002-04-27 15:20:53 +00:00
|
|
|
|
2003-04-19 13:15:33 +00:00
|
|
|
#ifdef HAVE_LCD_CHARCELLS
|
|
|
|
/* Defined in lcd-playersim.c */
|
|
|
|
extern void lcd_print_char(int x, int y);
|
|
|
|
extern bool lcd_display_redraw;
|
|
|
|
extern unsigned char hardware_buffer_lcd[11][2];
|
|
|
|
static unsigned char lcd_buffer_copy[11][2];
|
|
|
|
#endif
|
2002-04-27 15:20:53 +00:00
|
|
|
|
2003-02-27 15:44:26 +00:00
|
|
|
void lcd_set_invert_display(bool invert)
|
|
|
|
{
|
|
|
|
(void)invert;
|
|
|
|
}
|
|
|
|
|
2002-09-10 07:19:40 +00:00
|
|
|
/* lcd_update()
|
|
|
|
update lcd */
|
2002-04-27 15:20:53 +00:00
|
|
|
void lcd_update()
|
|
|
|
{
|
2002-09-10 07:19:40 +00:00
|
|
|
int x, y;
|
2005-03-06 13:28:40 +00:00
|
|
|
RECT r;
|
|
|
|
|
2002-04-27 15:20:53 +00:00
|
|
|
if (hGUIWnd == NULL)
|
|
|
|
_endthread ();
|
|
|
|
|
2003-04-19 13:15:33 +00:00
|
|
|
#ifdef HAVE_LCD_CHARCELLS
|
|
|
|
for (y = 0; y < 2; y++)
|
|
|
|
{
|
|
|
|
for (x = 0; x < 11; x++)
|
|
|
|
{
|
|
|
|
if (lcd_display_redraw ||
|
|
|
|
lcd_buffer_copy[x][y] != hardware_buffer_lcd[x][y])
|
|
|
|
{
|
|
|
|
lcd_buffer_copy[x][y] = hardware_buffer_lcd[x][y];
|
|
|
|
lcd_print_char(x, y);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
lcd_display_redraw = false;
|
|
|
|
#endif
|
|
|
|
|
2002-09-10 07:19:40 +00:00
|
|
|
for (x = 0; x < LCD_WIDTH; x++)
|
|
|
|
for (y = 0; y < LCD_HEIGHT; y++)
|
2003-12-23 23:41:45 +00:00
|
|
|
bitmap[y][x] = ((lcd_framebuffer[y/8][x] >> (y & 7)) & 1);
|
2002-04-27 15:20:53 +00:00
|
|
|
|
2005-03-06 13:28:40 +00:00
|
|
|
/* Invalidate only the window part that actually did change */
|
|
|
|
GetClientRect (hGUIWnd, &r);
|
|
|
|
r.left = UI_LCD_POSX * r.right / UI_WIDTH;
|
|
|
|
r.top = UI_LCD_POSY * r.bottom / UI_HEIGHT;
|
|
|
|
r.right = (UI_LCD_POSX + UI_LCD_WIDTH) * r.right / UI_WIDTH;
|
|
|
|
r.bottom = (UI_LCD_POSY + UI_LCD_HEIGHT) * r.bottom / UI_HEIGHT;
|
|
|
|
InvalidateRect (hGUIWnd, &r, FALSE);
|
2002-04-27 17:02:17 +00:00
|
|
|
}
|
|
|
|
|
2002-09-10 07:19:40 +00:00
|
|
|
void lcd_update_rect(int x_start, int y_start,
|
|
|
|
int width, int height)
|
|
|
|
{
|
|
|
|
int x, y;
|
|
|
|
int xmax, ymax;
|
2005-03-06 13:28:40 +00:00
|
|
|
RECT r;
|
2002-09-10 07:19:40 +00:00
|
|
|
|
|
|
|
ymax = y_start + height;
|
|
|
|
xmax = x_start + width;
|
|
|
|
|
|
|
|
if (hGUIWnd == NULL)
|
|
|
|
_endthread ();
|
|
|
|
|
|
|
|
if(xmax > LCD_WIDTH)
|
|
|
|
xmax = LCD_WIDTH;
|
|
|
|
if(ymax >= LCD_HEIGHT)
|
|
|
|
ymax = LCD_HEIGHT;
|
|
|
|
|
|
|
|
for (x = x_start; x < xmax; x++)
|
|
|
|
for (y = y_start; y < ymax; y++)
|
2003-12-23 23:41:45 +00:00
|
|
|
bitmap[y][x] = ((lcd_framebuffer[y/8][x] >> (y & 7)) & 1);
|
2002-09-10 07:19:40 +00:00
|
|
|
|
2005-03-06 13:28:40 +00:00
|
|
|
/* Invalidate only the window part that actually did change */
|
|
|
|
GetClientRect (hGUIWnd, &r);
|
|
|
|
r.left = (UI_LCD_POSX + (UI_LCD_WIDTH * x_start / LCD_WIDTH))
|
|
|
|
* r.right / UI_WIDTH;
|
|
|
|
r.top = (UI_LCD_POSY + (UI_LCD_HEIGHT * y_start / LCD_HEIGHT))
|
|
|
|
* r.bottom / UI_HEIGHT;
|
|
|
|
r.right = (UI_LCD_POSX + (UI_LCD_WIDTH * xmax / LCD_WIDTH))
|
|
|
|
* r.right / UI_WIDTH;
|
|
|
|
r.bottom = (UI_LCD_POSY + (UI_LCD_HEIGHT * ymax / LCD_HEIGHT))
|
|
|
|
* r.bottom / UI_HEIGHT;
|
|
|
|
InvalidateRect (hGUIWnd, &r, FALSE);
|
2002-09-10 07:19:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* lcd_backlight()
|
|
|
|
set backlight state of lcd */
|
|
|
|
void lcd_backlight (bool on)
|
2002-04-27 17:02:17 +00:00
|
|
|
{
|
|
|
|
if (on)
|
|
|
|
{
|
|
|
|
RGBQUAD blon = {UI_LCD_BGCOLORLIGHT, 0};
|
|
|
|
bmi.bmiColors[0] = blon;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
RGBQUAD blon = {UI_LCD_BGCOLOR, 0};
|
|
|
|
bmi.bmiColors[0] = blon;
|
|
|
|
}
|
|
|
|
|
2002-09-10 07:19:40 +00:00
|
|
|
InvalidateRect (hGUIWnd, NULL, FALSE);
|
2002-08-02 14:00:52 +00:00
|
|
|
}
|
2003-04-19 13:15:33 +00:00
|
|
|
|
|
|
|
void drawdots(int color, struct coordinate *points, int count)
|
|
|
|
{
|
|
|
|
while (count--)
|
|
|
|
{
|
|
|
|
if (color)
|
|
|
|
{
|
|
|
|
DRAW_PIXEL(points[count].x, points[count].y);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
CLEAR_PIXEL(points[count].x, points[count].y);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void drawrectangles(int color, struct rectangle *points, int count)
|
|
|
|
{
|
|
|
|
while (count--)
|
|
|
|
{
|
|
|
|
int x;
|
|
|
|
int y;
|
|
|
|
int ix;
|
|
|
|
int iy;
|
|
|
|
|
|
|
|
for (x = points[count].x, ix = 0; ix < points[count].width; x++, ix++)
|
|
|
|
{
|
|
|
|
for (y = points[count].y, iy = 0; iy < points[count].width; y++, iy++)
|
|
|
|
{
|
|
|
|
if (color)
|
|
|
|
{
|
|
|
|
DRAW_PIXEL(x, y);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
CLEAR_PIXEL(x, y);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|