Successful test of basic gamepad button remapping to keyboard sequences.
This commit is contained in:
parent
16fc02daaf
commit
c753820d32
|
@ -623,7 +623,7 @@ void GamePadConfDialog_t::refreshKeyBindTree( bool reset )
|
|||
}
|
||||
|
||||
item->setText(0, tr(btnSeq));
|
||||
//item->setText(1, QString::fromStdString(keyName));
|
||||
item->setText(1, QString::fromStdString(binding->keySeq[0].name));
|
||||
|
||||
item->setTextAlignment(0, Qt::AlignLeft);
|
||||
item->setTextAlignment(1, Qt::AlignLeft);
|
||||
|
@ -1528,8 +1528,9 @@ GamePadFuncConfigDialog::GamePadFuncConfigDialog( gamepad_function_key_t *fk, QW
|
|||
QVBoxLayout *mainLayout, *vbox;
|
||||
QGridLayout *grid;
|
||||
QLabel *lbl;
|
||||
QGroupBox *frame;
|
||||
QPushButton *okButton, *cancelButton;
|
||||
QPushButton *clearButton[3];
|
||||
QPushButton *clearButton[4];
|
||||
|
||||
if ( fk == NULL )
|
||||
{
|
||||
|
@ -1544,35 +1545,47 @@ GamePadFuncConfigDialog::GamePadFuncConfigDialog( gamepad_function_key_t *fk, QW
|
|||
|
||||
if ( editMode )
|
||||
{
|
||||
setWindowTitle( tr("Edit Function") );
|
||||
setWindowTitle( tr("Edit Gamepad Key Mapping") );
|
||||
}
|
||||
else
|
||||
{
|
||||
setWindowTitle( tr("Add Function") );
|
||||
setWindowTitle( tr("Add Gamepad Key Mapping") );
|
||||
}
|
||||
|
||||
btnLbl[0] = new QLineEdit();
|
||||
btnLbl[1] = new QLineEdit();
|
||||
keySeqLbl = new QLineEdit();
|
||||
keySeqLbl[0] = new QLineEdit();
|
||||
keySeqLbl[1] = new QLineEdit();
|
||||
|
||||
btnLbl[0]->setReadOnly(true);
|
||||
btnLbl[1]->setReadOnly(true);
|
||||
keySeqLbl->setReadOnly(true);
|
||||
keySeqLbl[0]->setReadOnly(true);
|
||||
keySeqLbl[1]->setReadOnly(true);
|
||||
|
||||
btnLbl[0]->setAlignment( Qt::AlignCenter );
|
||||
btnLbl[1]->setAlignment( Qt::AlignCenter );
|
||||
keySeqLbl[0]->setAlignment( Qt::AlignCenter );
|
||||
keySeqLbl[1]->setAlignment( Qt::AlignCenter );
|
||||
|
||||
b[0] = new GamePadConfigButton_t(0);
|
||||
b[1] = new GamePadConfigButton_t(1);
|
||||
hk = new GamePadConfigHotKey_t(k);
|
||||
hk[0] = new GamePadConfigHotKey_t(0,k);
|
||||
hk[1] = new GamePadConfigHotKey_t(1,k);
|
||||
|
||||
clearButton[0] = new QPushButton( tr("Clear") );
|
||||
clearButton[1] = new QPushButton( tr("Clear") );
|
||||
clearButton[2] = new QPushButton( tr("Clear") );
|
||||
clearButton[3] = new QPushButton( tr("Clear") );
|
||||
|
||||
mainLayout = new QVBoxLayout();
|
||||
|
||||
setLayout(mainLayout);
|
||||
|
||||
frame = new QGroupBox( tr("Game Pad Button Sequence:") );
|
||||
mainLayout->addWidget( frame );
|
||||
|
||||
grid = new QGridLayout();
|
||||
mainLayout->addLayout( grid );
|
||||
frame->setLayout( grid );
|
||||
|
||||
//grid->setColumnMinimumWidth( 1, 20 );
|
||||
|
||||
|
@ -1586,18 +1599,33 @@ GamePadFuncConfigDialog::GamePadFuncConfigDialog( gamepad_function_key_t *fk, QW
|
|||
grid->addWidget( b[1], 1, 2 );
|
||||
grid->addWidget( clearButton[1], 1, 3 );
|
||||
|
||||
grid->addWidget( new QLabel( tr("Key Sequence:") ), 2, 0 );
|
||||
grid->addWidget( keySeqLbl, 2, 1 );
|
||||
grid->addWidget( hk, 2, 2 );
|
||||
grid->addWidget( clearButton[2], 2, 3 );
|
||||
frame = new QGroupBox( tr("Maps to Key Sequence:") );
|
||||
mainLayout->addWidget( frame );
|
||||
|
||||
grid = new QGridLayout();
|
||||
frame->setLayout( grid );
|
||||
|
||||
grid->addWidget( new QLabel( tr("On Press:") ), 0, 0 );
|
||||
grid->addWidget( keySeqLbl[0], 0, 1 );
|
||||
grid->addWidget( hk[0], 0, 2 );
|
||||
grid->addWidget( clearButton[2], 0, 3 );
|
||||
|
||||
grid->addWidget( new QLabel( tr("On Release:") ), 1, 0 );
|
||||
grid->addWidget( keySeqLbl[1], 1, 1 );
|
||||
grid->addWidget( hk[1], 1, 2 );
|
||||
grid->addWidget( clearButton[3], 1, 3 );
|
||||
|
||||
hbox = new QHBoxLayout();
|
||||
okButton = new QPushButton( tr("OK") );
|
||||
cancelButton = new QPushButton( tr("Cancel") );
|
||||
|
||||
okButton->setIcon(style()->standardIcon(QStyle::SP_DialogApplyButton));
|
||||
cancelButton->setIcon(style()->standardIcon(QStyle::SP_DialogCancelButton));
|
||||
|
||||
mainLayout->addLayout( hbox );
|
||||
hbox->addWidget( cancelButton );
|
||||
hbox->addWidget( okButton );
|
||||
hbox->addWidget( cancelButton, 1 );
|
||||
hbox->addStretch( 5 );
|
||||
hbox->addWidget( okButton, 1 );
|
||||
|
||||
connect( okButton, SIGNAL(clicked(void)), this, SLOT(acceptCB(void)) );
|
||||
connect( cancelButton, SIGNAL(clicked(void)), this, SLOT(rejectCB(void)) );
|
||||
|
@ -1607,9 +1635,18 @@ GamePadFuncConfigDialog::GamePadFuncConfigDialog( gamepad_function_key_t *fk, QW
|
|||
//ret = dialog.exec();
|
||||
buttonConfigStatus = 0;
|
||||
|
||||
connect( b[0], SIGNAL(clicked(void)), this, SLOT(changeButton0(void)) );
|
||||
connect( b[1], SIGNAL(clicked(void)), this, SLOT(changeButton1(void)) );
|
||||
connect( hk, SIGNAL(clicked(void)), this, SLOT(changeKeySeq(void) ) );
|
||||
connect( b[0] , SIGNAL(clicked(void)), this, SLOT(changeButton0(void)) );
|
||||
connect( b[1] , SIGNAL(clicked(void)), this, SLOT(changeButton1(void)) );
|
||||
connect( hk[0], SIGNAL(clicked(void)), this, SLOT(changeKeySeq0(void) ) );
|
||||
connect( hk[1], SIGNAL(clicked(void)), this, SLOT(changeKeySeq1(void) ) );
|
||||
|
||||
connect( clearButton[0], SIGNAL(clicked(void)), this, SLOT(clearButton0(void)) );
|
||||
connect( clearButton[1], SIGNAL(clicked(void)), this, SLOT(clearButton1(void)) );
|
||||
connect( clearButton[2], SIGNAL(clicked(void)), this, SLOT(clearButton2(void)) );
|
||||
connect( clearButton[3], SIGNAL(clicked(void)), this, SLOT(clearButton3(void)) );
|
||||
|
||||
hk[0]->setKeyNameLbl( keySeqLbl[0] );
|
||||
hk[1]->setKeyNameLbl( keySeqLbl[1] );
|
||||
}
|
||||
//----------------------------------------------------
|
||||
GamePadFuncConfigDialog::~GamePadFuncConfigDialog(void)
|
||||
|
@ -1707,36 +1744,90 @@ void GamePadFuncConfigDialog::changeButton1(void)
|
|||
changeButton(1);
|
||||
}
|
||||
//----------------------------------------------------
|
||||
void GamePadFuncConfigDialog::changeKeySeq(void)
|
||||
void GamePadFuncConfigDialog::changeKeySeq0(void)
|
||||
{
|
||||
hk->setCaptureState(true);
|
||||
hk->setStyleSheet("background-color: green; color: white;");
|
||||
hk[0]->setCaptureState(true);
|
||||
hk[0]->setStyleSheet("background-color: green; color: white;");
|
||||
}
|
||||
//----------------------------------------------------
|
||||
GamePadConfigHotKey_t::GamePadConfigHotKey_t(gamepad_function_key_t *fk)
|
||||
void GamePadFuncConfigDialog::changeKeySeq1(void)
|
||||
{
|
||||
hk[1]->setCaptureState(true);
|
||||
hk[1]->setStyleSheet("background-color: green; color: white;");
|
||||
}
|
||||
//----------------------------------------------------
|
||||
void GamePadFuncConfigDialog::clearButton0(void)
|
||||
{
|
||||
k->bmap[0].ButtType = -1;
|
||||
k->bmap[0].DeviceNum = -1;
|
||||
k->bmap[0].ButtonNum = -1;
|
||||
k->bmap[0].state = 0;
|
||||
|
||||
btnLbl[0]->clear();
|
||||
}
|
||||
//----------------------------------------------------
|
||||
void GamePadFuncConfigDialog::clearButton1(void)
|
||||
{
|
||||
k->bmap[1].ButtType = -1;
|
||||
k->bmap[1].DeviceNum = -1;
|
||||
k->bmap[1].ButtonNum = -1;
|
||||
k->bmap[1].state = 0;
|
||||
|
||||
btnLbl[1]->clear();
|
||||
}
|
||||
//----------------------------------------------------
|
||||
void GamePadFuncConfigDialog::clearButton2(void)
|
||||
{
|
||||
k->keySeq[0].key = 0;
|
||||
k->keySeq[0].modifier = 0;
|
||||
k->keySeq[0].name.clear();
|
||||
}
|
||||
//----------------------------------------------------
|
||||
void GamePadFuncConfigDialog::clearButton3(void)
|
||||
{
|
||||
k->keySeq[1].key = 0;
|
||||
k->keySeq[1].modifier = 0;
|
||||
k->keySeq[1].name.clear();
|
||||
}
|
||||
//----------------------------------------------------
|
||||
GamePadConfigHotKey_t::GamePadConfigHotKey_t(int idxIn, gamepad_function_key_t *fk)
|
||||
{
|
||||
setText("Change");
|
||||
|
||||
k = fk;
|
||||
|
||||
keySeqLbl = NULL;
|
||||
captureState = false;
|
||||
idx = idxIn;
|
||||
}
|
||||
//----------------------------------------------------
|
||||
void GamePadConfigHotKey_t::setKeyNameLbl( QLineEdit *lbl )
|
||||
{
|
||||
keySeqLbl = lbl;
|
||||
}
|
||||
//----------------------------------------------------
|
||||
void GamePadConfigHotKey_t::keyPressEvent(QKeyEvent *event)
|
||||
{
|
||||
printf("GamePad Hot Key Press: 0x%x '%s'\n", event->key(), event->text().toStdString().c_str() );
|
||||
//printf("GamePad Hot Key Press: 0x%x '%s'\n", event->key(), event->text().toStdString().c_str() );
|
||||
//pushKeyEvent(event, 1);
|
||||
|
||||
if ( captureState )
|
||||
{
|
||||
k->qKey = event->key();
|
||||
k->qModifier = event->modifiers();
|
||||
QKeySequence ks( event->modifiers() + event->key() );
|
||||
|
||||
k->keySeq[idx].key = event->key();
|
||||
k->keySeq[idx].modifier = event->modifiers();
|
||||
k->keySeq[idx].name = ks.toString().toStdString();
|
||||
|
||||
if ( keySeqLbl )
|
||||
{
|
||||
keySeqLbl->setText( ks.toString() );
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void GamePadConfigHotKey_t::keyReleaseEvent(QKeyEvent *event)
|
||||
{
|
||||
printf("GamePad Hot Key Release: 0x%x \n", event->key() );
|
||||
//printf("GamePad Hot Key Release: 0x%x \n", event->key() );
|
||||
//pushKeyEvent(event, 0);
|
||||
|
||||
captureState = false;
|
||||
|
|
|
@ -36,14 +36,17 @@ protected:
|
|||
class GamePadConfigHotKey_t : public QPushButton
|
||||
{
|
||||
public:
|
||||
GamePadConfigHotKey_t( gamepad_function_key_t *k );
|
||||
GamePadConfigHotKey_t( int idx, gamepad_function_key_t *k );
|
||||
|
||||
void setCaptureState(bool s){ captureState = s; };
|
||||
|
||||
void setKeyNameLbl( QLineEdit *lbl );
|
||||
protected:
|
||||
void keyPressEvent(QKeyEvent *event);
|
||||
void keyReleaseEvent(QKeyEvent *event);
|
||||
|
||||
int idx;
|
||||
QLineEdit *keySeqLbl;
|
||||
gamepad_function_key_t *k;
|
||||
bool captureState;
|
||||
};
|
||||
|
@ -62,10 +65,10 @@ protected:
|
|||
void changeButton(int x);
|
||||
|
||||
QLineEdit *btnLbl[2];
|
||||
QLineEdit *keySeqLbl;
|
||||
QLineEdit *keySeqLbl[2];
|
||||
|
||||
GamePadConfigButton_t *b[2];
|
||||
GamePadConfigHotKey_t *hk;
|
||||
GamePadConfigHotKey_t *hk[2];
|
||||
gamepad_function_key_t *k;
|
||||
|
||||
int buttonConfigStatus;
|
||||
|
@ -78,7 +81,12 @@ private slots:
|
|||
void rejectCB(void);
|
||||
void changeButton0(void);
|
||||
void changeButton1(void);
|
||||
void changeKeySeq(void);
|
||||
void changeKeySeq0(void);
|
||||
void changeKeySeq1(void);
|
||||
void clearButton0(void);
|
||||
void clearButton1(void);
|
||||
void clearButton2(void);
|
||||
void clearButton3(void);
|
||||
};
|
||||
|
||||
class GamePadView_t : public QWidget
|
||||
|
|
|
@ -64,6 +64,7 @@ static int cspec = 0;
|
|||
static int buttonConfigInProgress = 0;
|
||||
|
||||
extern int gametype;
|
||||
static int DTestButton (ButtConfig * bc);
|
||||
|
||||
std::list <gamepad_function_key_t*> gpKeySeqList;
|
||||
|
||||
|
@ -412,8 +413,16 @@ setHotKeys (void)
|
|||
|
||||
gamepad_function_key_t::gamepad_function_key_t(void)
|
||||
{
|
||||
qKey = 0;
|
||||
qModifier = Qt::NoModifier;
|
||||
for (int i=0; i<2; i++)
|
||||
{
|
||||
keySeq[i].key = 0;
|
||||
keySeq[i].modifier = Qt::NoModifier;
|
||||
}
|
||||
for (int i=0; i<2; i++)
|
||||
{
|
||||
bmap[i].ButtonNum = -1;
|
||||
bmap[i].state = 0;
|
||||
}
|
||||
}
|
||||
|
||||
gamepad_function_key_t::~gamepad_function_key_t(void)
|
||||
|
@ -421,20 +430,64 @@ gamepad_function_key_t::~gamepad_function_key_t(void)
|
|||
|
||||
}
|
||||
|
||||
void gamepad_function_key_t::sendKeyPressEvent(void)
|
||||
void gamepad_function_key_t::sendKeyPressEvent(int idx)
|
||||
{
|
||||
QKeyEvent *k = new QKeyEvent (QEvent::KeyPress, qKey, (Qt::KeyboardModifiers)qModifier );
|
||||
QKeyEvent *k = new QKeyEvent (QEvent::KeyPress, keySeq[idx].key, (Qt::KeyboardModifiers)keySeq[idx].modifier );
|
||||
|
||||
qApp->postEvent((QObject*)consoleWindow,(QEvent *)k);
|
||||
}
|
||||
|
||||
void gamepad_function_key_t::sendKeyReleaseEvent(void)
|
||||
void gamepad_function_key_t::sendKeyReleaseEvent(int idx)
|
||||
{
|
||||
QKeyEvent *k = new QKeyEvent (QEvent::KeyRelease, qKey, (Qt::KeyboardModifiers)qModifier );
|
||||
QKeyEvent *k = new QKeyEvent (QEvent::KeyRelease, keySeq[idx].key, (Qt::KeyboardModifiers)keySeq[idx].modifier );
|
||||
|
||||
qApp->postEvent((QObject*)consoleWindow,(QEvent *)k);
|
||||
}
|
||||
|
||||
void gamepad_function_key_t::updateStatus(void)
|
||||
{
|
||||
int state_lp[2], state[2];
|
||||
|
||||
state_lp[0] = bmap[0].state;
|
||||
state_lp[1] = bmap[1].state;
|
||||
|
||||
state[0] = DTestButton( &bmap[0] );
|
||||
state[1] = DTestButton( &bmap[1] );
|
||||
|
||||
if ( (bmap[0].ButtonNum >= 0) && (bmap[1].ButtonNum >= 0) )
|
||||
{
|
||||
int s,lp;
|
||||
|
||||
s = state[0] && state[1];
|
||||
lp = state_lp[0] && state_lp[1];
|
||||
|
||||
if ( s && !lp )
|
||||
{
|
||||
sendKeyPressEvent(0);
|
||||
}
|
||||
else if ( !s && lp )
|
||||
{
|
||||
sendKeyReleaseEvent(0);
|
||||
sendKeyPressEvent(1);
|
||||
sendKeyReleaseEvent(1);
|
||||
}
|
||||
}
|
||||
else if ( bmap[1].ButtonNum >= 0 )
|
||||
{
|
||||
if ( state[1] && !state_lp[1] )
|
||||
{
|
||||
sendKeyPressEvent(0);
|
||||
}
|
||||
else if ( !state[1] && state_lp[1] )
|
||||
{
|
||||
sendKeyReleaseEvent(0);
|
||||
sendKeyPressEvent(1);
|
||||
sendKeyReleaseEvent(1);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/***
|
||||
* This function is a wrapper for FCEUI_ToggleEmulationPause that handles
|
||||
* releasing/capturing mouse pointer during pause toggles
|
||||
|
@ -1393,6 +1446,16 @@ static int32 MouseRelative[3] = { 0, 0, 0 };
|
|||
|
||||
static uint8 fkbkeys[0x48];
|
||||
|
||||
static void updateGamePadKeyMappings(void)
|
||||
{
|
||||
std::list <gamepad_function_key_t*>::iterator it;
|
||||
|
||||
for (it=gpKeySeqList.begin(); it!=gpKeySeqList.end(); it++)
|
||||
{
|
||||
(*it)->updateStatus();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Update all of the input devices required for the active game.
|
||||
*/
|
||||
|
@ -1405,6 +1468,9 @@ void FCEUD_UpdateInput(void)
|
|||
{
|
||||
return;
|
||||
}
|
||||
|
||||
updateGamePadKeyMappings();
|
||||
|
||||
UpdatePhysicalInput ();
|
||||
KeyboardCommands ();
|
||||
|
||||
|
|
|
@ -54,16 +54,22 @@ extern struct hotkey_t Hotkeys[];
|
|||
|
||||
struct gamepad_function_key_t
|
||||
{
|
||||
int qKey;
|
||||
unsigned int qModifier;
|
||||
struct {
|
||||
int key;
|
||||
unsigned int modifier;
|
||||
std::string name;
|
||||
|
||||
} keySeq[2];
|
||||
|
||||
struct ButtConfig bmap[2];
|
||||
|
||||
gamepad_function_key_t(void);
|
||||
~gamepad_function_key_t(void);
|
||||
|
||||
void sendKeyPressEvent(void);
|
||||
void sendKeyReleaseEvent(void);
|
||||
void sendKeyPressEvent(int idx);
|
||||
void sendKeyReleaseEvent(int idx);
|
||||
|
||||
void updateStatus(void);
|
||||
};
|
||||
|
||||
extern std::list <gamepad_function_key_t*> gpKeySeqList;
|
||||
|
|
Loading…
Reference in New Issue