/*#*
*#* $Log$
+ *#* Revision 1.4 2006/02/10 12:33:49 bernie
+ *#* Make emulator display a bit larger.
+ *#*
+ *#* Revision 1.3 2006/01/23 23:11:07 bernie
+ *#* Use RASTER_SIZE() to compute... err... the raster size.
+ *#*
+ *#* Revision 1.2 2006/01/17 02:30:43 bernie
+ *#* Fix QImage format.
+ *#*
*#* Revision 1.1 2006/01/16 03:51:35 bernie
*#* Add LCD Qt emulator.
*#*
#include "lcd_gfx_qt.h"
#include <emul/emul.h>
+#include <cfg/debug.h>
#include <qpainter.h>
#include <qimage.h>
void EmulLCD::drawContents(QPainter *p)
{
- QImage img(raster, WIDTH, HEIGHT, 1, NULL, 0, QImage::IgnoreEndian);
+ QImage img(raster, WIDTH, HEIGHT, 1, NULL, 0, QImage::BigEndian);
p->setBackgroundMode(OpaqueMode);
p->setPen(fg_color);
/*!
* Raster buffer to draw into.
+ *
* Bits in the bitmap bytes have vertical orientation,
* as required by the LCD driver.
*/
DECLARE_WALL(wall_before_raster, WALL_SIZE)
-static uint8_t lcd_raster[EmulLCD::WIDTH * ((EmulLCD::HEIGHT + 7) / 8)];
+static uint8_t lcd_raster[RASTER_SIZE(EmulLCD::WIDTH, EmulLCD::HEIGHT)];
DECLARE_WALL(wall_after_raster, WALL_SIZE)
/*! Default LCD bitmap */
struct Bitmap lcd_bitmap;
-extern "C" void lcd_init(void)
+/*extern "C"*/ void lcd_init(void)
{
+ //FIXME INIT_WALL(wall_before_raster);
+ //FIXME INIT_WALL(wall_after_raster);
gfx_bitmapInit(&lcd_bitmap, lcd_raster, EmulLCD::WIDTH, EmulLCD::HEIGHT);
gfx_bitmapClear(&lcd_bitmap);
}
-extern "C" void lcd_blit_bitmap(Bitmap *bm)
+/*extern "C"*/ void lcd_blit_bitmap(Bitmap *bm)
{
+ //FIXME CHECK_WALL(wall_before_raster);
+ //FIXME CHECK_WALL(wall_after_raster);
emul->emulLCD->writeRaster(bm->raster);
}