⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 pbobble2.c

📁 十七种模拟器源代码 非常有用的作课程设计不可缺少的
💻 C
📖 第 1 页 / 共 2 页
字号:
   // ----------------------   AddF3MemoryMap(0x100000);   RAM_BG0=RAM+0x33000;   RAM_BG1=RAM+0x32000;   RAM_BG2=RAM+0x31000;   RAM_BG3=RAM+0x30000;   RAM_SCR0=RAM+0x6A006;   RAM_SCR1=RAM+0x6A004;   RAM_SCR2=RAM+0x6A002;   RAM_SCR3=RAM+0x6A000;   SCR3_XOFS=0xF640;   SCR2_XOFS=0xF740;   SCR1_XOFS=0xF840;   SCR0_XOFS=0xF940;   SCR3_YOFS=0xF400;   SCR2_YOFS=0xF400;   SCR1_YOFS=0xF400;   SCR0_YOFS=0xF400;   if(!load_rom("e10.29", RAM, 0x40000)) return;   for(ta=0;ta<0x40000;ta++){      ROM[(ta<<2)+0]=RAM[ta];   }   if(!load_rom("e10.28", RAM, 0x40000)) return;   for(ta=0;ta<0x40000;ta++){      ROM[(ta<<2)+1]=RAM[ta];   }   if(!load_rom("e10.27", RAM, 0x40000)) return;   for(ta=0;ta<0x40000;ta++){      ROM[(ta<<2)+2]=RAM[ta];   }   if(!load_rom("e10.26", RAM, 0x40000)) return;   for(ta=0;ta<0x40000;ta++){      ROM[(ta<<2)+3]=RAM[ta];   }   // 68000 code   M68000ROM = load_region[REGION_ROM2];         if(!(PCMROM=AllocateMem(0x800000))) return;      load_be("e10-03.rom",PCMROM,0x200000);   load_be("e10-04.rom",PCMROM+0x400000,0x200000);   max_banks_this_game=3; //=memory_region_length(REGION_SOUND1)/0x400000;   memset(RAM+0x00000,0x00,0x80000);   memset(RAM+0x69000,0xFF,0x01000);   // EEPROM ACCESS   // -------------   WriteWord68k(&ROM[0x0044D2],0x7F00);		//	raine	#$00 <eeprom access>   WriteWord68k(&ROM[0x0044D4],0x4ED6);		//	jmp	(a6)   // SPEED HACK   // ----------   WriteWord68k(&ROM[0x031D4],0x4EF9);		//	jmp	$F8000   WriteLong68k(&ROM[0x031D6],0x000F8000);   WriteWord68k(&ROM[0xF8000],0x4EB9);		//	jsr	$0291C <random gen>   WriteLong68k(&ROM[0xF8002],0x0000291C);   WriteWord68k(&ROM[0xF8006],0x7F02);		//	raine	#$02 <stop cpu>   WriteWord68k(&ROM[0xF8008],0x6100-10);	//	bra.s	<loop>   F3SystemEEPROMAccess=&F3SysEEPROMAccessMode2;   set_colour_mapper(&col_map_xxxx_xxxx_rrrr_rrrr_gggg_gggg_bbbb_bbbb);   InitPaletteMap(RAM+0x60000, 0x200, 0x40, 0x8000);   // Init tc0003vcu emulation   // ------------------------   tc0003vcu.RAM	= RAM+0x20000;   tc0003vcu.mapper	= &Map_24bit_xRGB;   tc0003vcu.bmp_x	= 64;   tc0003vcu.bmp_y	= 64;   tc0003vcu.bmp_w	= 320;   tc0003vcu.bmp_h	= 232;   tc0003vcu.scr_x	= 0;   tc0003vcu.scr_y	= 0;   // Init tc0200obj emulation   // ------------------------   tc0200obj.RAM	= RAM+0x20000;   tc0200obj.RAM_B	= RAM+0x28000;   tc0200obj.GFX	= GFX_SPR;   tc0200obj.MASK	= GFX_SPR_SOLID;   tc0200obj.bmp_x	= 64;   tc0200obj.bmp_y	= 64;   tc0200obj.bmp_w	= 320;   tc0200obj.bmp_h	= 232;   tc0200obj.mapper	= &Map_24bit_xRGB;   tc0200obj.tile_mask	= 0x3FFF;   tc0200obj.ofs_x	= 0-0x2E;   tc0200obj.ofs_y	= 0-0x18;   tc0200obj.cols	= 16;   init_tc0200obj();   init_f3_system_ioc(F3_IOC_2P_3BUTTON);   init_m68k();   setup_sound_68000();}void ClearPuzzleBobble2(void){   save_eeprom();#ifdef RAINE_DEBUG      //save_debug("ROM.bin",ROM,0x100000,0);      //save_debug("RAM.bin",RAM,0x080000,0);      //save_debug("GFX.bin",GFX,0x400000,0);#endif}void ClearPuzzleBobble2x(void){   save_eeprom();   #ifdef RAINE_DEBUG      //save_debug("ROM.bin",ROM,0x100000,0);      //save_debug("RAM.bin",RAM,0x080000,0);      //save_debug("GFX.bin",GFX,0x400000,0);   #endif}void DrawPuzzleBobble2(void){   int x16,y16,zz,zzz,zzzz;   int ta,x,y,z;   UINT8 *map;   ClearPaletteMap();   // Init tc0003vcu emulation   // ------------------------   tc0003vcu_layer_count = 0;   if(check_layer_enabled(f3_bg0_id)){   MAKE_SCROLL_512x512_4_16(      (ReadWord68k(&RAM_SCR0[0])-SCR0_XOFS)>>6,      (ReadWord68k(&RAM_SCR0[8])-SCR0_YOFS)>>7   );   START_SCROLL_512x512_4_16(64,64,320,232);      ta=ReadWord68k(&RAM_BG0[zz+2])&0x3FFF;      MAP_PALETTE_MULTI_MAPPED_NEW(         ReadWord68k(&RAM_BG0[zz])&0x1FF,         GFX_BG0_PENS[ta],         map      );      switch(RAM_BG0[zz]&0xC0){         case 0x00: Draw16x16_Mapped_Rot(&GFX_BG0[ta<<8],x,y,map);        break;         case 0x40: Draw16x16_Mapped_FlipY_Rot(&GFX_BG0[ta<<8],x,y,map);  break;         case 0x80: Draw16x16_Mapped_FlipX_Rot(&GFX_BG0[ta<<8],x,y,map);  break;         case 0xC0: Draw16x16_Mapped_FlipXY_Rot(&GFX_BG0[ta<<8],x,y,map); break;      }   END_SCROLL_512x512_4_16();   }   if(check_layer_enabled(f3_bg1_id)){   MAKE_SCROLL_512x512_4_16(      (ReadWord68k(&RAM_SCR1[0])-SCR1_XOFS)>>6,      (ReadWord68k(&RAM_SCR1[8])-SCR1_YOFS)>>7   );   START_SCROLL_512x512_4_16(64,64,320,232);      ta=ReadWord68k(&RAM_BG1[zz+2])&0x3FFF;      if(GFX_BG0_SOLID[ta]!=0){			// No pixels; skip         MAP_PALETTE_MULTI_MAPPED_NEW(            ReadWord68k(&RAM_BG1[zz])&0x1FF,            GFX_BG0_PENS[ta],            map         );         if(GFX_BG0_SOLID[ta]==1){		// Some pixels; trans            switch(RAM_BG1[zz]&0xC0){               case 0x00: Draw16x16_Trans_Mapped_Rot(&GFX_BG0[ta<<8],x,y,map);        break;               case 0x40: Draw16x16_Trans_Mapped_FlipY_Rot(&GFX_BG0[ta<<8],x,y,map);  break;               case 0x80: Draw16x16_Trans_Mapped_FlipX_Rot(&GFX_BG0[ta<<8],x,y,map);  break;               case 0xC0: Draw16x16_Trans_Mapped_FlipXY_Rot(&GFX_BG0[ta<<8],x,y,map); break;            }         }         else{					// all pixels; solid            switch(RAM_BG1[zz]&0xC0){               case 0x00: Draw16x16_Mapped_Rot(&GFX_BG0[ta<<8],x,y,map);        break;               case 0x40: Draw16x16_Mapped_FlipY_Rot(&GFX_BG0[ta<<8],x,y,map);  break;               case 0x80: Draw16x16_Mapped_FlipX_Rot(&GFX_BG0[ta<<8],x,y,map);  break;               case 0xC0: Draw16x16_Mapped_FlipXY_Rot(&GFX_BG0[ta<<8],x,y,map); break;            }         }      }   END_SCROLL_512x512_4_16();   }   if(check_layer_enabled(f3_bg2_id)){   MAKE_SCROLL_512x512_4_16(      (ReadWord68k(&RAM_SCR2[0])-SCR2_XOFS)>>6,      (ReadWord68k(&RAM_SCR2[8])-SCR2_YOFS)>>7   );   START_SCROLL_512x512_4_16(64,64,320,232);      ta=ReadWord68k(&RAM_BG2[zz+2])&0x3FFF;      if(GFX_BG0_SOLID[ta]!=0){			// No pixels; skip         MAP_PALETTE_MULTI_MAPPED_NEW(            ReadWord68k(&RAM_BG2[zz])&0x1FF,            GFX_BG0_PENS[ta],            map         );         if(GFX_BG0_SOLID[ta]==1){		// Some pixels; trans            switch(RAM_BG2[zz]&0xC0){               case 0x00: Draw16x16_Trans_Mapped_Rot(&GFX_BG0[ta<<8],x,y,map);        break;               case 0x40: Draw16x16_Trans_Mapped_FlipY_Rot(&GFX_BG0[ta<<8],x,y,map);  break;               case 0x80: Draw16x16_Trans_Mapped_FlipX_Rot(&GFX_BG0[ta<<8],x,y,map);  break;               case 0xC0: Draw16x16_Trans_Mapped_FlipXY_Rot(&GFX_BG0[ta<<8],x,y,map); break;            }         }         else{					// all pixels; solid            switch(RAM_BG2[zz]&0xC0){               case 0x00: Draw16x16_Mapped_Rot(&GFX_BG0[ta<<8],x,y,map);        break;               case 0x40: Draw16x16_Mapped_FlipY_Rot(&GFX_BG0[ta<<8],x,y,map);  break;               case 0x80: Draw16x16_Mapped_FlipX_Rot(&GFX_BG0[ta<<8],x,y,map);  break;               case 0xC0: Draw16x16_Mapped_FlipXY_Rot(&GFX_BG0[ta<<8],x,y,map); break;            }         }      }   END_SCROLL_512x512_4_16();   }   if(check_layer_enabled(f3_bg3_id)){   MAKE_SCROLL_512x512_4_16(      (ReadWord68k(&RAM_SCR3[0])-SCR3_XOFS)>>6,      (ReadWord68k(&RAM_SCR3[8])-SCR3_YOFS)>>7   );   START_SCROLL_512x512_4_16(64,64,320,232);      ta=ReadWord68k(&RAM_BG3[zz+2])&0x3FFF;      if(GFX_BG0_SOLID[ta]!=0){			// No pixels; skip         MAP_PALETTE_MULTI_MAPPED_NEW(            ReadWord68k(&RAM_BG3[zz])&0x1FF,            GFX_BG0_PENS[ta],            map         );         if(GFX_BG0_SOLID[ta]==1){		// Some pixels; trans            switch(RAM_BG3[zz]&0xC0){               case 0x00: Draw16x16_Trans_Mapped_Rot(&GFX_BG0[ta<<8],x,y,map);        break;               case 0x40: Draw16x16_Trans_Mapped_FlipY_Rot(&GFX_BG0[ta<<8],x,y,map);  break;               case 0x80: Draw16x16_Trans_Mapped_FlipX_Rot(&GFX_BG0[ta<<8],x,y,map);  break;               case 0xC0: Draw16x16_Trans_Mapped_FlipXY_Rot(&GFX_BG0[ta<<8],x,y,map); break;            }         }         else{					// all pixels; solid            switch(RAM_BG3[zz]&0xC0){               case 0x00: Draw16x16_Mapped_Rot(&GFX_BG0[ta<<8],x,y,map);        break;               case 0x40: Draw16x16_Mapped_FlipY_Rot(&GFX_BG0[ta<<8],x,y,map);  break;               case 0x80: Draw16x16_Mapped_FlipX_Rot(&GFX_BG0[ta<<8],x,y,map);  break;               case 0xC0: Draw16x16_Mapped_FlipXY_Rot(&GFX_BG0[ta<<8],x,y,map); break;            }         }      }   END_SCROLL_512x512_4_16();   }   // object   render_tc0200obj_mapped_f3system_b();   if(check_layer_enabled(f3_bg5_id)){   zz=0;   for(y=64;y<232+64;y+=8){   for(x=64;x<320+64;x+=8){      z=RAM[0x3C001+zz];      if((z!=0)&&(z!=0x10)){		// 0x10='brown' rectangle         MAP_PALETTE_MULTI_MAPPED_NEW(            (RAM[0x3C000+zz]>>1)&0x3F,            16,            map         );         if((RAM[0x3C000+zz]&0x01)!=0){            Draw8x8_Trans_Packed_Mapped_Rot(&RAM[0x3E000+(z<<5)],x,y,map);         }         else{            Draw8x8_Trans_Packed_Mapped_FlipY_Rot(&RAM[0x3E000+(z<<5)],x,y,map);         }      }      zz+=2;   }   zz+=(128-80);   }   }}/******************************************************************************//* ENSONIQ ES-5505 [OTIS]                                                     *//******************************************************************************//*1E - Page SelectPage	Address	Function00 - 1F	00 - 1D	Voice Specific Control40	00 - ?? *//******************************************************************************//* ENSONIQ ES-5510 [Ensoniq Signal Processor / DSP]                           *//******************************************************************************//*Address	Register Name	Bits	Description / Function	---------------------------------------------------------------00	GPR        	23-16	GPR / SPR Data MS-byte	01	GPR 		15-8	GPR / SPR  Data	02	GPR   		7-0	GPR / SPR  Data LS-byte	03	INSTR           47-40	Mult D Operand Address	04	INSTR   	39-32	Mult C Operand Address	05	INSTR 		31-24 	ALU B Operand Address	06	INSTR    	23-16	ALU A Operand Address	07	INSTR    	15-8	ALU Opcode / Operand Select	08	INSTR    	7-3	Skip Flag +  MAC + RAM Control	09	DIL 		23-16	DRAM Input Latch MS-byte	0A	DIL 		15-8	DRAM Input Latch 	0B	DIL		7-0	DRAM Input Latch LS-byte	 (always read as 00 )0C	DOL 		23-16	DRAM Ouput Latch MS-byte	0D	DOL 		15-8	DRAM Ouput Latch 	0E	DOL		7-0	DRAM Ouput Latch LS-byte	 (always read as FF )0F	DADR		23-16	DRAM Address MS-byte	 (write last to transfer data)10	DADR		15-8	DRAM Address 	11	DADR  		7-4	DRAM Address LS-byte	12	Host Control 	2-0	ESP State / Control Flags	14	RAM Access Control 	7-6	RAM,I/O, Read/Write Select	16	Program Counter            		For Test Purposes Only	17	Internal Refresh counter        		For Test Purposes Only	18	Host serial control	7-0	Serial I/O Format and Control	1F	Halt enable       (write only) Frame Counter (read only)		Stop ESP Execution For Test Purposes Only	80	Read  Select:  GPR + INSTR  	7-0	Read  Address	Address Ranges:	A0	Write Select:  GPR      	7-0	Write Address	GPR       $00 - $BF	C0	Write Select:  INSTR      	7-0	Write Address	SPR       $EA - $FF	E0	Write Select:  GPR+INSTR	7-0	Write Address	INSTR   $00 - $9F	*//*Elevator Action 2-----------------EnsoniqOTISR2609-0381303FP05164K9442Ensoniq57010001019416MVA82Ensoniq609-0390750FP03457 K9420ES5510000106ESPR6MotorolaMC68681PTwin Qix--------EnsoniqOTISR2609-0381303FP05164K9442Ensoniq57010001019416MVA82Ensoniq609-0390750FP03457 K9420ES5510000106ESPR6MotorolaMC68681PSuper Chase-----------6800068681MB8421 (x2)MB87078Ensoniq 5510Ensoniq 5505*/

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -