Merge branch 'master' of https://github.com/TASVideos/fceux
This commit is contained in:
commit
f2eb89c629
|
@ -142,6 +142,7 @@ void FCEUI_SetRenderedLines(int ntscf, int ntscl, int palf, int pall);
|
||||||
|
|
||||||
//Sets the base directory(save states, snapshots, etc. are saved in directories below this directory.
|
//Sets the base directory(save states, snapshots, etc. are saved in directories below this directory.
|
||||||
void FCEUI_SetBaseDirectory(std::string const & dir);
|
void FCEUI_SetBaseDirectory(std::string const & dir);
|
||||||
|
const char *FCEUI_GetBaseDirectory(void);
|
||||||
|
|
||||||
bool FCEUI_GetUserPaletteAvail(void);
|
bool FCEUI_GetUserPaletteAvail(void);
|
||||||
void FCEUI_SetUserPalette(uint8 *pal, int nEntries);
|
void FCEUI_SetUserPalette(uint8 *pal, int nEntries);
|
||||||
|
|
|
@ -78,6 +78,8 @@ consoleWin_t::~consoleWin_t(void)
|
||||||
{
|
{
|
||||||
nes_shm->runEmulator = 0;
|
nes_shm->runEmulator = 0;
|
||||||
|
|
||||||
|
gameTimer->stop();
|
||||||
|
|
||||||
if ( gamePadConfWin != NULL )
|
if ( gamePadConfWin != NULL )
|
||||||
{
|
{
|
||||||
gamePadConfWin->closeWindow();
|
gamePadConfWin->closeWindow();
|
||||||
|
|
|
@ -1,35 +1,52 @@
|
||||||
// GamePadConf.cpp
|
// GamePadConf.cpp
|
||||||
//
|
//
|
||||||
|
#include <QDir>
|
||||||
|
#include <QInputDialog>
|
||||||
|
|
||||||
#include "Qt/GamePadConf.h"
|
#include "Qt/GamePadConf.h"
|
||||||
#include "Qt/main.h"
|
#include "Qt/main.h"
|
||||||
|
#include "Qt/dface.h"
|
||||||
#include "Qt/input.h"
|
#include "Qt/input.h"
|
||||||
#include "Qt/config.h"
|
#include "Qt/config.h"
|
||||||
#include "Qt/keyscan.h"
|
#include "Qt/keyscan.h"
|
||||||
|
#include "Qt/sdl-joystick.h"
|
||||||
#include "Qt/fceuWrapper.h"
|
#include "Qt/fceuWrapper.h"
|
||||||
|
|
||||||
//----------------------------------------------------
|
//----------------------------------------------------
|
||||||
GamePadConfDialog_t::GamePadConfDialog_t(QWidget *parent)
|
GamePadConfDialog_t::GamePadConfDialog_t(QWidget *parent)
|
||||||
: QDialog( parent )
|
: QDialog( parent )
|
||||||
{
|
{
|
||||||
QHBoxLayout *hbox1, *hbox2;
|
QHBoxLayout *hbox, *hbox1, *hbox2, *hbox3, *hbox4;
|
||||||
|
QVBoxLayout *vbox;
|
||||||
QGridLayout *grid;
|
QGridLayout *grid;
|
||||||
QCheckBox *efs_chkbox, *udlr_chkbox;
|
QCheckBox *efs_chkbox, *udlr_chkbox;
|
||||||
QGroupBox *frame;
|
QGroupBox *frame1, *frame2;
|
||||||
QPushButton *loadDefaultButton;
|
QLabel *label;
|
||||||
|
QPushButton *newProfileButton;
|
||||||
|
QPushButton *saveProfileButton;
|
||||||
|
QPushButton *applyProfileButton;
|
||||||
|
QPushButton *removeProfileButton;
|
||||||
QPushButton *clearAllButton;
|
QPushButton *clearAllButton;
|
||||||
QPushButton *closebutton;
|
QPushButton *closebutton;
|
||||||
QPushButton *clearButton[GAMEPAD_NUM_BUTTONS];
|
QPushButton *clearButton[GAMEPAD_NUM_BUTTONS];
|
||||||
|
|
||||||
|
InitJoysticks();
|
||||||
|
|
||||||
portNum = 0;
|
portNum = 0;
|
||||||
configNo = 0;
|
|
||||||
buttonConfigStatus = 1;
|
buttonConfigStatus = 1;
|
||||||
|
|
||||||
|
inputTimer = new QTimer( this );
|
||||||
|
|
||||||
|
connect( inputTimer, &QTimer::timeout, this, &GamePadConfDialog_t::updatePeriodic );
|
||||||
|
|
||||||
setWindowTitle( tr("GamePad Config") );
|
setWindowTitle( tr("GamePad Config") );
|
||||||
|
|
||||||
hbox1 = new QHBoxLayout();
|
hbox1 = new QHBoxLayout();
|
||||||
hbox2 = new QHBoxLayout();
|
hbox2 = new QHBoxLayout();
|
||||||
|
hbox3 = new QHBoxLayout();
|
||||||
|
hbox4 = new QHBoxLayout();
|
||||||
|
|
||||||
QLabel *label = new QLabel(tr("Port:"));
|
label = new QLabel(tr("Console Port:"));
|
||||||
portSel = new QComboBox();
|
portSel = new QComboBox();
|
||||||
hbox1->addWidget( label );
|
hbox1->addWidget( label );
|
||||||
hbox1->addWidget( portSel );
|
hbox1->addWidget( portSel );
|
||||||
|
@ -39,6 +56,85 @@ GamePadConfDialog_t::GamePadConfDialog_t(QWidget *parent)
|
||||||
portSel->addItem( tr("3"), 2 );
|
portSel->addItem( tr("3"), 2 );
|
||||||
portSel->addItem( tr("4"), 3 );
|
portSel->addItem( tr("4"), 3 );
|
||||||
|
|
||||||
|
label = new QLabel(tr("Device:"));
|
||||||
|
devSel = new QComboBox();
|
||||||
|
hbox2->addWidget( label );
|
||||||
|
hbox2->addWidget( devSel );
|
||||||
|
|
||||||
|
devSel->addItem( tr("Keyboard"), -1 );
|
||||||
|
|
||||||
|
for (int i=0; i<MAX_JOYSTICKS; i++)
|
||||||
|
{
|
||||||
|
jsDev_t *js = getJoystickDevice( i );
|
||||||
|
|
||||||
|
if ( js != NULL )
|
||||||
|
{
|
||||||
|
if ( js->isConnected() )
|
||||||
|
{
|
||||||
|
char stmp[128];
|
||||||
|
sprintf( stmp, "%i: %s", i, js->getName() );
|
||||||
|
devSel->addItem( tr(stmp), i );
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (int i=0; i<devSel->count(); i++)
|
||||||
|
{
|
||||||
|
if ( devSel->itemData(i).toInt() == GamePad[portNum].getDeviceIndex() )
|
||||||
|
{
|
||||||
|
devSel->setCurrentIndex( i );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
label = new QLabel(tr("GUID:"));
|
||||||
|
guidLbl = new QLabel();
|
||||||
|
|
||||||
|
hbox3->addWidget( label );
|
||||||
|
hbox3->addWidget( guidLbl );
|
||||||
|
|
||||||
|
guidLbl->setText( GamePad[portNum].getGUID() );
|
||||||
|
|
||||||
|
frame1 = new QGroupBox(tr("Mapping Profile:"));
|
||||||
|
//grid = new QGridLayout();
|
||||||
|
vbox = new QVBoxLayout();
|
||||||
|
|
||||||
|
//frame1->setLayout( grid );
|
||||||
|
frame1->setLayout( vbox );
|
||||||
|
|
||||||
|
hbox = new QHBoxLayout();
|
||||||
|
vbox->addLayout( hbox );
|
||||||
|
|
||||||
|
mapSel = new QComboBox();
|
||||||
|
hbox->addWidget( mapSel );
|
||||||
|
|
||||||
|
mapSel->setWhatsThis( tr("Combo box for selection of a saved button mapping profile for the selected device"));
|
||||||
|
mapSel->addItem( tr("default"), 0 );
|
||||||
|
|
||||||
|
hbox = new QHBoxLayout();
|
||||||
|
vbox->addLayout( hbox );
|
||||||
|
|
||||||
|
applyProfileButton = new QPushButton( tr("Load") );
|
||||||
|
applyProfileButton->setWhatsThis(tr("Sets Current Active Map to the Selected Profile"));
|
||||||
|
hbox->addWidget( applyProfileButton );
|
||||||
|
|
||||||
|
saveProfileButton = new QPushButton( tr("Save") );
|
||||||
|
saveProfileButton->setWhatsThis(tr("Stores Current Active Map to the Selected Profile"));
|
||||||
|
hbox->addWidget( saveProfileButton );
|
||||||
|
|
||||||
|
hbox = new QHBoxLayout();
|
||||||
|
vbox->addLayout( hbox );
|
||||||
|
|
||||||
|
newProfileButton = new QPushButton( tr("New") );
|
||||||
|
newProfileButton->setWhatsThis(tr("Create a New Map Profile"));
|
||||||
|
hbox->addWidget( newProfileButton );
|
||||||
|
|
||||||
|
removeProfileButton = new QPushButton( tr("Delete") );
|
||||||
|
removeProfileButton->setWhatsThis(tr("Deletes the Selected Map Profile"));
|
||||||
|
hbox->addWidget( removeProfileButton );
|
||||||
|
|
||||||
|
mapMsg = new QLabel();
|
||||||
|
vbox->addWidget(mapMsg);
|
||||||
|
|
||||||
efs_chkbox = new QCheckBox( tr("Enable Four Score") );
|
efs_chkbox = new QCheckBox( tr("Enable Four Score") );
|
||||||
udlr_chkbox = new QCheckBox( tr("Allow Up+Down/Left+Right") );
|
udlr_chkbox = new QCheckBox( tr("Allow Up+Down/Left+Right") );
|
||||||
|
|
||||||
|
@ -50,13 +146,12 @@ GamePadConfDialog_t::GamePadConfDialog_t(QWidget *parent)
|
||||||
g_config->getOption("SDL.Input.EnableOppositeDirectionals", &opposite_dirs);
|
g_config->getOption("SDL.Input.EnableOppositeDirectionals", &opposite_dirs);
|
||||||
udlr_chkbox->setChecked( opposite_dirs );
|
udlr_chkbox->setChecked( opposite_dirs );
|
||||||
|
|
||||||
frame = new QGroupBox(tr("Buttons:"));
|
frame2 = new QGroupBox(tr("Current Active Button Mappings:"));
|
||||||
grid = new QGridLayout();
|
grid = new QGridLayout();
|
||||||
|
|
||||||
grid-> setHorizontalSpacing(50);
|
grid-> setHorizontalSpacing(50);
|
||||||
|
|
||||||
//frame->setFrameStyle( QFrame::Box );
|
frame2->setLayout( grid );
|
||||||
frame->setLayout( grid );
|
|
||||||
|
|
||||||
for (int i=0; i<GAMEPAD_NUM_BUTTONS; i++)
|
for (int i=0; i<GAMEPAD_NUM_BUTTONS; i++)
|
||||||
{
|
{
|
||||||
|
@ -71,23 +166,25 @@ GamePadConfDialog_t::GamePadConfDialog_t(QWidget *parent)
|
||||||
|
|
||||||
buttonName = new QLabel(tr(text));
|
buttonName = new QLabel(tr(text));
|
||||||
keyName[i] = new QLabel();
|
keyName[i] = new QLabel();
|
||||||
|
keyState[i] = new QLabel( tr("F") );
|
||||||
|
label = new QLabel( tr("State:") );
|
||||||
button[i] = new GamePadConfigButton_t(i);
|
button[i] = new GamePadConfigButton_t(i);
|
||||||
clearButton[i] = new QPushButton( tr("Clear") );
|
clearButton[i] = new QPushButton( tr("Clear") );
|
||||||
|
|
||||||
grid->addWidget( buttonName , i, 0, Qt::AlignCenter );
|
grid->addWidget( buttonName , i, 0, Qt::AlignCenter );
|
||||||
grid->addWidget( keyName[i] , i, 1, Qt::AlignCenter );
|
grid->addWidget( keyName[i] , i, 1, Qt::AlignCenter );
|
||||||
grid->addWidget( button[i] , i, 2, Qt::AlignCenter );
|
grid->addWidget( label , i, 2, Qt::AlignCenter );
|
||||||
grid->addWidget( clearButton[i], i, 3, Qt::AlignCenter );
|
grid->addWidget( keyState[i] , i, 3, Qt::AlignCenter );
|
||||||
|
grid->addWidget( button[i] , i, 4, Qt::AlignCenter );
|
||||||
|
grid->addWidget( clearButton[i], i, 5, Qt::AlignCenter );
|
||||||
}
|
}
|
||||||
updateCntrlrDpy();
|
updateCntrlrDpy();
|
||||||
|
|
||||||
loadDefaultButton = new QPushButton(tr("Load Defaults"));
|
|
||||||
clearAllButton = new QPushButton(tr("Clear All"));
|
clearAllButton = new QPushButton(tr("Clear All"));
|
||||||
closebutton = new QPushButton(tr("Close"));
|
closebutton = new QPushButton(tr("Close"));
|
||||||
|
|
||||||
hbox2->addWidget( loadDefaultButton );
|
hbox4->addWidget( clearAllButton );
|
||||||
hbox2->addWidget( clearAllButton );
|
hbox4->addWidget( closebutton );
|
||||||
hbox2->addWidget( closebutton );
|
|
||||||
|
|
||||||
connect(button[0], SIGNAL(clicked()), this, SLOT(changeButton0(void)) );
|
connect(button[0], SIGNAL(clicked()), this, SLOT(changeButton0(void)) );
|
||||||
connect(button[1], SIGNAL(clicked()), this, SLOT(changeButton1(void)) );
|
connect(button[1], SIGNAL(clicked()), this, SLOT(changeButton1(void)) );
|
||||||
|
@ -111,29 +208,41 @@ GamePadConfDialog_t::GamePadConfDialog_t(QWidget *parent)
|
||||||
connect(clearButton[8], SIGNAL(clicked()), this, SLOT(clearButton8(void)) );
|
connect(clearButton[8], SIGNAL(clicked()), this, SLOT(clearButton8(void)) );
|
||||||
connect(clearButton[9], SIGNAL(clicked()), this, SLOT(clearButton9(void)) );
|
connect(clearButton[9], SIGNAL(clicked()), this, SLOT(clearButton9(void)) );
|
||||||
|
|
||||||
connect(loadDefaultButton, SIGNAL(clicked()), this, SLOT(loadDefaults(void)) );
|
connect(newProfileButton , SIGNAL(clicked()), this, SLOT(newProfileCallback(void)) );
|
||||||
|
connect(applyProfileButton , SIGNAL(clicked()), this, SLOT(loadProfileCallback(void)) );
|
||||||
|
connect(saveProfileButton , SIGNAL(clicked()), this, SLOT(saveProfileCallback(void)) );
|
||||||
|
connect(removeProfileButton, SIGNAL(clicked()), this, SLOT(deleteProfileCallback(void)) );
|
||||||
|
|
||||||
connect(clearAllButton , SIGNAL(clicked()), this, SLOT(clearAllCallback(void)) );
|
connect(clearAllButton , SIGNAL(clicked()), this, SLOT(clearAllCallback(void)) );
|
||||||
connect(closebutton , SIGNAL(clicked()), this, SLOT(closeWindow(void)) );
|
connect(closebutton , SIGNAL(clicked()), this, SLOT(closeWindow(void)) );
|
||||||
|
|
||||||
connect(portSel , SIGNAL(activated(int)), this, SLOT(controllerSelect(int)) );
|
connect(portSel , SIGNAL(activated(int)), this, SLOT(portSelect(int)) );
|
||||||
|
connect(devSel , SIGNAL(activated(int)), this, SLOT(deviceSelect(int)) );
|
||||||
connect(efs_chkbox , SIGNAL(stateChanged(int)), this, SLOT(ena4score(int)) );
|
connect(efs_chkbox , SIGNAL(stateChanged(int)), this, SLOT(ena4score(int)) );
|
||||||
connect(udlr_chkbox, SIGNAL(stateChanged(int)), this, SLOT(oppDirEna(int)) );
|
connect(udlr_chkbox, SIGNAL(stateChanged(int)), this, SLOT(oppDirEna(int)) );
|
||||||
|
|
||||||
QVBoxLayout *mainLayout = new QVBoxLayout();
|
QVBoxLayout *mainLayout = new QVBoxLayout();
|
||||||
|
|
||||||
mainLayout->addLayout( hbox1 );
|
mainLayout->addLayout( hbox1 );
|
||||||
|
mainLayout->addLayout( hbox2 );
|
||||||
|
mainLayout->addLayout( hbox3 );
|
||||||
|
mainLayout->addWidget( frame1 );
|
||||||
mainLayout->addWidget( efs_chkbox );
|
mainLayout->addWidget( efs_chkbox );
|
||||||
mainLayout->addWidget( udlr_chkbox );
|
mainLayout->addWidget( udlr_chkbox );
|
||||||
mainLayout->addWidget( frame );
|
mainLayout->addWidget( frame2 );
|
||||||
mainLayout->addLayout( hbox2 );
|
mainLayout->addLayout( hbox4 );
|
||||||
|
|
||||||
setLayout( mainLayout );
|
setLayout( mainLayout );
|
||||||
|
|
||||||
|
inputTimer->start( 33 ); // 30hz
|
||||||
|
|
||||||
|
loadMapList();
|
||||||
}
|
}
|
||||||
|
|
||||||
//----------------------------------------------------
|
//----------------------------------------------------
|
||||||
GamePadConfDialog_t::~GamePadConfDialog_t(void)
|
GamePadConfDialog_t::~GamePadConfDialog_t(void)
|
||||||
{
|
{
|
||||||
|
inputTimer->stop();
|
||||||
buttonConfigStatus = 0;
|
buttonConfigStatus = 0;
|
||||||
}
|
}
|
||||||
void GamePadConfDialog_t::keyPressEvent(QKeyEvent *event)
|
void GamePadConfDialog_t::keyPressEvent(QKeyEvent *event)
|
||||||
|
@ -148,30 +257,139 @@ void GamePadConfDialog_t::keyReleaseEvent(QKeyEvent *event)
|
||||||
pushKeyEvent( event, 0 );
|
pushKeyEvent( event, 0 );
|
||||||
}
|
}
|
||||||
//----------------------------------------------------
|
//----------------------------------------------------
|
||||||
|
void GamePadConfDialog_t::loadMapList(void)
|
||||||
|
{
|
||||||
|
QDir dir;
|
||||||
|
QStringList filters, fileList;
|
||||||
|
const char *baseDir = FCEUI_GetBaseDirectory();
|
||||||
|
const char *guid;
|
||||||
|
std::string path;
|
||||||
|
std::string prefix, mapName;
|
||||||
|
int index, devIdx;
|
||||||
|
jsDev_t *js;
|
||||||
|
size_t n=0;
|
||||||
|
char stmp[256];
|
||||||
|
|
||||||
|
index = devSel->currentIndex();
|
||||||
|
devIdx = devSel->itemData(index).toInt();
|
||||||
|
|
||||||
|
if ( devIdx < 0 )
|
||||||
|
{
|
||||||
|
guid = "keyboard";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
js = getJoystickDevice( devIdx );
|
||||||
|
|
||||||
|
guid = js->getGUID();
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( guid == NULL )
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
path = std::string(baseDir) + "/input/" + std::string(guid);
|
||||||
|
|
||||||
|
dir.setPath( QString::fromStdString(path) );
|
||||||
|
|
||||||
|
filters << "*.txt";
|
||||||
|
dir.setNameFilters(filters);
|
||||||
|
|
||||||
|
fileList = dir.entryList( filters, QDir::Files, QDir::NoSort );
|
||||||
|
|
||||||
|
sprintf( stmp, "SDL.Input.GamePad.%u.", portNum );
|
||||||
|
prefix = stmp;
|
||||||
|
|
||||||
|
g_config->getOption(prefix + "Profile", &mapName );
|
||||||
|
|
||||||
|
mapSel->clear();
|
||||||
|
mapSel->addItem( tr("default"), 0 ); n=1;
|
||||||
|
|
||||||
|
for (size_t i=0; i < fileList.size(); i++)
|
||||||
|
{
|
||||||
|
size_t suffixIdx;
|
||||||
|
std::string fileName = fileList[i].toStdString();
|
||||||
|
|
||||||
|
suffixIdx = fileName.find_last_of('.');
|
||||||
|
|
||||||
|
fileName.erase( suffixIdx );
|
||||||
|
|
||||||
|
//printf("File: %s \n", fileName.c_str() );
|
||||||
|
//
|
||||||
|
|
||||||
|
if ( fileName.compare("default") == 0 ) continue;
|
||||||
|
|
||||||
|
mapSel->addItem( tr(fileName.c_str()), (int)i+1 );
|
||||||
|
|
||||||
|
if ( mapName.compare( fileName ) == 0 )
|
||||||
|
{
|
||||||
|
mapSel->setCurrentIndex(n);
|
||||||
|
}
|
||||||
|
n++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//----------------------------------------------------
|
||||||
void GamePadConfDialog_t::updateCntrlrDpy(void)
|
void GamePadConfDialog_t::updateCntrlrDpy(void)
|
||||||
{
|
{
|
||||||
char keyNameStr[128];
|
char keyNameStr[128];
|
||||||
|
|
||||||
for (int i=0; i<GAMEPAD_NUM_BUTTONS; i++)
|
for (int i=0; i<GAMEPAD_NUM_BUTTONS; i++)
|
||||||
{
|
{
|
||||||
if (GamePadConfig[portNum][i].ButtType[configNo] == BUTTC_KEYBOARD)
|
if (GamePad[portNum].bmap[i].ButtType == BUTTC_KEYBOARD)
|
||||||
{
|
{
|
||||||
snprintf( keyNameStr, sizeof (keyNameStr), "%s",
|
snprintf( keyNameStr, sizeof (keyNameStr), "%s",
|
||||||
SDL_GetKeyName (GamePadConfig[portNum][i].ButtonNum[configNo]));
|
SDL_GetKeyName (GamePad[portNum].bmap[i].ButtonNum));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
strcpy( keyNameStr, ButtonName( &GamePadConfig[portNum][i], configNo ) );
|
strcpy( keyNameStr, ButtonName( &GamePad[portNum].bmap[i] ) );
|
||||||
}
|
}
|
||||||
keyName[i]->setText( tr(keyNameStr) );
|
keyName[i]->setText( tr(keyNameStr) );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//----------------------------------------------------
|
//----------------------------------------------------
|
||||||
void GamePadConfDialog_t::controllerSelect(int index)
|
void GamePadConfDialog_t::portSelect(int index)
|
||||||
{
|
{
|
||||||
//printf("Port Number:%i \n", index);
|
//printf("Port Number:%i \n", index);
|
||||||
portNum = index;
|
portNum = index;
|
||||||
updateCntrlrDpy();
|
updateCntrlrDpy();
|
||||||
|
|
||||||
|
for (int i=0; i<devSel->count(); i++)
|
||||||
|
{
|
||||||
|
if ( devSel->itemData(i).toInt() == GamePad[portNum].getDeviceIndex() )
|
||||||
|
{
|
||||||
|
devSel->setCurrentIndex( i );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
guidLbl->setText( GamePad[portNum].getGUID() );
|
||||||
|
|
||||||
|
loadMapList();
|
||||||
|
}
|
||||||
|
//----------------------------------------------------
|
||||||
|
void GamePadConfDialog_t::deviceSelect(int index)
|
||||||
|
{
|
||||||
|
jsDev_t *js;
|
||||||
|
int devIdx = devSel->itemData(index).toInt();
|
||||||
|
|
||||||
|
js = getJoystickDevice( devIdx );
|
||||||
|
|
||||||
|
if ( js != NULL )
|
||||||
|
{
|
||||||
|
if ( js->isConnected() )
|
||||||
|
{
|
||||||
|
guidLbl->setText( js->getGUID() );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
guidLbl->setText("");
|
||||||
|
}
|
||||||
|
GamePad[portNum].setDeviceIndex( devIdx );
|
||||||
|
|
||||||
|
loadMapList();
|
||||||
|
|
||||||
|
updateCntrlrDpy();
|
||||||
}
|
}
|
||||||
//----------------------------------------------------
|
//----------------------------------------------------
|
||||||
void GamePadConfDialog_t::ena4score(int state)
|
void GamePadConfDialog_t::ena4score(int state)
|
||||||
|
@ -190,8 +408,8 @@ void GamePadConfDialog_t::oppDirEna(int state)
|
||||||
//----------------------------------------------------
|
//----------------------------------------------------
|
||||||
void GamePadConfDialog_t::changeButton(int padNo, int x)
|
void GamePadConfDialog_t::changeButton(int padNo, int x)
|
||||||
{
|
{
|
||||||
char buf[256];
|
//char buf[256];
|
||||||
std::string prefix;
|
//std::string prefix;
|
||||||
const char *keyNameStr;
|
const char *keyNameStr;
|
||||||
|
|
||||||
if ( buttonConfigStatus == 2 )
|
if ( buttonConfigStatus == 2 )
|
||||||
|
@ -205,29 +423,9 @@ void GamePadConfDialog_t::changeButton(int padNo, int x)
|
||||||
|
|
||||||
button[x]->setText("Waiting" );
|
button[x]->setText("Waiting" );
|
||||||
|
|
||||||
snprintf (buf, sizeof(buf)-1, "SDL.Input.GamePad.%d.", padNo);
|
DWaitButton (NULL, &GamePad[padNo].bmap[x], &buttonConfigStatus );
|
||||||
prefix = buf;
|
|
||||||
DWaitButton (NULL, &GamePadConfig[padNo][x], configNo, &buttonConfigStatus );
|
|
||||||
|
|
||||||
g_config->setOption (prefix + GamePadNames[x],
|
keyNameStr = ButtonName( &GamePad[padNo].bmap[x] );
|
||||||
GamePadConfig[padNo][x].ButtonNum[configNo]);
|
|
||||||
|
|
||||||
if (GamePadConfig[padNo][x].ButtType[configNo] == BUTTC_KEYBOARD)
|
|
||||||
{
|
|
||||||
g_config->setOption (prefix + "DeviceType", "Keyboard");
|
|
||||||
}
|
|
||||||
else if (GamePadConfig[padNo][x].ButtType[configNo] == BUTTC_JOYSTICK)
|
|
||||||
{
|
|
||||||
g_config->setOption (prefix + "DeviceType", "Joystick");
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
g_config->setOption (prefix + "DeviceType", "Unknown");
|
|
||||||
}
|
|
||||||
g_config->setOption (prefix + "DeviceNum",
|
|
||||||
GamePadConfig[padNo][x].DeviceNum[configNo]);
|
|
||||||
|
|
||||||
keyNameStr = ButtonName( &GamePadConfig[padNo][x], configNo );
|
|
||||||
|
|
||||||
keyName[x]->setText( keyNameStr );
|
keyName[x]->setText( keyNameStr );
|
||||||
button[x]->setText("Change");
|
button[x]->setText("Change");
|
||||||
|
@ -239,19 +437,9 @@ void GamePadConfDialog_t::changeButton(int padNo, int x)
|
||||||
//----------------------------------------------------
|
//----------------------------------------------------
|
||||||
void GamePadConfDialog_t::clearButton( int padNo, int x )
|
void GamePadConfDialog_t::clearButton( int padNo, int x )
|
||||||
{
|
{
|
||||||
char buf[256];
|
GamePad[padNo].bmap[x].ButtonNum = -1;
|
||||||
std::string prefix;
|
|
||||||
|
|
||||||
GamePadConfig[padNo][x].ButtonNum[configNo] = -1;
|
|
||||||
|
|
||||||
keyName[x]->setText("");
|
keyName[x]->setText("");
|
||||||
|
|
||||||
snprintf (buf, sizeof(buf)-1, "SDL.Input.GamePad.%d.", padNo);
|
|
||||||
prefix = buf;
|
|
||||||
|
|
||||||
g_config->setOption (prefix + GamePadNames[x],
|
|
||||||
GamePadConfig[padNo][x].ButtonNum[configNo]);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
//----------------------------------------------------
|
//----------------------------------------------------
|
||||||
void GamePadConfDialog_t::closeEvent(QCloseEvent *event)
|
void GamePadConfDialog_t::closeEvent(QCloseEvent *event)
|
||||||
|
@ -377,48 +565,150 @@ void GamePadConfDialog_t::clearAllCallback(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//----------------------------------------------------
|
//----------------------------------------------------
|
||||||
void GamePadConfDialog_t::loadDefaults(void)
|
void GamePadConfDialog_t::saveConfig(void)
|
||||||
{
|
{
|
||||||
char buf[256];
|
char stmp[256];
|
||||||
std::string prefix;
|
std::string prefix, mapName;
|
||||||
|
|
||||||
if ( portNum > 0 )
|
sprintf( stmp, "SDL.Input.GamePad.%u.", portNum );
|
||||||
{
|
prefix = stmp;
|
||||||
clearAllCallback();
|
|
||||||
return;
|
mapName = mapSel->currentText().toStdString();
|
||||||
|
|
||||||
|
g_config->setOption(prefix + "DeviceGUID", GamePad[portNum].getGUID() );
|
||||||
|
g_config->setOption(prefix + "Profile" , mapName.c_str() );
|
||||||
}
|
}
|
||||||
|
//----------------------------------------------------
|
||||||
snprintf (buf, sizeof(buf)-1, "SDL.Input.GamePad.%d.", portNum);
|
void GamePadConfDialog_t::createNewProfile( const char *name )
|
||||||
prefix = buf;
|
|
||||||
|
|
||||||
for (int x=0; x<GAMEPAD_NUM_BUTTONS; x++)
|
|
||||||
{
|
{
|
||||||
GamePadConfig[portNum][x].ButtType[configNo] = BUTTC_KEYBOARD;
|
printf("Creating: %s \n", name );
|
||||||
GamePadConfig[portNum][x].DeviceNum[configNo] = 0;
|
|
||||||
GamePadConfig[portNum][x].ButtonNum[configNo] = DefaultGamePad[portNum][x];
|
|
||||||
GamePadConfig[portNum][x].NumC = 1;
|
|
||||||
|
|
||||||
g_config->setOption (prefix + GamePadNames[x],
|
GamePad[portNum].createProfile(name);
|
||||||
GamePadConfig[portNum][x].ButtonNum[configNo]);
|
|
||||||
|
|
||||||
if (GamePadConfig[portNum][x].ButtType[configNo] == BUTTC_KEYBOARD)
|
mapSel->addItem( tr(name) );
|
||||||
{
|
|
||||||
g_config->setOption (prefix + "DeviceType", "Keyboard");
|
|
||||||
}
|
}
|
||||||
else if (GamePadConfig[portNum][x].ButtType[configNo] == BUTTC_JOYSTICK)
|
//----------------------------------------------------
|
||||||
|
void GamePadConfDialog_t::newProfileCallback(void)
|
||||||
{
|
{
|
||||||
g_config->setOption (prefix + "DeviceType", "Joystick");
|
int ret;
|
||||||
|
QInputDialog dialog(this);
|
||||||
|
|
||||||
|
dialog.setWindowTitle( tr("New Profile") );
|
||||||
|
dialog.setLabelText( tr("Specify New Profile Name") );
|
||||||
|
dialog.setOkButtonText( tr("Create") );
|
||||||
|
|
||||||
|
dialog.show();
|
||||||
|
ret = dialog.exec();
|
||||||
|
|
||||||
|
if ( QDialog::Accepted == ret )
|
||||||
|
{
|
||||||
|
createNewProfile( dialog.textValue().toStdString().c_str() );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//----------------------------------------------------
|
||||||
|
void GamePadConfDialog_t::loadProfileCallback(void)
|
||||||
|
{
|
||||||
|
char stmp[256];
|
||||||
|
int index, devIdx, ret;
|
||||||
|
std::string mapName;
|
||||||
|
|
||||||
|
index = devSel->currentIndex();
|
||||||
|
devIdx = devSel->itemData(index).toInt();
|
||||||
|
|
||||||
|
mapName = mapSel->currentText().toStdString();
|
||||||
|
|
||||||
|
GamePad[portNum].setDeviceIndex( devIdx );
|
||||||
|
|
||||||
|
if ( mapName.compare("default") == 0 )
|
||||||
|
{
|
||||||
|
ret =GamePad[portNum].loadDefaults();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
g_config->setOption (prefix + "DeviceType", "Unknown");
|
ret = GamePad[portNum].loadProfile( mapName.c_str() );
|
||||||
}
|
}
|
||||||
g_config->setOption (prefix + "DeviceNum",
|
if ( ret == 0 )
|
||||||
GamePadConfig[portNum][x].DeviceNum[configNo]);
|
{
|
||||||
|
saveConfig();
|
||||||
|
|
||||||
|
sprintf( stmp, "Mapping Loaded: %s/%s \n", GamePad[portNum].getGUID(), mapName.c_str() );
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
sprintf( stmp, "Error: Failed to Load Mapping: %s/%s \n", GamePad[portNum].getGUID(), mapName.c_str() );
|
||||||
|
}
|
||||||
|
mapMsg->setText( tr(stmp) );
|
||||||
|
|
||||||
updateCntrlrDpy();
|
updateCntrlrDpy();
|
||||||
}
|
}
|
||||||
//----------------------------------------------------
|
//----------------------------------------------------
|
||||||
|
void GamePadConfDialog_t::saveProfileCallback(void)
|
||||||
|
{
|
||||||
|
int ret;
|
||||||
|
std::string mapName;
|
||||||
|
char stmp[256];
|
||||||
|
|
||||||
|
mapName = mapSel->currentText().toStdString();
|
||||||
|
|
||||||
|
ret = GamePad[portNum].saveCurrentMapToFile( mapName.c_str() );
|
||||||
|
|
||||||
|
if ( ret == 0 )
|
||||||
|
{
|
||||||
|
saveConfig();
|
||||||
|
|
||||||
|
sprintf( stmp, "Mapping Saved: %s/%s \n", GamePad[portNum].getGUID(), mapName.c_str() );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
sprintf( stmp, "Error: Failed to Save Mapping: %s \n", mapName.c_str() );
|
||||||
|
}
|
||||||
|
mapMsg->setText( tr(stmp) );
|
||||||
|
|
||||||
|
}
|
||||||
|
//----------------------------------------------------
|
||||||
|
void GamePadConfDialog_t::deleteProfileCallback(void)
|
||||||
|
{
|
||||||
|
int ret;
|
||||||
|
std::string mapName;
|
||||||
|
char stmp[256];
|
||||||
|
|
||||||
|
mapName = mapSel->currentText().toStdString();
|
||||||
|
|
||||||
|
ret = GamePad[portNum].deleteMapping( mapName.c_str() );
|
||||||
|
|
||||||
|
if ( ret == 0 )
|
||||||
|
{
|
||||||
|
sprintf( stmp, "Mapping Deleted: %s/%s \n", GamePad[portNum].getGUID(), mapName.c_str() );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
sprintf( stmp, "Error: Failed to Delete Mapping: %s \n", mapName.c_str() );
|
||||||
|
}
|
||||||
|
mapMsg->setText( tr(stmp) );
|
||||||
|
|
||||||
|
loadMapList();
|
||||||
|
}
|
||||||
|
//----------------------------------------------------
|
||||||
|
void GamePadConfDialog_t::updatePeriodic(void)
|
||||||
|
{
|
||||||
|
for (int i=0; i<GAMEPAD_NUM_BUTTONS; i++)
|
||||||
|
{
|
||||||
|
const char *txt, *style;
|
||||||
|
if ( GamePad[portNum].bmap[i].state )
|
||||||
|
{
|
||||||
|
txt = " T ";
|
||||||
|
style = "background-color: green; color: white;";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
txt = " F ";
|
||||||
|
style = "background-color: red; color: white;";
|
||||||
|
}
|
||||||
|
keyState[i]->setText( tr(txt) );
|
||||||
|
keyState[i]->setStyleSheet( style );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//----------------------------------------------------
|
||||||
GamePadConfigButton_t::GamePadConfigButton_t(int i)
|
GamePadConfigButton_t::GamePadConfigButton_t(int i)
|
||||||
{
|
{
|
||||||
idx = i;
|
idx = i;
|
||||||
|
|
|
@ -12,6 +12,7 @@
|
||||||
#include <QPushButton>
|
#include <QPushButton>
|
||||||
#include <QLabel>
|
#include <QLabel>
|
||||||
#include <QFrame>
|
#include <QFrame>
|
||||||
|
#include <QTimer>
|
||||||
#include <QGroupBox>
|
#include <QGroupBox>
|
||||||
|
|
||||||
#include "Qt/main.h"
|
#include "Qt/main.h"
|
||||||
|
@ -37,12 +38,18 @@ class GamePadConfDialog_t : public QDialog
|
||||||
~GamePadConfDialog_t(void);
|
~GamePadConfDialog_t(void);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
QTimer *inputTimer;
|
||||||
QComboBox *portSel;
|
QComboBox *portSel;
|
||||||
|
QComboBox *devSel;
|
||||||
|
QComboBox *mapSel;
|
||||||
|
QComboBox *profSel;
|
||||||
|
QLabel *guidLbl;
|
||||||
|
QLabel *mapMsg;
|
||||||
QLabel *keyName[GAMEPAD_NUM_BUTTONS];
|
QLabel *keyName[GAMEPAD_NUM_BUTTONS];
|
||||||
|
QLabel *keyState[GAMEPAD_NUM_BUTTONS];
|
||||||
GamePadConfigButton_t *button[GAMEPAD_NUM_BUTTONS];
|
GamePadConfigButton_t *button[GAMEPAD_NUM_BUTTONS];
|
||||||
|
|
||||||
int portNum;
|
int portNum;
|
||||||
int configNo;
|
|
||||||
int buttonConfigStatus;
|
int buttonConfigStatus;
|
||||||
|
|
||||||
void changeButton( int port, int button );
|
void changeButton( int port, int button );
|
||||||
|
@ -52,6 +59,9 @@ class GamePadConfDialog_t : public QDialog
|
||||||
void closeEvent(QCloseEvent *bar);
|
void closeEvent(QCloseEvent *bar);
|
||||||
private:
|
private:
|
||||||
void updateCntrlrDpy(void);
|
void updateCntrlrDpy(void);
|
||||||
|
void createNewProfile( const char *name );
|
||||||
|
void loadMapList(void);
|
||||||
|
void saveConfig(void);
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
void closeWindow(void);
|
void closeWindow(void);
|
||||||
|
@ -77,9 +87,14 @@ class GamePadConfDialog_t : public QDialog
|
||||||
void clearButton8(void);
|
void clearButton8(void);
|
||||||
void clearButton9(void);
|
void clearButton9(void);
|
||||||
void clearAllCallback(void);
|
void clearAllCallback(void);
|
||||||
void loadDefaults(void);
|
|
||||||
void ena4score(int state);
|
void ena4score(int state);
|
||||||
void oppDirEna(int state);
|
void oppDirEna(int state);
|
||||||
void controllerSelect(int index);
|
void portSelect(int index);
|
||||||
|
void deviceSelect(int index);
|
||||||
|
void newProfileCallback(void);
|
||||||
|
void loadProfileCallback(void);
|
||||||
|
void saveProfileCallback(void);
|
||||||
|
void deleteProfileCallback(void);
|
||||||
|
void updatePeriodic(void);
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
|
@ -102,20 +102,20 @@ LoadCPalette(const std::string &file)
|
||||||
static void
|
static void
|
||||||
CreateDirs(const std::string &dir)
|
CreateDirs(const std::string &dir)
|
||||||
{
|
{
|
||||||
const char *subs[8]={"fcs","snaps","gameinfo","sav","cheats","movies","cfg.d"};
|
const char *subs[9]={"fcs","snaps","gameinfo","sav","cheats","movies","input"};
|
||||||
std::string subdir;
|
std::string subdir;
|
||||||
int x;
|
int x;
|
||||||
|
|
||||||
#if defined(WIN32) || defined(NEED_MINGW_HACKS)
|
#if defined(WIN32) || defined(NEED_MINGW_HACKS)
|
||||||
mkdir(dir.c_str());
|
mkdir(dir.c_str());
|
||||||
chmod(dir.c_str(), 755);
|
chmod(dir.c_str(), 755);
|
||||||
for(x = 0; x < 6; x++) {
|
for(x = 0; x < 7; x++) {
|
||||||
subdir = dir + PSS + subs[x];
|
subdir = dir + PSS + subs[x];
|
||||||
mkdir(subdir.c_str());
|
mkdir(subdir.c_str());
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
mkdir(dir.c_str(), S_IRWXU);
|
mkdir(dir.c_str(), S_IRWXU);
|
||||||
for(x = 0; x < 6; x++) {
|
for(x = 0; x < 7; x++) {
|
||||||
subdir = dir + PSS + subs[x];
|
subdir = dir + PSS + subs[x];
|
||||||
mkdir(subdir.c_str(), S_IRWXU);
|
mkdir(subdir.c_str(), S_IRWXU);
|
||||||
}
|
}
|
||||||
|
@ -242,7 +242,7 @@ InitConfig()
|
||||||
config->addOption("input4", "SDL.Input.3", "Gamepad.3");
|
config->addOption("input4", "SDL.Input.3", "Gamepad.3");
|
||||||
|
|
||||||
// allow for input configuration
|
// allow for input configuration
|
||||||
config->addOption('i', "inputcfg", "SDL.InputCfg", InputCfg);
|
//config->addOption('i', "inputcfg", "SDL.InputCfg", InputCfg);
|
||||||
|
|
||||||
// display input
|
// display input
|
||||||
config->addOption("inputdisplay", "SDL.InputDisplay", 0);
|
config->addOption("inputdisplay", "SDL.InputDisplay", 0);
|
||||||
|
@ -317,10 +317,8 @@ InitConfig()
|
||||||
prefix = buf;
|
prefix = buf;
|
||||||
|
|
||||||
config->addOption(prefix + "DeviceType", DefaultGamePadDevice[i]);
|
config->addOption(prefix + "DeviceType", DefaultGamePadDevice[i]);
|
||||||
config->addOption(prefix + "DeviceNum", 0);
|
config->addOption(prefix + "DeviceGUID", "");
|
||||||
for(unsigned int j = 0; j < GAMEPAD_NUM_BUTTONS; j++) {
|
config->addOption(prefix + "Profile" , "");
|
||||||
config->addOption(prefix + GamePadNames[j], DefaultGamePad[i][j]);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// PowerPad 0 - 1
|
// PowerPad 0 - 1
|
||||||
|
|
|
@ -18,6 +18,8 @@ void SilenceSound(int s); /* DOS and SDL */
|
||||||
|
|
||||||
int InitJoysticks(void);
|
int InitJoysticks(void);
|
||||||
int KillJoysticks(void);
|
int KillJoysticks(void);
|
||||||
|
int AddJoystick( int which );
|
||||||
|
int RemoveJoystick( int which );
|
||||||
uint32 *GetJSOr(void);
|
uint32 *GetJSOr(void);
|
||||||
|
|
||||||
int InitVideo(FCEUGI *gi);
|
int InitVideo(FCEUGI *gi);
|
||||||
|
|
|
@ -414,6 +414,7 @@ static void ShowUsage(const char *prog)
|
||||||
int fceuWrapperInit( int argc, char *argv[] )
|
int fceuWrapperInit( int argc, char *argv[] )
|
||||||
{
|
{
|
||||||
int error;
|
int error;
|
||||||
|
std::string s;
|
||||||
|
|
||||||
for (int i=0; i<argc; i++)
|
for (int i=0; i<argc; i++)
|
||||||
{
|
{
|
||||||
|
@ -468,15 +469,14 @@ int fceuWrapperInit( int argc, char *argv[] )
|
||||||
g_config->save();
|
g_config->save();
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string s;
|
|
||||||
|
|
||||||
g_config->getOption("SDL.InputCfg", &s);
|
//g_config->getOption("SDL.InputCfg", &s);
|
||||||
|
|
||||||
if (s.size() != 0)
|
//if (s.size() != 0)
|
||||||
{
|
//{
|
||||||
InitVideo(GameInfo);
|
// InitVideo(GameInfo);
|
||||||
InputCfg(s);
|
// InputCfg(s);
|
||||||
}
|
//}
|
||||||
|
|
||||||
// update the input devices
|
// update the input devices
|
||||||
UpdateInput(g_config);
|
UpdateInput(g_config);
|
||||||
|
|
|
@ -24,8 +24,9 @@
|
||||||
#include "Qt/config.h"
|
#include "Qt/config.h"
|
||||||
|
|
||||||
|
|
||||||
#include "Qt/sdl-video.h"
|
|
||||||
#include "Qt/sdl.h"
|
#include "Qt/sdl.h"
|
||||||
|
#include "Qt/sdl-video.h"
|
||||||
|
#include "Qt/sdl-joystick.h"
|
||||||
|
|
||||||
#include "common/cheat.h"
|
#include "common/cheat.h"
|
||||||
#include "../../movie.h"
|
#include "../../movie.h"
|
||||||
|
@ -49,8 +50,8 @@ extern bool bindSavestate, frameAdvanceLagSkip, lagCounterDisplay;
|
||||||
/* UsrInputType[] is user-specified. CurInputType[] is current
|
/* UsrInputType[] is user-specified. CurInputType[] is current
|
||||||
(game loading can override user settings)
|
(game loading can override user settings)
|
||||||
*/
|
*/
|
||||||
static int UsrInputType[NUM_INPUT_DEVICES];
|
static int UsrInputType[NUM_INPUT_DEVICES] = { SI_GAMEPAD, SI_GAMEPAD, SI_NONE };
|
||||||
static int CurInputType[NUM_INPUT_DEVICES];
|
static int CurInputType[NUM_INPUT_DEVICES] = { SI_GAMEPAD, SI_GAMEPAD, SI_NONE };
|
||||||
static int cspec = 0;
|
static int cspec = 0;
|
||||||
static int buttonConfigInProgress = 0;
|
static int buttonConfigInProgress = 0;
|
||||||
|
|
||||||
|
@ -956,6 +957,12 @@ UpdatePhysicalInput ()
|
||||||
g_keyState[ event.key.keysym.scancode ] = (event.type == SDL_KEYDOWN) ? 1 : 0;
|
g_keyState[ event.key.keysym.scancode ] = (event.type == SDL_KEYDOWN) ? 1 : 0;
|
||||||
//checkKeyBoardState( event.key.keysym.scancode );
|
//checkKeyBoardState( event.key.keysym.scancode );
|
||||||
break;
|
break;
|
||||||
|
case SDL_JOYDEVICEADDED:
|
||||||
|
AddJoystick( event.jdevice.which );
|
||||||
|
break;
|
||||||
|
case SDL_JOYDEVICEREMOVED:
|
||||||
|
RemoveJoystick( event.jdevice.which );
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -964,8 +971,6 @@ UpdatePhysicalInput ()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static int bcpv=0, bcpj=0;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Begin configuring the buttons by placing the video and joystick
|
* Begin configuring the buttons by placing the video and joystick
|
||||||
* subsystems into a well-known state. Button configuration really
|
* subsystems into a well-known state. Button configuration really
|
||||||
|
@ -973,13 +978,7 @@ static int bcpv=0, bcpj=0;
|
||||||
*/
|
*/
|
||||||
int ButtonConfigBegin ()
|
int ButtonConfigBegin ()
|
||||||
{
|
{
|
||||||
// shut down the joystick subsystems
|
// initialize the joystick subsystem (if not already inited)
|
||||||
//SDL_Surface *screen;
|
|
||||||
|
|
||||||
bcpj = KillJoysticks ();
|
|
||||||
|
|
||||||
// XXX soules - why did we shut this down?
|
|
||||||
// initialize the joystick subsystem
|
|
||||||
InitJoysticks ();
|
InitJoysticks ();
|
||||||
|
|
||||||
buttonConfigInProgress = 1;
|
buttonConfigInProgress = 1;
|
||||||
|
@ -995,18 +994,6 @@ int ButtonConfigBegin ()
|
||||||
void
|
void
|
||||||
ButtonConfigEnd ()
|
ButtonConfigEnd ()
|
||||||
{
|
{
|
||||||
// shutdown the joystick and video subsystems
|
|
||||||
KillJoysticks ();
|
|
||||||
//SDL_QuitSubSystem(SDL_INIT_VIDEO);
|
|
||||||
|
|
||||||
// re-initialize joystick and video subsystems if they were active before
|
|
||||||
/*if(!bcpv) {
|
|
||||||
InitVideo(GameInfo);
|
|
||||||
} */
|
|
||||||
if (!bcpj)
|
|
||||||
{
|
|
||||||
InitJoysticks ();
|
|
||||||
}
|
|
||||||
buttonConfigInProgress = 0;
|
buttonConfigInProgress = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1016,49 +1003,50 @@ ButtonConfigEnd ()
|
||||||
static int
|
static int
|
||||||
DTestButton (ButtConfig * bc)
|
DTestButton (ButtConfig * bc)
|
||||||
{
|
{
|
||||||
int x;
|
|
||||||
|
|
||||||
for (x = 0; x < bc->NumC; x++)
|
if (bc->ButtType == BUTTC_KEYBOARD)
|
||||||
{
|
{
|
||||||
if (bc->ButtType[x] == BUTTC_KEYBOARD)
|
if (g_keyState[SDL_GetScancodeFromKey (bc->ButtonNum)])
|
||||||
{
|
|
||||||
if (g_keyState[SDL_GetScancodeFromKey (bc->ButtonNum[x])])
|
|
||||||
{
|
{
|
||||||
|
bc->state = 1;
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
bc->state = 0;
|
||||||
}
|
}
|
||||||
else if (bc->ButtType[x] == BUTTC_JOYSTICK)
|
}
|
||||||
|
else if (bc->ButtType == BUTTC_JOYSTICK)
|
||||||
{
|
{
|
||||||
if (DTestButtonJoy (bc))
|
if (DTestButtonJoy (bc))
|
||||||
{
|
{
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#define MK(x) {{BUTTC_KEYBOARD},{0},{MKK(x)},1}
|
#define MK(x) {BUTTC_KEYBOARD,0,MKK(x),0}
|
||||||
#define MK2(x1,x2) {{BUTTC_KEYBOARD},{0},{MKK(x1),MKK(x2)},2}
|
//#define MK2(x1,x2) {BUTTC_KEYBOARD,0,MKK(x1)}
|
||||||
#define MKZ() {{0},{0},{-1},0}
|
#define MKZ() {0,0,-1,0}
|
||||||
#define GPZ() {MKZ(), MKZ(), MKZ(), MKZ()}
|
#define GPZ() {MKZ(), MKZ(), MKZ(), MKZ()}
|
||||||
|
|
||||||
ButtConfig GamePadConfig[ GAMEPAD_NUM_DEVICES ][ GAMEPAD_NUM_BUTTONS ] =
|
//ButtConfig GamePadConfig[ GAMEPAD_NUM_DEVICES ][ GAMEPAD_NUM_BUTTONS ] =
|
||||||
{
|
//{
|
||||||
/* Gamepad 1 */
|
///* Gamepad 1 */
|
||||||
{MK (KP_3), MK (KP_2), MK (SLASH), MK (ENTER),
|
// {MK (KP_3), MK (KP_2), MK (SLASH), MK (ENTER),
|
||||||
MK (w), MK (z), MK (a), MK (s), MKZ (), MKZ ()},
|
// MK (w), MK (z), MK (a), MK (s), MKZ (), MKZ ()},
|
||||||
|
//
|
||||||
/* Gamepad 2 */
|
// /* Gamepad 2 */
|
||||||
GPZ (),
|
// GPZ (),
|
||||||
|
//
|
||||||
/* Gamepad 3 */
|
// /* Gamepad 3 */
|
||||||
GPZ (),
|
// GPZ (),
|
||||||
|
//
|
||||||
/* Gamepad 4 */
|
// /* Gamepad 4 */
|
||||||
GPZ ()
|
// GPZ ()
|
||||||
};
|
//};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Update the status of the gamepad input devices.
|
* Update the status of the gamepad input devices.
|
||||||
|
@ -1090,7 +1078,7 @@ UpdateGamepad(void)
|
||||||
// a, b, select, start, up, down, left, right
|
// a, b, select, start, up, down, left, right
|
||||||
for (x = 0; x < 8; x++)
|
for (x = 0; x < 8; x++)
|
||||||
{
|
{
|
||||||
if (DTestButton (&GamePadConfig[wg][x]))
|
if (DTestButton (&GamePad[wg].bmap[x]))
|
||||||
{
|
{
|
||||||
//printf("GamePad%i Button Hit: %i \n", wg, x );
|
//printf("GamePad%i Button Hit: %i \n", wg, x );
|
||||||
if(opposite_dirs == 0)
|
if(opposite_dirs == 0)
|
||||||
|
@ -1128,7 +1116,7 @@ UpdateGamepad(void)
|
||||||
{
|
{
|
||||||
for (x = 0; x < 2; x++)
|
for (x = 0; x < 2; x++)
|
||||||
{
|
{
|
||||||
if (DTestButton (&GamePadConfig[wg][8 + x]))
|
if (DTestButton (&GamePad[wg].bmap[8 + x]))
|
||||||
{
|
{
|
||||||
JS |= (1 << x) << (wg << 3);
|
JS |= (1 << x) << (wg << 3);
|
||||||
}
|
}
|
||||||
|
@ -1563,42 +1551,42 @@ UpdateFTrainer ()
|
||||||
* @param bc the NES gamepad's button config
|
* @param bc the NES gamepad's button config
|
||||||
* @param which the index of the button
|
* @param which the index of the button
|
||||||
*/
|
*/
|
||||||
const char * ButtonName (const ButtConfig * bc, int which)
|
const char * ButtonName (const ButtConfig * bc)
|
||||||
{
|
{
|
||||||
static char name[256];
|
static char name[256];
|
||||||
|
|
||||||
name[0] = 0;
|
name[0] = 0;
|
||||||
|
|
||||||
if (bc->ButtonNum[which] == -1)
|
if (bc->ButtonNum == -1)
|
||||||
{
|
{
|
||||||
return name;
|
return name;
|
||||||
}
|
}
|
||||||
switch (bc->ButtType[which])
|
switch (bc->ButtType)
|
||||||
{
|
{
|
||||||
case BUTTC_KEYBOARD:
|
case BUTTC_KEYBOARD:
|
||||||
return SDL_GetKeyName (bc->ButtonNum[which]);
|
return SDL_GetKeyName (bc->ButtonNum);
|
||||||
break;
|
break;
|
||||||
case BUTTC_JOYSTICK:
|
case BUTTC_JOYSTICK:
|
||||||
{
|
{
|
||||||
int joyNum, inputNum;
|
int joyNum, inputNum;
|
||||||
const char *inputType, *inputDirection;
|
const char *inputType, *inputDirection;
|
||||||
|
|
||||||
joyNum = bc->DeviceNum[which];
|
joyNum = bc->DeviceNum;
|
||||||
|
|
||||||
if (bc->ButtonNum[which] & 0x8000)
|
if (bc->ButtonNum & 0x8000)
|
||||||
{
|
{
|
||||||
inputType = "Axis";
|
inputType = "Axis";
|
||||||
inputNum = bc->ButtonNum[which] & 0x3FFF;
|
inputNum = bc->ButtonNum & 0x3FFF;
|
||||||
inputDirection = bc->ButtonNum[which] & 0x4000 ? "-" : "+";
|
inputDirection = bc->ButtonNum & 0x4000 ? "-" : "+";
|
||||||
}
|
}
|
||||||
else if (bc->ButtonNum[which] & 0x2000)
|
else if (bc->ButtonNum & 0x2000)
|
||||||
{
|
{
|
||||||
int inputValue;
|
int inputValue;
|
||||||
char direction[128] = "";
|
char direction[128] = "";
|
||||||
|
|
||||||
inputType = "Hat";
|
inputType = "Hat";
|
||||||
inputNum = (bc->ButtonNum[which] >> 8) & 0x1F;
|
inputNum = (bc->ButtonNum >> 8) & 0x1F;
|
||||||
inputValue = bc->ButtonNum[which] & 0xF;
|
inputValue = bc->ButtonNum & 0xF;
|
||||||
|
|
||||||
if (inputValue & SDL_HAT_UP)
|
if (inputValue & SDL_HAT_UP)
|
||||||
strncat (direction, "Up ", sizeof (direction)-1);
|
strncat (direction, "Up ", sizeof (direction)-1);
|
||||||
|
@ -1617,7 +1605,7 @@ const char * ButtonName (const ButtConfig * bc, int which)
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
inputType = "Button";
|
inputType = "Button";
|
||||||
inputNum = bc->ButtonNum[which];
|
inputNum = bc->ButtonNum;
|
||||||
inputDirection = "";
|
inputDirection = "";
|
||||||
}
|
}
|
||||||
sprintf( name, "js%i:%s%i%s", joyNum, inputType, inputNum, inputDirection );
|
sprintf( name, "js%i:%s%i%s", joyNum, inputType, inputNum, inputDirection );
|
||||||
|
@ -1632,7 +1620,7 @@ const char * ButtonName (const ButtConfig * bc, int which)
|
||||||
* Waits for a button input and returns the information as to which
|
* Waits for a button input and returns the information as to which
|
||||||
* button was pressed. Used in button configuration.
|
* button was pressed. Used in button configuration.
|
||||||
*/
|
*/
|
||||||
int DWaitButton (const uint8_t * text, ButtConfig * bc, int wb, int *buttonConfigStatus )
|
int DWaitButton (const uint8_t * text, ButtConfig * bc, int *buttonConfigStatus )
|
||||||
{
|
{
|
||||||
SDL_Event event;
|
SDL_Event event;
|
||||||
static int32 LastAx[64][64];
|
static int32 LastAx[64][64];
|
||||||
|
@ -1684,23 +1672,23 @@ int DWaitButton (const uint8_t * text, ButtConfig * bc, int wb, int *buttonConfi
|
||||||
{
|
{
|
||||||
case SDL_KEYDOWN:
|
case SDL_KEYDOWN:
|
||||||
//printf("SDL KeyDown:%i \n", event.key.keysym.sym );
|
//printf("SDL KeyDown:%i \n", event.key.keysym.sym );
|
||||||
bc->ButtType[wb] = BUTTC_KEYBOARD;
|
bc->ButtType = BUTTC_KEYBOARD;
|
||||||
bc->DeviceNum[wb] = 0;
|
bc->DeviceNum = 0;
|
||||||
bc->ButtonNum[wb] = event.key.keysym.sym;
|
bc->ButtonNum = event.key.keysym.sym;
|
||||||
return (1);
|
return (1);
|
||||||
case SDL_JOYBUTTONDOWN:
|
case SDL_JOYBUTTONDOWN:
|
||||||
bc->ButtType[wb] = BUTTC_JOYSTICK;
|
bc->ButtType = BUTTC_JOYSTICK;
|
||||||
bc->DeviceNum[wb] = event.jbutton.which;
|
bc->DeviceNum = event.jbutton.which;
|
||||||
bc->ButtonNum[wb] = event.jbutton.button;
|
bc->ButtonNum = event.jbutton.button;
|
||||||
return (1);
|
return (1);
|
||||||
case SDL_JOYHATMOTION:
|
case SDL_JOYHATMOTION:
|
||||||
if (event.jhat.value == SDL_HAT_CENTERED)
|
if (event.jhat.value == SDL_HAT_CENTERED)
|
||||||
done--;
|
done--;
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
bc->ButtType[wb] = BUTTC_JOYSTICK;
|
bc->ButtType = BUTTC_JOYSTICK;
|
||||||
bc->DeviceNum[wb] = event.jhat.which;
|
bc->DeviceNum = event.jhat.which;
|
||||||
bc->ButtonNum[wb] =
|
bc->ButtonNum =
|
||||||
(0x2000 | ((event.jhat.hat & 0x1F) << 8) | event.
|
(0x2000 | ((event.jhat.hat & 0x1F) << 8) | event.
|
||||||
jhat.value);
|
jhat.value);
|
||||||
return (1);
|
return (1);
|
||||||
|
@ -1722,9 +1710,9 @@ int DWaitButton (const uint8_t * text, ButtConfig * bc, int wb, int *buttonConfi
|
||||||
(LastAx[event.jaxis.which][event.jaxis.axis] -
|
(LastAx[event.jaxis.which][event.jaxis.axis] -
|
||||||
event.jaxis.value) >= 8192)
|
event.jaxis.value) >= 8192)
|
||||||
{
|
{
|
||||||
bc->ButtType[wb] = BUTTC_JOYSTICK;
|
bc->ButtType = BUTTC_JOYSTICK;
|
||||||
bc->DeviceNum[wb] = event.jaxis.which;
|
bc->DeviceNum = event.jaxis.which;
|
||||||
bc->ButtonNum[wb] = (0x8000 | event.jaxis.axis |
|
bc->ButtonNum = (0x8000 | event.jaxis.axis |
|
||||||
((event.jaxis.value < 0)
|
((event.jaxis.value < 0)
|
||||||
? 0x4000 : 0));
|
? 0x4000 : 0));
|
||||||
return (1);
|
return (1);
|
||||||
|
@ -1761,170 +1749,169 @@ int DWaitButton (const uint8_t * text, ButtConfig * bc, int wb, int *buttonConfi
|
||||||
* used as input for the specified button, thus allowing up to four
|
* used as input for the specified button, thus allowing up to four
|
||||||
* possible settings for each input button.
|
* possible settings for each input button.
|
||||||
*/
|
*/
|
||||||
void
|
// void
|
||||||
ConfigButton (char *text, ButtConfig * bc)
|
//ConfigButton (char *text, ButtConfig * bc)
|
||||||
{
|
//{
|
||||||
uint8 buf[256];
|
// uint8 buf[256];
|
||||||
int wc;
|
// int wc;
|
||||||
|
//
|
||||||
for (wc = 0; wc < MAXBUTTCONFIG; wc++)
|
// for (wc = 0; wc < MAXBUTTCONFIG; wc++)
|
||||||
{
|
// {
|
||||||
sprintf ((char *) buf, "%s (%d)", text, wc + 1);
|
// sprintf ((char *) buf, "%s (%d)", text, wc + 1);
|
||||||
DWaitButton (buf, bc, wc, NULL);
|
// DWaitButton (buf, bc, wc, NULL);
|
||||||
|
//
|
||||||
if (wc &&
|
// if (wc &&
|
||||||
bc->ButtType[wc] == bc->ButtType[wc - 1] &&
|
// bc->ButtType[wc] == bc->ButtType[wc - 1] &&
|
||||||
bc->DeviceNum[wc] == bc->DeviceNum[wc - 1] &&
|
// bc->DeviceNum[wc] == bc->DeviceNum[wc - 1] &&
|
||||||
bc->ButtonNum[wc] == bc->ButtonNum[wc - 1])
|
// bc->ButtonNum[wc] == bc->ButtonNum[wc - 1])
|
||||||
{
|
// {
|
||||||
break;
|
// break;
|
||||||
}
|
// }
|
||||||
}
|
// }
|
||||||
bc->NumC = wc;
|
//}
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Update the button configuration for a specified device.
|
* Update the button configuration for a specified device.
|
||||||
*/
|
*/
|
||||||
extern Config *g_config;
|
extern Config *g_config;
|
||||||
|
|
||||||
void ConfigDevice (int which, int arg)
|
//void ConfigDevice (int which, int arg)
|
||||||
{
|
//{
|
||||||
char buf[256];
|
// char buf[256];
|
||||||
int x;
|
// int x;
|
||||||
std::string prefix;
|
// std::string prefix;
|
||||||
const char *str[10] =
|
// const char *str[10] =
|
||||||
{ "A", "B", "SELECT", "START", "UP", "DOWN", "LEFT", "RIGHT", "Rapid A",
|
// { "A", "B", "SELECT", "START", "UP", "DOWN", "LEFT", "RIGHT", "Rapid A",
|
||||||
"Rapid B"
|
// "Rapid B"
|
||||||
};
|
// };
|
||||||
|
//
|
||||||
// XXX soules - set the configuration options so that later calls
|
// // XXX soules - set the configuration options so that later calls
|
||||||
// don't override these. This is a temp hack until I
|
// // don't override these. This is a temp hack until I
|
||||||
// can clean up this file.
|
// // can clean up this file.
|
||||||
|
//
|
||||||
ButtonConfigBegin ();
|
// ButtonConfigBegin ();
|
||||||
switch (which)
|
// switch (which)
|
||||||
{
|
// {
|
||||||
case FCFGD_QUIZKING:
|
// case FCFGD_QUIZKING:
|
||||||
prefix = "SDL.Input.QuizKing.";
|
// prefix = "SDL.Input.QuizKing.";
|
||||||
for (x = 0; x < 6; x++)
|
// for (x = 0; x < 6; x++)
|
||||||
{
|
// {
|
||||||
sprintf (buf, "Quiz King Buzzer #%d", x + 1);
|
// sprintf (buf, "Quiz King Buzzer #%d", x + 1);
|
||||||
ConfigButton (buf, &QuizKingButtons[x]);
|
// ConfigButton (buf, &QuizKingButtons[x]);
|
||||||
|
//
|
||||||
g_config->setOption (prefix + QuizKingNames[x],
|
// g_config->setOption (prefix + QuizKingNames[x],
|
||||||
QuizKingButtons[x].ButtonNum[0]);
|
// QuizKingButtons[x].ButtonNum);
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
if (QuizKingButtons[0].ButtType[0] == BUTTC_KEYBOARD)
|
// if (QuizKingButtons[0].ButtType == BUTTC_KEYBOARD)
|
||||||
{
|
// {
|
||||||
g_config->setOption (prefix + "DeviceType", "Keyboard");
|
// g_config->setOption (prefix + "DeviceType", "Keyboard");
|
||||||
}
|
// }
|
||||||
else if (QuizKingButtons[0].ButtType[0] == BUTTC_JOYSTICK)
|
// else if (QuizKingButtons[0].ButtType == BUTTC_JOYSTICK)
|
||||||
{
|
// {
|
||||||
g_config->setOption (prefix + "DeviceType", "Joystick");
|
// g_config->setOption (prefix + "DeviceType", "Joystick");
|
||||||
}
|
// }
|
||||||
else
|
// else
|
||||||
{
|
// {
|
||||||
g_config->setOption (prefix + "DeviceType", "Unknown");
|
// g_config->setOption (prefix + "DeviceType", "Unknown");
|
||||||
}
|
// }
|
||||||
g_config->setOption (prefix + "DeviceNum",
|
// g_config->setOption (prefix + "DeviceNum",
|
||||||
QuizKingButtons[0].DeviceNum[0]);
|
// QuizKingButtons[0].DeviceNum);
|
||||||
break;
|
// break;
|
||||||
case FCFGD_HYPERSHOT:
|
// case FCFGD_HYPERSHOT:
|
||||||
prefix = "SDL.Input.HyperShot.";
|
// prefix = "SDL.Input.HyperShot.";
|
||||||
for (x = 0; x < 4; x++)
|
// for (x = 0; x < 4; x++)
|
||||||
{
|
// {
|
||||||
sprintf (buf, "Hyper Shot %d: %s",
|
// sprintf (buf, "Hyper Shot %d: %s",
|
||||||
((x & 2) >> 1) + 1, (x & 1) ? "JUMP" : "RUN");
|
// ((x & 2) >> 1) + 1, (x & 1) ? "JUMP" : "RUN");
|
||||||
ConfigButton (buf, &HyperShotButtons[x]);
|
// ConfigButton (buf, &HyperShotButtons[x]);
|
||||||
|
//
|
||||||
g_config->setOption (prefix + HyperShotNames[x],
|
// g_config->setOption (prefix + HyperShotNames[x],
|
||||||
HyperShotButtons[x].ButtonNum[0]);
|
// HyperShotButtons[x].ButtonNum);
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
if (HyperShotButtons[0].ButtType[0] == BUTTC_KEYBOARD)
|
// if (HyperShotButtons[0].ButtType == BUTTC_KEYBOARD)
|
||||||
{
|
// {
|
||||||
g_config->setOption (prefix + "DeviceType", "Keyboard");
|
// g_config->setOption (prefix + "DeviceType", "Keyboard");
|
||||||
}
|
// }
|
||||||
else if (HyperShotButtons[0].ButtType[0] == BUTTC_JOYSTICK)
|
// else if (HyperShotButtons[0].ButtType == BUTTC_JOYSTICK)
|
||||||
{
|
// {
|
||||||
g_config->setOption (prefix + "DeviceType", "Joystick");
|
// g_config->setOption (prefix + "DeviceType", "Joystick");
|
||||||
}
|
// }
|
||||||
else
|
// else
|
||||||
{
|
// {
|
||||||
g_config->setOption (prefix + "DeviceType", "Unknown");
|
// g_config->setOption (prefix + "DeviceType", "Unknown");
|
||||||
}
|
// }
|
||||||
g_config->setOption (prefix + "DeviceNum",
|
// g_config->setOption (prefix + "DeviceNum",
|
||||||
HyperShotButtons[0].DeviceNum[0]);
|
// HyperShotButtons[0].DeviceNum);
|
||||||
break;
|
// break;
|
||||||
case FCFGD_POWERPAD:
|
// case FCFGD_POWERPAD:
|
||||||
snprintf (buf, 256, "SDL.Input.PowerPad.%d", (arg & 1));
|
// snprintf (buf, 256, "SDL.Input.PowerPad.%d", (arg & 1));
|
||||||
prefix = buf;
|
// prefix = buf;
|
||||||
for (x = 0; x < 12; x++)
|
// for (x = 0; x < 12; x++)
|
||||||
{
|
// {
|
||||||
sprintf (buf, "PowerPad %d: %d", (arg & 1) + 1, x + 11);
|
// sprintf (buf, "PowerPad %d: %d", (arg & 1) + 1, x + 11);
|
||||||
ConfigButton (buf, &powerpadsc[arg & 1][x]);
|
// ConfigButton (buf, &powerpadsc[arg & 1][x]);
|
||||||
|
//
|
||||||
g_config->setOption (prefix + PowerPadNames[x],
|
// g_config->setOption (prefix + PowerPadNames[x],
|
||||||
powerpadsc[arg & 1][x].ButtonNum[0]);
|
// powerpadsc[arg & 1][x].ButtonNum);
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
if (powerpadsc[arg & 1][0].ButtType[0] == BUTTC_KEYBOARD)
|
// if (powerpadsc[arg & 1][0].ButtType == BUTTC_KEYBOARD)
|
||||||
{
|
// {
|
||||||
g_config->setOption (prefix + "DeviceType", "Keyboard");
|
// g_config->setOption (prefix + "DeviceType", "Keyboard");
|
||||||
}
|
// }
|
||||||
else if (powerpadsc[arg & 1][0].ButtType[0] == BUTTC_JOYSTICK)
|
// else if (powerpadsc[arg & 1][0].ButtType == BUTTC_JOYSTICK)
|
||||||
{
|
// {
|
||||||
g_config->setOption (prefix + "DeviceType", "Joystick");
|
// g_config->setOption (prefix + "DeviceType", "Joystick");
|
||||||
}
|
// }
|
||||||
else
|
// else
|
||||||
{
|
// {
|
||||||
g_config->setOption (prefix + "DeviceType", "Unknown");
|
// g_config->setOption (prefix + "DeviceType", "Unknown");
|
||||||
}
|
// }
|
||||||
g_config->setOption (prefix + "DeviceNum",
|
// g_config->setOption (prefix + "DeviceNum",
|
||||||
powerpadsc[arg & 1][0].DeviceNum[0]);
|
// powerpadsc[arg & 1][0].DeviceNum);
|
||||||
break;
|
// break;
|
||||||
|
//
|
||||||
case FCFGD_GAMEPAD:
|
// case FCFGD_GAMEPAD:
|
||||||
snprintf (buf, 256, "SDL.Input.GamePad.%d", arg);
|
// snprintf (buf, 256, "SDL.Input.GamePad.%d", arg);
|
||||||
prefix = buf;
|
// prefix = buf;
|
||||||
for (x = 0; x < 10; x++)
|
// for (x = 0; x < 10; x++)
|
||||||
{
|
// {
|
||||||
sprintf (buf, "GamePad #%d: %s", arg + 1, str[x]);
|
// sprintf (buf, "GamePad #%d: %s", arg + 1, str[x]);
|
||||||
ConfigButton (buf, &GamePadConfig[arg][x]);
|
// ConfigButton (buf, &GamePadConfig[arg][x]);
|
||||||
|
//
|
||||||
g_config->setOption (prefix + GamePadNames[x],
|
// g_config->setOption (prefix + GamePadNames[x],
|
||||||
GamePadConfig[arg][x].ButtonNum[0]);
|
// GamePadConfig[arg][x].ButtonNum);
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
if (GamePadConfig[arg][0].ButtType[0] == BUTTC_KEYBOARD)
|
// if (GamePadConfig[arg][0].ButtType == BUTTC_KEYBOARD)
|
||||||
{
|
// {
|
||||||
g_config->setOption (prefix + "DeviceType", "Keyboard");
|
// g_config->setOption (prefix + "DeviceType", "Keyboard");
|
||||||
}
|
// }
|
||||||
else if (GamePadConfig[arg][0].ButtType[0] == BUTTC_JOYSTICK)
|
// else if (GamePadConfig[arg][0].ButtType == BUTTC_JOYSTICK)
|
||||||
{
|
// {
|
||||||
g_config->setOption (prefix + "DeviceType", "Joystick");
|
// g_config->setOption (prefix + "DeviceType", "Joystick");
|
||||||
}
|
// }
|
||||||
else
|
// else
|
||||||
{
|
// {
|
||||||
g_config->setOption (prefix + "DeviceType", "Unknown");
|
// g_config->setOption (prefix + "DeviceType", "Unknown");
|
||||||
}
|
// }
|
||||||
g_config->setOption (prefix + "DeviceNum",
|
// g_config->setOption (prefix + "DeviceNum",
|
||||||
GamePadConfig[arg][0].DeviceNum[0]);
|
// GamePadConfig[arg][0].DeviceNum);
|
||||||
break;
|
// break;
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
ButtonConfigEnd ();
|
// ButtonConfigEnd ();
|
||||||
}
|
//}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Update the button configuration for a device, specified by a text string.
|
* Update the button configuration for a device, specified by a text string.
|
||||||
*/
|
*/
|
||||||
void InputCfg (const std::string & text)
|
//void InputCfg (const std::string & text)
|
||||||
{
|
//{
|
||||||
|
//
|
||||||
// if (noGui)
|
// if (noGui)
|
||||||
// {
|
// {
|
||||||
// if (text.find ("gamepad") != std::string::npos)
|
// if (text.find ("gamepad") != std::string::npos)
|
||||||
|
@ -1960,8 +1947,8 @@ void InputCfg (const std::string & text)
|
||||||
// }
|
// }
|
||||||
// else
|
// else
|
||||||
// printf ("Please run \"fceux --nogui\" before using --inputcfg\n");
|
// printf ("Please run \"fceux --nogui\" before using --inputcfg\n");
|
||||||
|
//
|
||||||
}
|
//}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1973,7 +1960,9 @@ void InputCfg (const std::string & text)
|
||||||
UpdateInput (Config * config)
|
UpdateInput (Config * config)
|
||||||
{
|
{
|
||||||
char buf[64];
|
char buf[64];
|
||||||
std::string device, prefix;
|
std::string device, prefix, guid, mapping;
|
||||||
|
|
||||||
|
InitJoysticks();
|
||||||
|
|
||||||
for (unsigned int i = 0; i < 3; i++)
|
for (unsigned int i = 0; i < 3; i++)
|
||||||
{
|
{
|
||||||
|
@ -2067,36 +2056,17 @@ UpdateInput (Config * config)
|
||||||
prefix = buf;
|
prefix = buf;
|
||||||
|
|
||||||
config->getOption (prefix + "DeviceType", &device );
|
config->getOption (prefix + "DeviceType", &device );
|
||||||
if (device.find ("Keyboard") != std::string::npos)
|
config->getOption (prefix + "DeviceGUID", &guid );
|
||||||
{
|
config->getOption (prefix + "Profile" , &mapping);
|
||||||
type = BUTTC_KEYBOARD;
|
|
||||||
}
|
|
||||||
else if (device.find ("Joystick") != std::string::npos)
|
|
||||||
{
|
|
||||||
type = BUTTC_JOYSTICK;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
type = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
config->getOption (prefix + "DeviceNum", &devnum);
|
GamePad[i].init( i, guid.c_str(), mapping.c_str() );
|
||||||
for (unsigned int j = 0; j < GAMEPAD_NUM_BUTTONS; j++)
|
|
||||||
{
|
|
||||||
config->getOption (prefix + GamePadNames[j], &button);
|
|
||||||
|
|
||||||
GamePadConfig[i][j].ButtType[0] = type;
|
|
||||||
GamePadConfig[i][j].DeviceNum[0] = devnum;
|
|
||||||
GamePadConfig[i][j].ButtonNum[0] = button;
|
|
||||||
GamePadConfig[i][j].NumC = 1;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// PowerPad 0 - 1
|
// PowerPad 0 - 1
|
||||||
for (unsigned int i = 0; i < POWERPAD_NUM_DEVICES; i++)
|
for (unsigned int i = 0; i < POWERPAD_NUM_DEVICES; i++)
|
||||||
{
|
{
|
||||||
char buf[64];
|
char buf[64];
|
||||||
snprintf (buf, 32, "SDL.Input.PowerPad.%u.", i);
|
snprintf (buf, sizeof(buf)-1, "SDL.Input.PowerPad.%u.", i);
|
||||||
prefix = buf;
|
prefix = buf;
|
||||||
|
|
||||||
config->getOption (prefix + "DeviceType", &device);
|
config->getOption (prefix + "DeviceType", &device);
|
||||||
|
@ -2118,10 +2088,9 @@ UpdateInput (Config * config)
|
||||||
{
|
{
|
||||||
config->getOption (prefix + PowerPadNames[j], &button);
|
config->getOption (prefix + PowerPadNames[j], &button);
|
||||||
|
|
||||||
powerpadsc[i][j].ButtType[0] = type;
|
powerpadsc[i][j].ButtType = type;
|
||||||
powerpadsc[i][j].DeviceNum[0] = devnum;
|
powerpadsc[i][j].DeviceNum = devnum;
|
||||||
powerpadsc[i][j].ButtonNum[0] = button;
|
powerpadsc[i][j].ButtonNum = button;
|
||||||
powerpadsc[i][j].NumC = 1;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2145,10 +2114,9 @@ UpdateInput (Config * config)
|
||||||
{
|
{
|
||||||
config->getOption (prefix + QuizKingNames[j], &button);
|
config->getOption (prefix + QuizKingNames[j], &button);
|
||||||
|
|
||||||
QuizKingButtons[j].ButtType[0] = type;
|
QuizKingButtons[j].ButtType = type;
|
||||||
QuizKingButtons[j].DeviceNum[0] = devnum;
|
QuizKingButtons[j].DeviceNum = devnum;
|
||||||
QuizKingButtons[j].ButtonNum[0] = button;
|
QuizKingButtons[j].ButtonNum = button;
|
||||||
QuizKingButtons[j].NumC = 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// HyperShot
|
// HyperShot
|
||||||
|
@ -2171,10 +2139,9 @@ UpdateInput (Config * config)
|
||||||
{
|
{
|
||||||
config->getOption (prefix + HyperShotNames[j], &button);
|
config->getOption (prefix + HyperShotNames[j], &button);
|
||||||
|
|
||||||
HyperShotButtons[j].ButtType[0] = type;
|
HyperShotButtons[j].ButtType = type;
|
||||||
HyperShotButtons[j].DeviceNum[0] = devnum;
|
HyperShotButtons[j].DeviceNum = devnum;
|
||||||
HyperShotButtons[j].ButtonNum[0] = button;
|
HyperShotButtons[j].ButtonNum = button;
|
||||||
HyperShotButtons[j].NumC = 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Mahjong
|
// Mahjong
|
||||||
|
@ -2197,10 +2164,9 @@ UpdateInput (Config * config)
|
||||||
{
|
{
|
||||||
config->getOption (prefix + MahjongNames[j], &button);
|
config->getOption (prefix + MahjongNames[j], &button);
|
||||||
|
|
||||||
MahjongButtons[j].ButtType[0] = type;
|
MahjongButtons[j].ButtType = type;
|
||||||
MahjongButtons[j].DeviceNum[0] = devnum;
|
MahjongButtons[j].DeviceNum = devnum;
|
||||||
MahjongButtons[j].ButtonNum[0] = button;
|
MahjongButtons[j].ButtonNum = button;
|
||||||
MahjongButtons[j].NumC = 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// TopRider
|
// TopRider
|
||||||
|
@ -2223,10 +2189,9 @@ UpdateInput (Config * config)
|
||||||
{
|
{
|
||||||
config->getOption (prefix + TopRiderNames[j], &button);
|
config->getOption (prefix + TopRiderNames[j], &button);
|
||||||
|
|
||||||
TopRiderButtons[j].ButtType[0] = type;
|
TopRiderButtons[j].ButtType = type;
|
||||||
TopRiderButtons[j].DeviceNum[0] = devnum;
|
TopRiderButtons[j].DeviceNum = devnum;
|
||||||
TopRiderButtons[j].ButtonNum[0] = button;
|
TopRiderButtons[j].ButtonNum = button;
|
||||||
TopRiderButtons[j].NumC = 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// FTrainer
|
// FTrainer
|
||||||
|
@ -2249,10 +2214,9 @@ UpdateInput (Config * config)
|
||||||
{
|
{
|
||||||
config->getOption (prefix + FTrainerNames[j], &button);
|
config->getOption (prefix + FTrainerNames[j], &button);
|
||||||
|
|
||||||
FTrainerButtons[j].ButtType[0] = type;
|
FTrainerButtons[j].ButtType = type;
|
||||||
FTrainerButtons[j].DeviceNum[0] = devnum;
|
FTrainerButtons[j].DeviceNum = devnum;
|
||||||
FTrainerButtons[j].ButtonNum[0] = button;
|
FTrainerButtons[j].ButtonNum = button;
|
||||||
FTrainerButtons[j].NumC = 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// FamilyKeyBoard
|
// FamilyKeyBoard
|
||||||
|
@ -2275,10 +2239,9 @@ UpdateInput (Config * config)
|
||||||
{
|
{
|
||||||
config->getOption (prefix + FamilyKeyBoardNames[j], &button);
|
config->getOption (prefix + FamilyKeyBoardNames[j], &button);
|
||||||
|
|
||||||
fkbmap[j].ButtType[0] = type;
|
fkbmap[j].ButtType = type;
|
||||||
fkbmap[j].DeviceNum[0] = devnum;
|
fkbmap[j].DeviceNum = devnum;
|
||||||
fkbmap[j].ButtonNum[0] = button;
|
fkbmap[j].ButtonNum = button;
|
||||||
fkbmap[j].NumC = 1;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
|
|
||||||
#include "common/configSys.h"
|
#include "common/configSys.h"
|
||||||
|
|
||||||
#define MAXBUTTCONFIG 4
|
//#define MAXBUTTCONFIG 4
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
BUTTC_KEYBOARD = 0,
|
BUTTC_KEYBOARD = 0,
|
||||||
|
@ -14,14 +14,14 @@ enum {
|
||||||
};
|
};
|
||||||
struct ButtConfig
|
struct ButtConfig
|
||||||
{
|
{
|
||||||
int ButtType[MAXBUTTCONFIG];
|
int ButtType; //[MAXBUTTCONFIG];
|
||||||
int DeviceNum[MAXBUTTCONFIG];
|
int DeviceNum; //[MAXBUTTCONFIG];
|
||||||
int ButtonNum[MAXBUTTCONFIG];
|
int ButtonNum; //[MAXBUTTCONFIG];
|
||||||
uint32_t NumC;
|
int state;
|
||||||
|
//uint32_t NumC;
|
||||||
//uint64 DeviceID[MAXBUTTCONFIG]; /* TODO */
|
//uint64 DeviceID[MAXBUTTCONFIG]; /* TODO */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
extern int NoWaiting;
|
extern int NoWaiting;
|
||||||
extern CFGSTRUCT InputConfig[];
|
extern CFGSTRUCT InputConfig[];
|
||||||
extern ARGPSTRUCT InputArgs[];
|
extern ARGPSTRUCT InputArgs[];
|
||||||
|
@ -32,7 +32,7 @@ int getKeyState( int k );
|
||||||
int ButtonConfigBegin();
|
int ButtonConfigBegin();
|
||||||
void ButtonConfigEnd();
|
void ButtonConfigEnd();
|
||||||
void ConfigButton(char *text, ButtConfig *bc);
|
void ConfigButton(char *text, ButtConfig *bc);
|
||||||
int DWaitButton(const uint8_t *text, ButtConfig *bc, int wb, int *buttonConfigStatus = NULL);
|
int DWaitButton(const uint8_t *text, ButtConfig *bc, int *buttonConfigStatus = NULL);
|
||||||
|
|
||||||
|
|
||||||
#define FCFGD_GAMEPAD 1
|
#define FCFGD_GAMEPAD 1
|
||||||
|
@ -46,7 +46,7 @@ void InitInputInterface(void);
|
||||||
void InputUserActiveFix(void);
|
void InputUserActiveFix(void);
|
||||||
|
|
||||||
extern bool replaceP2StartWithMicrophone;
|
extern bool replaceP2StartWithMicrophone;
|
||||||
extern ButtConfig GamePadConfig[4][10];
|
//extern ButtConfig GamePadConfig[4][10];
|
||||||
//extern ButtConfig powerpadsc[2][12];
|
//extern ButtConfig powerpadsc[2][12];
|
||||||
//extern ButtConfig QuizKingButtons[6];
|
//extern ButtConfig QuizKingButtons[6];
|
||||||
//extern ButtConfig FTrainerButtons[12];
|
//extern ButtConfig FTrainerButtons[12];
|
||||||
|
@ -59,9 +59,9 @@ int DTestButtonJoy(ButtConfig *bc);
|
||||||
void FCEUD_UpdateInput(void);
|
void FCEUD_UpdateInput(void);
|
||||||
|
|
||||||
void UpdateInput(Config *config);
|
void UpdateInput(Config *config);
|
||||||
void InputCfg(const std::string &);
|
//void InputCfg(const std::string &);
|
||||||
|
|
||||||
std::string GetUserText(const char* title);
|
std::string GetUserText(const char* title);
|
||||||
const char* ButtonName(const ButtConfig* bc, int which);
|
const char* ButtonName(const ButtConfig* bc);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,92 @@
|
||||||
|
// sdl-joystick.h
|
||||||
|
|
||||||
|
#ifndef __SDL_JOYSTICK_H__
|
||||||
|
#define __SDL_JOYSTICK_H__
|
||||||
|
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
#include "Qt/main.h"
|
||||||
|
#include "Qt/input.h"
|
||||||
|
#include "Qt/sdl.h"
|
||||||
|
|
||||||
|
#define MAX_JOYSTICKS 32
|
||||||
|
|
||||||
|
struct nesGamePadMap_t
|
||||||
|
{
|
||||||
|
char guid[64];
|
||||||
|
char name[128];
|
||||||
|
char btn[GAMEPAD_NUM_BUTTONS][32];
|
||||||
|
char os[64];
|
||||||
|
|
||||||
|
nesGamePadMap_t(void);
|
||||||
|
~nesGamePadMap_t(void);
|
||||||
|
|
||||||
|
void clearMapping(void);
|
||||||
|
int parseMapping( const char *text );
|
||||||
|
};
|
||||||
|
|
||||||
|
struct jsDev_t
|
||||||
|
{
|
||||||
|
SDL_Joystick *js;
|
||||||
|
SDL_GameController *gc;
|
||||||
|
|
||||||
|
jsDev_t(void);
|
||||||
|
//~jsDev_t(void);
|
||||||
|
|
||||||
|
void init( int idx );
|
||||||
|
int close(void);
|
||||||
|
SDL_Joystick *getJS(void);
|
||||||
|
bool isGameController(void);
|
||||||
|
bool isConnected(void);
|
||||||
|
void print(void);
|
||||||
|
int bindPort( int idx );
|
||||||
|
int unbindPort( int idx );
|
||||||
|
int getBindPorts(void);
|
||||||
|
const char *getName(void);
|
||||||
|
const char *getGUID(void);
|
||||||
|
|
||||||
|
private:
|
||||||
|
int devIdx;
|
||||||
|
int portBindMask;
|
||||||
|
std::string guidStr;
|
||||||
|
std::string name;
|
||||||
|
};
|
||||||
|
|
||||||
|
class GamePad_t
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
|
||||||
|
ButtConfig bmap[GAMEPAD_NUM_BUTTONS];
|
||||||
|
|
||||||
|
GamePad_t(void);
|
||||||
|
~GamePad_t(void);
|
||||||
|
|
||||||
|
int init( int port, const char *guid, const char *profile = NULL );
|
||||||
|
const char *getGUID(void);
|
||||||
|
|
||||||
|
int loadDefaults(void);
|
||||||
|
int loadProfile( const char *name, const char *guid = NULL );
|
||||||
|
|
||||||
|
int getDeviceIndex(void){ return devIdx; }
|
||||||
|
int setDeviceIndex( int devIdx );
|
||||||
|
int setMapping( const char *map );
|
||||||
|
int setMapping( nesGamePadMap_t *map );
|
||||||
|
|
||||||
|
int createProfile( const char *name );
|
||||||
|
int getMapFromFile( const char *filename, char *out );
|
||||||
|
int getDefaultMap( char *out, const char *guid = NULL );
|
||||||
|
int saveMappingToFile( const char *filename, const char *txtMap );
|
||||||
|
int saveCurrentMapToFile( const char *filename );
|
||||||
|
int deleteMapping( const char *name );
|
||||||
|
|
||||||
|
private:
|
||||||
|
int devIdx;
|
||||||
|
int portNum;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
extern GamePad_t GamePad[4];
|
||||||
|
|
||||||
|
jsDev_t *getJoystickDevice( int devNum );
|
||||||
|
|
||||||
|
#endif
|
|
@ -465,6 +465,11 @@ void FCEUI_SetBaseDirectory(std::string const & dir)
|
||||||
{
|
{
|
||||||
BaseDirectory = dir;
|
BaseDirectory = dir;
|
||||||
}
|
}
|
||||||
|
/// Gets the base directory
|
||||||
|
const char *FCEUI_GetBaseDirectory(void)
|
||||||
|
{
|
||||||
|
return BaseDirectory.c_str();
|
||||||
|
}
|
||||||
|
|
||||||
static char *odirs[FCEUIOD__COUNT]={0,0,0,0,0,0,0,0,0,0,0,0,0}; // odirs, odors. ^_^
|
static char *odirs[FCEUIOD__COUNT]={0,0,0,0,0,0,0,0,0,0,0,0,0}; // odirs, odors. ^_^
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue