win32 Pico mostly finished
[picodrive.git] / platform / win32 / GenaDrive / Emu.cpp
index d93abaf..46fa27a 100644 (file)
@@ -2,8 +2,11 @@
 #include "app.h"\r
 \r
 unsigned short *EmuScreen=NULL;\r
-int EmuWidth=0,EmuHeight=0;\r
-static int EmuScan(unsigned int num, void *sdata);\r
+int EmuWidth=320,EmuHeight=224;\r
+RECT EmuScreenRect = { 0, 0, 320, 224 };\r
+int PicoPadAdd = 0;\r
+\r
+static int EmuScan(unsigned int num);\r
 unsigned char *PicoDraw2FB = NULL;\r
 \r
 int EmuInit()\r
@@ -20,7 +23,7 @@ int EmuInit()
   memset(EmuScreen,0,len);\r
 \r
   PicoDrawSetColorFormat(1);\r
-  PicoScan=EmuScan;\r
+  PicoScanBegin=EmuScan;\r
 \r
   return 0;\r
 }\r
@@ -36,18 +39,9 @@ void EmuExit()
 }\r
 \r
 // Megadrive scanline callback:\r
-static int EmuScan(unsigned int num, void *sdata)\r
+static int EmuScan(unsigned int num)\r
 {\r
-  unsigned short *pd=NULL,*end=NULL;\r
-  unsigned short *ps=NULL;\r
-\r
-  if (num>=(unsigned int)EmuHeight) return 0;\r
-\r
-  // Copy scanline to screen buffer:\r
-  pd=EmuScreen+(num<<8)+(num<<6); end=pd+320;\r
-  ps=(unsigned short *)sdata;\r
-\r
-  do { *pd++=0xf800;/**ps++;*/ } while (pd<end);\r
+  DrawLineDest=EmuScreen+(num<<8)+(num<<6);\r
   \r
   return 0;\r
 }\r
@@ -65,19 +59,16 @@ int EmuFrame()
   }\r
 \r
   PicoPad[0]=input;\r
+  PicoPad[0]|=PicoPadAdd;\r
 \r
-  PsndOut=(short *)DSoundNext; PicoFrame(); PsndOut=NULL;\r
+  PsndOut=(short *)DSoundNext;\r
+  PicoFrame();\r
+  PsndOut=NULL;\r
 \r
   return 0;\r
 }\r
 \r
 \r
-\r
-int mp3_get_offset(void) // 0-1023\r
-{\r
-  return 0;\r
-}\r
-\r
 void mp3_update(int *buffer, int length, int stereo)\r
 {\r
 }\r