📄 pbobble2.c
字号:
// ---------------------- 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 + -