mirror of
https://github.com/Pecusx/libretro-atari800.git
synced 2026-05-20 22:33:22 +02:00
some cleanup
This commit is contained in:
+110
-334
@@ -56,22 +56,25 @@ int MOUSE_EMULATED=1;
|
|||||||
#else
|
#else
|
||||||
int MOUSE_EMULATED=-1;
|
int MOUSE_EMULATED=-1;
|
||||||
#endif
|
#endif
|
||||||
int MAXPAS=6,SHIFTON=-1,MOUSEMODE=-1,PAS=4;
|
int SHIFTON=-1,MOUSEMODE=-1,PAS=4;
|
||||||
int SND=1; //SOUND ON/OFF
|
int SND=1; //SOUND ON/OFF
|
||||||
static int firstps=0;
|
|
||||||
int pauseg=0; //enter_gui
|
int pauseg=0; //enter_gui
|
||||||
int touch=-1; // gui mouse btn
|
int touch=-1; // gui mouse btn
|
||||||
//JOY
|
//JOY
|
||||||
int al[2][2];//left analog1
|
int al[2][2];//left analog1
|
||||||
int ar[2][2];//right analog1
|
int ar[2][2];//right analog1
|
||||||
unsigned char MXjoy[2]; // joy
|
unsigned char MXjoy[2]; // joy
|
||||||
int NUMjoy=1;
|
|
||||||
int NUMDRV=1;
|
#define JOYRANGE_UP_VALUE -16384 /* Joystick ranges in XY */
|
||||||
|
#define JOYRANGE_DOWN_VALUE 16383
|
||||||
|
#define JOYRANGE_LEFT_VALUE -16384
|
||||||
|
#define JOYRANGE_RIGHT_VALUE 16383
|
||||||
|
|
||||||
|
extern int a5200_joyhack;
|
||||||
|
|
||||||
//MOUSE
|
//MOUSE
|
||||||
extern int pushi; // gui mouse btn
|
extern int pushi; // gui mouse btn
|
||||||
int gmx,gmy; //gui mouse
|
int gmx,gmy; //gui mouse
|
||||||
int c64mouse_enable=0;
|
|
||||||
int mouse_wu=0,mouse_wd=0;
|
int mouse_wu=0,mouse_wd=0;
|
||||||
//KEYBOARD
|
//KEYBOARD
|
||||||
char Key_Sate[512];
|
char Key_Sate[512];
|
||||||
@@ -128,29 +131,8 @@ long GetTicks(void)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int slowdown=0;
|
int slowdown=0;
|
||||||
|
|
||||||
void gui_poll_events(void)
|
|
||||||
{
|
|
||||||
Ktime = GetTicks();
|
|
||||||
|
|
||||||
if(Ktime - LastFPSTime >= 1000/50)
|
|
||||||
{
|
|
||||||
slowdown=0;
|
|
||||||
frame++;
|
|
||||||
LastFPSTime = Ktime;
|
|
||||||
|
|
||||||
co_switch(mainThread);
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void retro_mouse(int a,int b) {}
|
|
||||||
void retro_mouse_but0(int a) {}
|
|
||||||
void retro_mouse_but1(int a) {}
|
|
||||||
void enter_options(void) {}
|
|
||||||
|
|
||||||
#if defined(ANDROID) || defined(__ANDROID__)
|
#if defined(ANDROID) || defined(__ANDROID__)
|
||||||
#define DEFAULT_PATH "/mnt/sdcard/"
|
#define DEFAULT_PATH "/mnt/sdcard/"
|
||||||
#else
|
#else
|
||||||
@@ -163,7 +145,6 @@ void enter_options(void) {}
|
|||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int STATUTON=-1;
|
|
||||||
#define RETRO_DEVICE_ATARI_KEYBOARD RETRO_DEVICE_SUBCLASS(RETRO_DEVICE_KEYBOARD, 0)
|
#define RETRO_DEVICE_ATARI_KEYBOARD RETRO_DEVICE_SUBCLASS(RETRO_DEVICE_KEYBOARD, 0)
|
||||||
#define RETRO_DEVICE_ATARI_JOYSTICK RETRO_DEVICE_SUBCLASS(RETRO_DEVICE_JOYPAD, 1)
|
#define RETRO_DEVICE_ATARI_JOYSTICK RETRO_DEVICE_SUBCLASS(RETRO_DEVICE_JOYPAD, 1)
|
||||||
|
|
||||||
@@ -181,7 +162,6 @@ void texture_init(void)
|
|||||||
gmy=(retroh/2)-1;
|
gmy=(retroh/2)-1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int bitstart=0;
|
|
||||||
int pushi=0; //mouse button
|
int pushi=0; //mouse button
|
||||||
int keydown=0,keyup=0;
|
int keydown=0,keyup=0;
|
||||||
int KBMOD=-1;
|
int KBMOD=-1;
|
||||||
@@ -191,7 +171,6 @@ int CTRLON=-1;
|
|||||||
extern unsigned short int bmp[400*300];
|
extern unsigned short int bmp[400*300];
|
||||||
extern unsigned atari_devices[ 2 ];
|
extern unsigned atari_devices[ 2 ];
|
||||||
|
|
||||||
#include "pokeysnd.h"
|
|
||||||
extern int UI_is_active;
|
extern int UI_is_active;
|
||||||
extern int CURRENT_TV;
|
extern int CURRENT_TV;
|
||||||
|
|
||||||
@@ -202,7 +181,6 @@ void retro_sound_update()
|
|||||||
if (! UI_is_active) {
|
if (! UI_is_active) {
|
||||||
|
|
||||||
Sound_Callback(SNDBUF, 1024*2*2);
|
Sound_Callback(SNDBUF, 1024*2*2);
|
||||||
//POKEYSND_Process(SNDBUF,snd_sampler_pal);
|
|
||||||
for(x=0;x<stop*2;x+=2)
|
for(x=0;x<stop*2;x+=2)
|
||||||
retro_audio_cb(SNDBUF[x],SNDBUF[x+2]);
|
retro_audio_cb(SNDBUF[x],SNDBUF[x+2]);
|
||||||
|
|
||||||
@@ -210,7 +188,6 @@ void retro_sound_update()
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//FIXME in kdbauto.c
|
|
||||||
extern void vkbd_key(int key,int pressed);
|
extern void vkbd_key(int key,int pressed);
|
||||||
|
|
||||||
void vkbd_key(int key,int pressed){
|
void vkbd_key(int key,int pressed){
|
||||||
@@ -219,108 +196,18 @@ void vkbd_key(int key,int pressed){
|
|||||||
if(pressed){
|
if(pressed){
|
||||||
|
|
||||||
if(SHIFTON==1)
|
if(SHIFTON==1)
|
||||||
;//keyboard_matrix[0x25 >> 4] &= ~bit_values2[0x25 & 7]; // key needs to be SHIFTed
|
;
|
||||||
|
Key_Sate[key]=1;
|
||||||
Key_Sate[key]=1;
|
// key is being held down
|
||||||
//keyboard_matrix[(unsigned char)key >> 4] &= ~bit_values2[(unsigned char)key & 7]; // key is being held down
|
|
||||||
|
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
if(SHIFTON==1)
|
if(SHIFTON==1)
|
||||||
;//keyboard_matrix[0x25 >> 4] |= bit_values2[0x25 & 7]; // make sure key is unSHIFTed
|
;
|
||||||
Key_Sate[key]=0;
|
Key_Sate[key]=0;
|
||||||
//keyboard_matrix[(unsigned char)key >> 4] |= bit_values2[(unsigned char)key & 7];
|
// key is being RELEASE
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void retro_key_down(int key)
|
|
||||||
{
|
|
||||||
int code;
|
|
||||||
/*
|
|
||||||
if(key<512)
|
|
||||||
code=KeySymToCPCKey[key];
|
|
||||||
else code = CPC_KEY_NULL;
|
|
||||||
CPC_SetKey(code);
|
|
||||||
*/
|
|
||||||
}
|
|
||||||
|
|
||||||
void retro_key_up(int key)
|
|
||||||
{
|
|
||||||
int code;
|
|
||||||
/*
|
|
||||||
if(key<512)
|
|
||||||
code=KeySymToCPCKey[key];
|
|
||||||
else code = CPC_KEY_NULL;
|
|
||||||
CPC_ClearKey(code);
|
|
||||||
*/
|
|
||||||
}
|
|
||||||
|
|
||||||
static int joy0_flag[6]={0,0,0,0,0,0};
|
|
||||||
//0x01,0x02,0x04,0x08,0x80 0x40
|
|
||||||
// UP DWN LEFT RGT BTN0 BTN1
|
|
||||||
// 0 1 2 3 4 5
|
|
||||||
void retro_joy0_test(unsigned char joy0)
|
|
||||||
{
|
|
||||||
|
|
||||||
if(joy0&0x01 && joy0_flag[0]==0 ){
|
|
||||||
//keyboard_matrix[(unsigned char)0x90 >> 4] &= ~bit_values2[(unsigned char)0x90 & 7];
|
|
||||||
joy0_flag[0]=1;
|
|
||||||
}
|
|
||||||
else if(joy0_flag[0]){
|
|
||||||
//keyboard_matrix[(unsigned char)0x90 >> 4] |= bit_values2[(unsigned char)0x90 & 7];
|
|
||||||
joy0_flag[0]=0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(joy0&0x02 && joy0_flag[1]==0 ){
|
|
||||||
//keyboard_matrix[(unsigned char)0x91 >> 4] &= ~bit_values2[(unsigned char)0x91 & 7];
|
|
||||||
joy0_flag[1]=1;
|
|
||||||
}
|
|
||||||
else if(joy0_flag[1]){
|
|
||||||
//keyboard_matrix[(unsigned char)0x91 >> 4] |= bit_values2[(unsigned char)0x91 & 7];
|
|
||||||
joy0_flag[1]=0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(joy0&0x04 && joy0_flag[2]==0 ){
|
|
||||||
//keyboard_matrix[(unsigned char)0x92 >> 4] &= ~bit_values2[(unsigned char)0x92 & 7];
|
|
||||||
joy0_flag[2]=1;
|
|
||||||
}
|
|
||||||
else if(joy0_flag[2]){
|
|
||||||
//keyboard_matrix[(unsigned char)0x92 >> 4] |= bit_values2[(unsigned char)0x92 & 7];
|
|
||||||
joy0_flag[2]=0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(joy0&0x08 && joy0_flag[3]==0 ){
|
|
||||||
//keyboard_matrix[(unsigned char)0x93 >> 4] &= ~bit_values2[(unsigned char)0x93 & 7];
|
|
||||||
joy0_flag[3]=1;
|
|
||||||
}
|
|
||||||
else if(joy0_flag[3]){
|
|
||||||
//keyboard_matrix[(unsigned char)0x93 >> 4] |= bit_values2[(unsigned char)0x93 & 7];
|
|
||||||
joy0_flag[3]=0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(joy0&0x40 && joy0_flag[5]==0 ){
|
|
||||||
//keyboard_matrix[(unsigned char)0x95 >> 4] &= ~bit_values2[(unsigned char)0x95 & 7];
|
|
||||||
joy0_flag[5]=1;
|
|
||||||
}
|
|
||||||
else if(joy0_flag[5]){
|
|
||||||
//keyboard_matrix[(unsigned char)0x95 >> 4] |= bit_values2[(unsigned char)0x95 & 7];
|
|
||||||
joy0_flag[5]=0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(joy0&0x80 && joy0_flag[4]==0 ){
|
|
||||||
//keyboard_matrix[(unsigned char)0x94 >> 4] &= ~bit_values2[(unsigned char)0x94 & 7];
|
|
||||||
joy0_flag[4]=1;
|
|
||||||
}
|
|
||||||
else if(joy0_flag[4]){
|
|
||||||
//keyboard_matrix[(unsigned char)0x94 >> 4] |= bit_values2[(unsigned char)0x94 & 7];
|
|
||||||
joy0_flag[4]=0;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void retro_virtualkb(void)
|
void retro_virtualkb(void)
|
||||||
{
|
{
|
||||||
// VKBD
|
// VKBD
|
||||||
@@ -332,9 +219,8 @@ void retro_virtualkb(void)
|
|||||||
|
|
||||||
if(oldi!=-1)
|
if(oldi!=-1)
|
||||||
{
|
{
|
||||||
//retro_key_up(oldi);
|
vkbd_key(oldi,0);
|
||||||
vkbd_key(oldi,0);
|
oldi=-1;
|
||||||
oldi=-1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if(SHOWKEY==1)
|
if(SHOWKEY==1)
|
||||||
@@ -410,83 +296,69 @@ void retro_virtualkb(void)
|
|||||||
}
|
}
|
||||||
else if(i==-5)
|
else if(i==-5)
|
||||||
{
|
{
|
||||||
//FLIP DSK PORT 1-2
|
|
||||||
NUMDRV=-NUMDRV;
|
|
||||||
oldi=-1;
|
oldi=-1;
|
||||||
}
|
}
|
||||||
else if(i==-6)
|
else if(i==-6)
|
||||||
{
|
{
|
||||||
//Exit
|
//Exit
|
||||||
retro_deinit();
|
//retro_deinit();
|
||||||
oldi=-1;
|
oldi=-1;
|
||||||
exit(0);
|
//SHUTDOWN
|
||||||
|
|
||||||
}
|
}
|
||||||
else if(i==-7)
|
else if(i==-7)
|
||||||
{
|
{
|
||||||
//SNA SAVE
|
|
||||||
// snapshot_save (RPATH);
|
|
||||||
oldi=-1;
|
oldi=-1;
|
||||||
}
|
}
|
||||||
else if(i==-8)
|
else if(i==-8)
|
||||||
{
|
{
|
||||||
//PLAY TAPE
|
|
||||||
// play_tape();
|
|
||||||
oldi=-1;
|
oldi=-1;
|
||||||
}
|
}
|
||||||
|
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
||||||
if(i==0x25 /*i==-10*/) //SHIFT
|
if(i==RETROK_LSHIFT) //SHIFT
|
||||||
{
|
{
|
||||||
// if(SHIFTON == 1)retro_key_up(RETROK_RSHIFT);
|
|
||||||
// else retro_key_down(RETROK_LSHIFT);
|
|
||||||
SHIFTON=-SHIFTON;
|
SHIFTON=-SHIFTON;
|
||||||
|
|
||||||
oldi=-1;
|
oldi=-1;
|
||||||
}
|
}
|
||||||
else if(i==0x27/*i==-11*/) //CTRL
|
else if(RETROK_LCTRL) //CTRL
|
||||||
{
|
{
|
||||||
// if(CTRLON == 1)retro_key_up(RETROK_LCTRL);
|
|
||||||
/// else retro_key_down(RETROK_LCTRL);
|
|
||||||
CTRLON=-CTRLON;
|
CTRLON=-CTRLON;
|
||||||
|
|
||||||
oldi=-1;
|
oldi=-1;
|
||||||
}
|
}
|
||||||
else if(i==-12) //RSTOP
|
else if(i==-12) //RSTOP
|
||||||
{
|
{
|
||||||
// if(RSTOPON == 1)retro_key_up(RETROK_ESCAPE);
|
//(RETROK_ESCAPE);
|
||||||
// else retro_key_down(RETROK_ESCAPE);
|
|
||||||
RSTOPON=-RSTOPON;
|
RSTOPON=-RSTOPON;
|
||||||
|
|
||||||
oldi=-1;
|
oldi=-1;
|
||||||
}
|
}
|
||||||
else if(i==-13) //GUI
|
else if(i==-13) //GUI
|
||||||
{
|
{
|
||||||
// pauseg=1;
|
SHOWKEY=-SHOWKEY;
|
||||||
|
oldi=-1;
|
||||||
SHOWKEY=-SHOWKEY;
|
|
||||||
Screen_SetFullUpdate(0);
|
|
||||||
oldi=-1;
|
|
||||||
}
|
}
|
||||||
else if(i==-14) //JOY PORT TOGGLE
|
else if(i==-14) //JOY PORT TOGGLE
|
||||||
{
|
{
|
||||||
//cur joy toggle
|
|
||||||
//cur_port++;if(cur_port>2)cur_port=1;
|
|
||||||
SHOWKEY=-SHOWKEY;
|
SHOWKEY=-SHOWKEY;
|
||||||
oldi=-1;
|
oldi=-1;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
oldi=i;
|
oldi=i;
|
||||||
//retro_key_down(oldi);
|
vkbd_key(oldi,1);
|
||||||
vkbd_key(oldi,1);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -494,7 +366,6 @@ void retro_virtualkb(void)
|
|||||||
void Screen_SetFullUpdate(int scr)
|
void Screen_SetFullUpdate(int scr)
|
||||||
{
|
{
|
||||||
if(scr==0 ||scr>1)memset(Retro_Screen, 0, sizeof(Retro_Screen));
|
if(scr==0 ||scr>1)memset(Retro_Screen, 0, sizeof(Retro_Screen));
|
||||||
// if(scr>0)memset(bmp,0,sizeof(bmp));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Process_key()
|
void Process_key()
|
||||||
@@ -507,12 +378,12 @@ void Process_key()
|
|||||||
if(memcmp( Key_Sate,old_Key_Sate , sizeof(Key_Sate) ) )
|
if(memcmp( Key_Sate,old_Key_Sate , sizeof(Key_Sate) ) )
|
||||||
for(i=0;i<320;i++)
|
for(i=0;i<320;i++)
|
||||||
if(Key_Sate[i] && Key_Sate[i]!=old_Key_Sate[i] )
|
if(Key_Sate[i] && Key_Sate[i]!=old_Key_Sate[i] )
|
||||||
{
|
{
|
||||||
|
/*
|
||||||
if(i==RETROK_F12){
|
if(i==RETROK_F12){
|
||||||
//play_tape();
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
/*
|
|
||||||
if(i==RETROK_RCTRL){
|
if(i==RETROK_RCTRL){
|
||||||
//CTRLON=-CTRLON;
|
//CTRLON=-CTRLON;
|
||||||
printf("Modifier crtl pressed %d \n",CTRLON);
|
printf("Modifier crtl pressed %d \n",CTRLON);
|
||||||
@@ -523,23 +394,23 @@ void Process_key()
|
|||||||
printf("Modifier shift pressed %d \n",SHIFTON);
|
printf("Modifier shift pressed %d \n",SHIFTON);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
*/
|
|
||||||
if(i==RETROK_LALT){
|
if(i==RETROK_LALT){
|
||||||
//KBMOD=-KBMOD;
|
//KBMOD=-KBMOD;
|
||||||
printf("Modifier alt pressed %d \n",KBMOD);
|
printf("Modifier alt pressed %d \n",KBMOD);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
//printf("press: %d \n",i);
|
//printf("press: %d \n",i);
|
||||||
retro_key_down(i);
|
//retro_key_down(i);
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
else if ( !Key_Sate[i] && Key_Sate[i]!=old_Key_Sate[i] )
|
else if ( !Key_Sate[i] && Key_Sate[i]!=old_Key_Sate[i] )
|
||||||
{
|
{
|
||||||
if(i==RETROK_F12){
|
|
||||||
//kbd_buf_feed("|tape\nrun\"\n^");
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
/*
|
/*
|
||||||
|
if(i==RETROK_F12){
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
if(i==RETROK_RCTRL){
|
if(i==RETROK_RCTRL){
|
||||||
CTRLON=-CTRLON;
|
CTRLON=-CTRLON;
|
||||||
printf("Modifier crtl released %d \n",CTRLON);
|
printf("Modifier crtl released %d \n",CTRLON);
|
||||||
@@ -550,54 +421,21 @@ void Process_key()
|
|||||||
printf("Modifier shift released %d \n",SHIFTON);
|
printf("Modifier shift released %d \n",SHIFTON);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
*/
|
|
||||||
if(i==RETROK_LALT){
|
if(i==RETROK_LALT){
|
||||||
KBMOD=-KBMOD;
|
// KBMOD=-KBMOD;
|
||||||
printf("Modifier alt released %d \n",KBMOD);
|
printf("Modifier alt released %d \n",KBMOD);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
//printf("release: %d \n",i);
|
*/
|
||||||
retro_key_up(i);
|
//printf("release: %d \n",i);
|
||||||
|
//retro_key_up(i);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
memcpy(old_Key_Sate,Key_Sate , sizeof(Key_Sate) );
|
memcpy(old_Key_Sate,Key_Sate , sizeof(Key_Sate) );
|
||||||
|
|
||||||
}
|
}
|
||||||
/*
|
|
||||||
void Print_Statut(void)
|
|
||||||
{
|
|
||||||
DrawFBoxBmp(bmp,0,CROP_HEIGHT,CROP_WIDTH,STAT_YSZ,RGB565(0,0,0));
|
|
||||||
|
|
||||||
Draw_text(bmp,STAT_DECX+40 ,STAT_BASEY,0xffff,0x8080,1,2,40,(SND>0?"SND":""));
|
|
||||||
Draw_text(bmp,STAT_DECX+80 ,STAT_BASEY,0xffff,0x8080,1,2,40,"F:%d",dwFPS);
|
|
||||||
Draw_text(bmp,STAT_DECX+120,STAT_BASEY,0xffff,0x8080,1,2,40,"DSK%c",NUMDRV>0?'A':'B');
|
|
||||||
if(ZOOM>-1)
|
|
||||||
Draw_text(bmp,(384-Mres[ZOOM].x)/2,(272-Mres[ZOOM].y)/2,0xffff,0x8080,1,2,40,"x:%3d y:%3d",Mres[ZOOM].x,Mres[ZOOM].y);
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
In joy mode
|
|
||||||
L3 GUI LOAD
|
|
||||||
R3 GUI SNAP
|
|
||||||
L2 STATUS ON/OFF
|
|
||||||
R2 AUTOLOAD TAPE
|
|
||||||
L CAT
|
|
||||||
R RESET
|
|
||||||
SEL MOUSE/JOY IN GUI
|
|
||||||
STR ENTER/RETURN
|
|
||||||
A FIRE1/VKBD KEY
|
|
||||||
B RUN
|
|
||||||
X FIRE2
|
|
||||||
Y VKBD ON/OFF
|
|
||||||
In Keayboard mode
|
|
||||||
F8 LOAD DSK/TAPE
|
|
||||||
F9 MEM SNAPSHOT LOAD/SAVE
|
|
||||||
F10 MAIN GUI
|
|
||||||
F12 PLAY TAPE
|
|
||||||
*/
|
|
||||||
|
|
||||||
int Retro_PollEvent()
|
int Retro_PollEvent()
|
||||||
{
|
{
|
||||||
@@ -605,9 +443,11 @@ int Retro_PollEvent()
|
|||||||
// INDEX 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
|
// INDEX 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
|
||||||
|
|
||||||
int SAVPAS=PAS;
|
int SAVPAS=PAS;
|
||||||
int i;
|
int i,j;
|
||||||
static int vbt[16]={0x0,0x0,0x0,0x0,0x01,0x02,0x04,0x08,0x80,0x40,0x0,0x0,0x0,0x0,0x0,0x0};
|
static int vbt[2][16]={
|
||||||
//MXjoy[0]=0;
|
{0x0,0x0,0x0,0x0,0x01,0x02,0x04,0x08,0x80,0x40,0x0,0x0,0x0,0x0,0x0,0x0},
|
||||||
|
{0x0,0x0,0x0,0x0,0x01,0x02,0x04,0x08,0x80,0x40,0x0,0x0,0x0,0x0,0x0,0x0},
|
||||||
|
};
|
||||||
|
|
||||||
input_poll_cb();
|
input_poll_cb();
|
||||||
|
|
||||||
@@ -618,128 +458,72 @@ int Retro_PollEvent()
|
|||||||
|
|
||||||
if(SHOWKEY==-1 && pauseg==0)Process_key();
|
if(SHOWKEY==-1 && pauseg==0)Process_key();
|
||||||
|
|
||||||
|
|
||||||
if(pauseg==0){ // if emulation running
|
|
||||||
|
|
||||||
//Joy mode
|
//Joy mode
|
||||||
|
for(j=0;j<2;j++){
|
||||||
|
|
||||||
for(i=4;i<10;i++)
|
for(i=4;i<10;i++)
|
||||||
{
|
{
|
||||||
if( input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, i))
|
if( input_state_cb(j, RETRO_DEVICE_JOYPAD, 0, i))
|
||||||
MXjoy[0] |= vbt[i]; // Joy press
|
MXjoy[j] |= vbt[j][i]; // Joy press
|
||||||
else if( MXjoy[0]&vbt[i])MXjoy[0] &= ~vbt[i]; // Joy press
|
else if( MXjoy[j]&vbt[j][i])MXjoy[j] &= ~vbt[j][i]; // Joy press
|
||||||
}
|
}
|
||||||
|
|
||||||
if(SHOWKEY==-1)retro_joy0_test(MXjoy[0]);
|
}
|
||||||
|
|
||||||
|
if(a5200_joyhack) //hack for robotron right analog act as Joy1
|
||||||
|
{
|
||||||
|
//emulate Joy1 with joy analog right
|
||||||
|
ar[0][0] = (input_state_cb(0, RETRO_DEVICE_ANALOG, RETRO_DEVICE_INDEX_ANALOG_RIGHT, RETRO_DEVICE_ID_ANALOG_X));
|
||||||
|
ar[0][1] = (input_state_cb(0, RETRO_DEVICE_ANALOG, RETRO_DEVICE_INDEX_ANALOG_RIGHT, RETRO_DEVICE_ID_ANALOG_Y));
|
||||||
|
|
||||||
|
int x=ar[0][0];
|
||||||
|
int y=ar[0][1];
|
||||||
|
|
||||||
|
/* Directions */
|
||||||
|
|
||||||
|
if (ar[0][1] <= JOYRANGE_UP_VALUE)
|
||||||
|
MXjoy[1] |= 0x01;
|
||||||
|
else if (ar[0][1] >= JOYRANGE_DOWN_VALUE)
|
||||||
|
MXjoy[1] |= 0x02;
|
||||||
|
|
||||||
|
if (ar[0][0] <= JOYRANGE_LEFT_VALUE)
|
||||||
|
MXjoy[1] |= 0x04;
|
||||||
|
else if (ar[0][0] >= JOYRANGE_RIGHT_VALUE)
|
||||||
|
MXjoy[1] |= 0x08;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
if(atari_devices[0]==RETRO_DEVICE_ATARI_JOYSTICK){
|
if(atari_devices[0]==RETRO_DEVICE_ATARI_JOYSTICK){
|
||||||
//shortcut for joy mode only
|
//shortcut for joy mode only
|
||||||
|
|
||||||
i=1;//show vkbd toggle
|
//Button B Y SLT STA
|
||||||
if ( input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, i) && mbt[i]==0 )
|
// 0 1 2 3
|
||||||
mbt[i]=1;
|
for(i=0;i<4;i++){
|
||||||
else if ( mbt[i]==1 && ! input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, i) )
|
|
||||||
{
|
|
||||||
mbt[i]=0;
|
|
||||||
SHOWKEY=-SHOWKEY;
|
|
||||||
}
|
|
||||||
|
|
||||||
i=3;// START
|
if ( input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, i) && mbt[i]==0 )
|
||||||
if ( input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, i) && mbt[i]==0 )
|
mbt[i]=1;
|
||||||
mbt[i]=1;
|
else if ( mbt[i]==1 && ! input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, i) )
|
||||||
else if ( mbt[i]==1 && ! input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, i) )
|
{
|
||||||
{
|
mbt[i]=0;
|
||||||
mbt[i]=0;
|
if(i==2)MOUSE_EMULATED=-MOUSE_EMULATED;
|
||||||
// kbd_buf_feed("\n");
|
}
|
||||||
}
|
}
|
||||||
|
//Button L R L2 R2 L3 R3
|
||||||
|
// 10 11 12 13 14 15
|
||||||
|
for(i=10;i<16;i++){
|
||||||
|
|
||||||
/*
|
if ( input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, i) && mbt[i]==0 )
|
||||||
i=10;//type DEL / ZOOM
|
mbt[i]=1;
|
||||||
if ( input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, i) && mbt[i]==0 )
|
else if ( mbt[i]==1 && ! input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, i) )
|
||||||
mbt[i]=1;
|
{
|
||||||
else if ( mbt[i]==1 && ! input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, i) ){
|
mbt[i]=0;
|
||||||
mbt[i]=0;
|
if(i==14)SHOWKEY=-SHOWKEY;
|
||||||
ZOOM++;if(ZOOM>4)ZOOM=-1;
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}//if atari_devices=joy
|
||||||
*/
|
|
||||||
|
|
||||||
i=0;//type RUN"
|
|
||||||
if ( input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, i) && mbt[i]==0 )
|
|
||||||
mbt[i]=1;
|
|
||||||
else if ( mbt[i]==1 && ! input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, i) ){
|
|
||||||
mbt[i]=0;
|
|
||||||
// kbd_buf_feed("RUN\"");
|
|
||||||
}
|
|
||||||
|
|
||||||
i=10;//Type CAT\n
|
|
||||||
if ( input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, i) && mbt[i]==0 )
|
|
||||||
mbt[i]=1;
|
|
||||||
else if ( mbt[i]==1 && ! input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, i) ){
|
|
||||||
mbt[i]=0;
|
|
||||||
// kbd_buf_feed("CAT\n");
|
|
||||||
//Screen_SetFullUpdate();
|
|
||||||
}
|
|
||||||
|
|
||||||
i=12;//show/hide statut
|
|
||||||
if ( input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, i) && mbt[i]==0 )
|
|
||||||
mbt[i]=1;
|
|
||||||
else if ( mbt[i]==1 && ! input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, i) ){
|
|
||||||
mbt[i]=0;
|
|
||||||
STATUTON=-STATUTON;
|
|
||||||
// Screen_SetFullUpdate();
|
|
||||||
}
|
|
||||||
|
|
||||||
i=13;//auto load tape
|
|
||||||
if ( input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, i) && mbt[i]==0 )
|
|
||||||
mbt[i]=1;
|
|
||||||
else if ( mbt[i]==1 && ! input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, i) ){
|
|
||||||
mbt[i]=0;
|
|
||||||
// kbd_buf_feed("|tape\nrun\"\n^");
|
|
||||||
}
|
|
||||||
|
|
||||||
i=11;//reset
|
|
||||||
if ( input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, i) && mbt[i]==0 )
|
|
||||||
mbt[i]=1;
|
|
||||||
else if ( mbt[i]==1 && ! input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, i) ){
|
|
||||||
mbt[i]=0;
|
|
||||||
//emu_reset();
|
|
||||||
}
|
|
||||||
|
|
||||||
i=2;//mouse/joy toggle
|
|
||||||
if ( input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, i) && mbt[i]==0 )
|
|
||||||
mbt[i]=1;
|
|
||||||
else if ( mbt[i]==1 && ! input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, i) ){
|
|
||||||
mbt[i]=0;
|
|
||||||
MOUSE_EMULATED=-MOUSE_EMULATED;
|
|
||||||
}
|
|
||||||
|
|
||||||
// L3 -> gui load
|
|
||||||
if (input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, 14)){
|
|
||||||
|
|
||||||
}
|
|
||||||
// R3 -> gui snapshot
|
|
||||||
if (input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, 15)){
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
}//if atari_devices=joy
|
|
||||||
|
|
||||||
|
|
||||||
}// if pauseg=0
|
|
||||||
else{
|
|
||||||
// if in gui
|
|
||||||
|
|
||||||
i=2;//mouse/joy toggle
|
|
||||||
if ( input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, i) && mbt[i]==0 )
|
|
||||||
mbt[i]=1;
|
|
||||||
else if ( mbt[i]==1 && ! input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, i) ){
|
|
||||||
mbt[i]=0;
|
|
||||||
MOUSE_EMULATED=-MOUSE_EMULATED;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
if(MOUSE_EMULATED==1){
|
if(MOUSE_EMULATED==1){
|
||||||
|
|
||||||
@@ -757,10 +541,10 @@ else{
|
|||||||
slowdown=1;
|
slowdown=1;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
//printf("-----------------%d \n",pauseg);
|
//printf("-----------------%d \n",pauseg);
|
||||||
mouse_wu = input_state_cb(0, RETRO_DEVICE_MOUSE, 0, RETRO_DEVICE_ID_MOUSE_WHEELUP);
|
mouse_wu = input_state_cb(0, RETRO_DEVICE_MOUSE, 0, RETRO_DEVICE_ID_MOUSE_WHEELUP);
|
||||||
mouse_wd = input_state_cb(0, RETRO_DEVICE_MOUSE, 0, RETRO_DEVICE_ID_MOUSE_WHEELDOWN);
|
mouse_wd = input_state_cb(0, RETRO_DEVICE_MOUSE, 0, RETRO_DEVICE_ID_MOUSE_WHEELDOWN);
|
||||||
if(mouse_wu || mouse_wd)printf("-----------------MOUSE UP:%d DOWN:%d\n",mouse_wu, mouse_wd);
|
//if(mouse_wu || mouse_wd)printf("-----------------MOUSE UP:%d DOWN:%d\n",mouse_wu, mouse_wd);
|
||||||
mouse_x = input_state_cb(0, RETRO_DEVICE_MOUSE, 0, RETRO_DEVICE_ID_MOUSE_X);
|
mouse_x = input_state_cb(0, RETRO_DEVICE_MOUSE, 0, RETRO_DEVICE_ID_MOUSE_X);
|
||||||
mouse_y = input_state_cb(0, RETRO_DEVICE_MOUSE, 0, RETRO_DEVICE_ID_MOUSE_Y);
|
mouse_y = input_state_cb(0, RETRO_DEVICE_MOUSE, 0, RETRO_DEVICE_ID_MOUSE_Y);
|
||||||
mouse_l = input_state_cb(0, RETRO_DEVICE_MOUSE, 0, RETRO_DEVICE_ID_MOUSE_LEFT);
|
mouse_l = input_state_cb(0, RETRO_DEVICE_MOUSE, 0, RETRO_DEVICE_ID_MOUSE_LEFT);
|
||||||
@@ -773,14 +557,14 @@ if(mouse_wu || mouse_wd)printf("-----------------MOUSE UP:%d DOWN:%d\n",mouse_wu
|
|||||||
|
|
||||||
mmbL=1;
|
mmbL=1;
|
||||||
pushi=1;
|
pushi=1;
|
||||||
touch=1;
|
touch=1;
|
||||||
|
|
||||||
}
|
}
|
||||||
else if(mmbL==1 && !mouse_l) {
|
else if(mmbL==1 && !mouse_l) {
|
||||||
|
|
||||||
mmbL=0;
|
mmbL=0;
|
||||||
pushi=0;
|
pushi=0;
|
||||||
touch=-1;
|
touch=-1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(mmbR==0 && mouse_r){
|
if(mmbR==0 && mouse_r){
|
||||||
@@ -790,14 +574,6 @@ if(mouse_wu || mouse_wd)printf("-----------------MOUSE UP:%d DOWN:%d\n",mouse_wu
|
|||||||
mmbR=0;
|
mmbR=0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(pauseg==0 && c64mouse_enable){
|
|
||||||
/*
|
|
||||||
mouse_move((int)mouse_x, (int)mouse_y);
|
|
||||||
mouse_button(0,mmbL);
|
|
||||||
mouse_button(1,mmbR);
|
|
||||||
*/
|
|
||||||
}
|
|
||||||
|
|
||||||
gmx+=mouse_x;
|
gmx+=mouse_x;
|
||||||
gmy+=mouse_y;
|
gmy+=mouse_y;
|
||||||
if(gmx<0)gmx=0;
|
if(gmx<0)gmx=0;
|
||||||
@@ -806,7 +582,7 @@ if(pauseg==0 && c64mouse_enable){
|
|||||||
if(gmy>retroh-1)gmy=retroh-1;
|
if(gmy>retroh-1)gmy=retroh-1;
|
||||||
|
|
||||||
|
|
||||||
if(SHOWKEY && pauseg==0)retro_virtualkb();
|
if(SHOWKEY==1 && pauseg==0)retro_virtualkb();
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
|
|||||||
@@ -17,6 +17,7 @@ int retroh=300;
|
|||||||
unsigned atari_devices[ 2 ];
|
unsigned atari_devices[ 2 ];
|
||||||
|
|
||||||
int autorun5200=0;
|
int autorun5200=0;
|
||||||
|
int a5200_joyhack=0;
|
||||||
|
|
||||||
int RETROJOY=0,RETROPT0=0,RETROSTATUS=0,RETRODRVTYPE=0;
|
int RETROJOY=0,RETROPT0=0,RETROSTATUS=0,RETRODRVTYPE=0;
|
||||||
int retrojoy_init=0,retro_ui_finalized=0;
|
int retrojoy_init=0,retro_ui_finalized=0;
|
||||||
@@ -80,11 +81,16 @@ void retro_set_environment(retro_environment_t cb)
|
|||||||
"atari800_opt1",
|
"atari800_opt1",
|
||||||
"Autodetect A5200 CartType; disabled|enabled" ,
|
"Autodetect A5200 CartType; disabled|enabled" ,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"atari800_opt2",
|
||||||
|
"Joy hack A5200 for robotron; disabled|enabled" ,
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"atari800_resolution",
|
"atari800_resolution",
|
||||||
"Internal resolution; 336x240|320x240|384x240|384x272|384x288|400x300",
|
"Internal resolution; 336x240|320x240|384x240|384x272|384x288|400x300",
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
||||||
{ NULL, NULL },
|
{ NULL, NULL },
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -105,6 +111,15 @@ static void update_variables(void)
|
|||||||
autorun5200 = 1;
|
autorun5200 = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var.key = "atari800_opt2";
|
||||||
|
var.value = NULL;
|
||||||
|
|
||||||
|
if (environ_cb(RETRO_ENVIRONMENT_GET_VARIABLE, &var) && var.value)
|
||||||
|
{
|
||||||
|
if (strcmp(var.value, "enabled") == 0)
|
||||||
|
a5200_joyhack = 1;
|
||||||
|
}
|
||||||
|
|
||||||
var.key = "atari800_resolution";
|
var.key = "atari800_resolution";
|
||||||
var.value = NULL;
|
var.value = NULL;
|
||||||
|
|
||||||
|
|||||||
+3
-1
@@ -46,7 +46,7 @@ extern int UI_is_active;
|
|||||||
|
|
||||||
static int swap_joysticks = FALSE;
|
static int swap_joysticks = FALSE;
|
||||||
int PLATFORM_kbd_joy_0_enabled = TRUE; /* enabled by default, doesn't hurt */
|
int PLATFORM_kbd_joy_0_enabled = TRUE; /* enabled by default, doesn't hurt */
|
||||||
int PLATFORM_kbd_joy_1_enabled = FALSE; /* disabled, would steal normal keys */
|
int PLATFORM_kbd_joy_1_enabled = TRUE;//FALSE; /* disabled, would steal normal keys */
|
||||||
extern unsigned char MXjoy[2]; // joy
|
extern unsigned char MXjoy[2]; // joy
|
||||||
extern int mbt[16];
|
extern int mbt[16];
|
||||||
extern int retro_sound_finalized;
|
extern int retro_sound_finalized;
|
||||||
@@ -255,6 +255,7 @@ static void get_platform_PORT(unsigned char *s0, unsigned char *s1)
|
|||||||
stick0 &= INPUT_STICK_BACK;
|
stick0 &= INPUT_STICK_BACK;
|
||||||
}
|
}
|
||||||
if (PLATFORM_kbd_joy_1_enabled) {
|
if (PLATFORM_kbd_joy_1_enabled) {
|
||||||
|
|
||||||
if (MXjoy[1]&0x04)
|
if (MXjoy[1]&0x04)
|
||||||
stick1 &= INPUT_STICK_LEFT;
|
stick1 &= INPUT_STICK_LEFT;
|
||||||
if (MXjoy[1]&0x08)
|
if (MXjoy[1]&0x08)
|
||||||
@@ -263,6 +264,7 @@ static void get_platform_PORT(unsigned char *s0, unsigned char *s1)
|
|||||||
stick1 &= INPUT_STICK_FORWARD;
|
stick1 &= INPUT_STICK_FORWARD;
|
||||||
if (MXjoy[1]&0x02)
|
if (MXjoy[1]&0x02)
|
||||||
stick1 &= INPUT_STICK_BACK;
|
stick1 &= INPUT_STICK_BACK;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (swap_joysticks) {
|
if (swap_joysticks) {
|
||||||
|
|||||||
Reference in New Issue
Block a user