X-Git-Url: http://4ch.mooo.com/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fmodex16.h;h=8068a02469aa3ade53ecf94fc24c74aaf900c801;hb=73a484ef8bbdbcb82bde5580b77001e7c54265f8;hp=01e687c700d7c5487c8ddb0d0ddbb5135770447b;hpb=f1605e99959acfb32b36ae875601fc14dd670742;p=16.git diff --git a/src/lib/modex16.h b/src/lib/modex16.h index 01e687c7..8068a024 100755 --- a/src/lib/modex16.h +++ b/src/lib/modex16.h @@ -32,6 +32,13 @@ #include "src/lib/16_head.h" #include "src/lib/16text.h" +//320x240 = 20x15 +//256x192 = 16x12 + +//temp defines +#define TILEWH 16 +#define QUADWH TILEWH/2 + /* -========================== Types & Macros ==========================- */ #define PAGE_OFFSET(x,y) (((y)<<6)+((y)<<4)+((x)>>2)) #define PLANE(x) (1<< (x&3)) @@ -39,11 +46,13 @@ typedef struct { word id; /* the Identification number of the page~ For layering~ */ - byte far* data; /* the data for the page */ - word dx; /* col we are viewing on the virtual screen */ - word dy; /* row we are viewing on the virtual screen */ - word width; /* virtual width of the page */ - word height; /* virtual height of the page */ + byte far* data; /* the data for the page */ + word dx; /* col we are viewing on the virtual screen */ + word dy; /* row we are viewing on the virtual screen */ + word width; /* virtual width of the page */ + word height; /* virtual height of the page */ + word tw; + word th; } page_t; typedef union @@ -60,14 +69,16 @@ void modexEnter(); void modexLeave(); page_t modexDefaultPage(); page_t modexNextPage(page_t *p); -page_t modexNextPage0(page_t *p, word x, word y); +page_t modexNextPageFlexibleSize(page_t *p, word x, word y); void modexShowPage(page_t *page); void modexPanPage(page_t *page, int dx, int dy); void modexSelectPlane(byte plane); void modexClearRegion(page_t *page, int x, int y, int w, int h, byte color); void oldDrawBmp(byte far* page, int x, int y, bitmap_t *bmp, byte sprite); +//void CDrawBmp(byte far* vgamem, page_t* page, int x, int y, bitmap_t *bmp, byte sprite); void modexDrawBmp(page_t *page, int x, int y, bitmap_t *bmp); void modexDrawBmpRegion(page_t *page, int x, int y, int rx, int ry, int rw, int rh, bitmap_t *bmp); +void modex_sparky4_DrawBmpRegion(page_t *page, int x, int y, int rx, int ry, int rw, int rh, bitmap_t *bmp); void modexDrawPlanarBuf(page_t *page, int x, int y, planar_buf_t *bmp); void modexDrawSprite(page_t *page, int x, int y, bitmap_t *bmp); void modexDrawSpriteRegion(page_t *page, int x, int y, int rx, int ry, int rw, int rh, bitmap_t *bmp); @@ -99,6 +110,7 @@ byte modexgetPixel(page_t *page, int x, int y); void modexhlin(page_t *page, word xl, word xh, word y, word color); void modexprint(page_t *page, word x, word y, word t, word col, word bgcol, const byte *str); void modexprintbig(page_t *page, word x, word y, word t, word col, word bgcol, const byte *str); +void cls(page_t *page, byte color, byte *Where); void modexWaitBorder(); /* -======================= Constants & Vars ==========================- */ @@ -126,8 +138,8 @@ extern int old_mode; #define INPUT_STATUS_1 0x03da #define DISPLAY_ENABLE 0x01 #define MAP_MASK 0x02 -#define PAL_READ_REG 0x03C7 /* Color register, read address */ -#define PAL_WRITE_REG 0x03C8 /* Color register, write address */ -#define PAL_DATA_REG 0x03C9 /* Color register, data port */ -#define PAL_SIZE (256 * 3) +#define PAL_READ_REG 0x03C7 /* Color register, read address */ +#define PAL_WRITE_REG 0x03C8 /* Color register, write address */ +#define PAL_DATA_REG 0x03C9 /* Color register, data port */ +#define PAL_SIZE (256 * 3) #endif