directsoundengine: add device selection.

directdrawblitter: only list devices if there are more than 2 devices (including primary)
directdrawblitter: use private static member rather than global friend enumeration callback
capitalization changes


git-svn-id: https://gambatte.svn.sourceforge.net/svnroot/gambatte@139 9dfb2916-2d38-0410-aef4-c5fe6c9ffc24
This commit is contained in:
sinamas 2008-03-19 14:23:01 +00:00
parent cdf2af953a
commit 37161f3599
7 changed files with 71 additions and 17 deletions

View File

@ -18,25 +18,70 @@
***************************************************************************/
#include "directsoundengine.h"
// #include <iostream>
#include <cstring>
#include <QWidget>
#include <QCheckBox>
#include <QComboBox>
#include <QLabel>
#include <QVBoxLayout>
#include <QHBoxLayout>
#include <QSettings>
DirectSoundEngine::DirectSoundEngine(HWND hwnd_in)
: AudioEngine("DirectSound"), confWidget(new QWidget), globalBufBox(new QCheckBox("Global buffer")),
lpDS(NULL), lpDSB(NULL), hwnd(hwnd_in), useGlobalBuf(false)
Q_DECLARE_METATYPE(GUID*)
BOOL CALLBACK DirectSoundEngine::enumCallback(LPGUID lpGuid, const char *lpcstrDescription, const char */*lpcstrModule*/, LPVOID lpContext) {
if (lpGuid) {
DirectSoundEngine *const thisptr = static_cast<DirectSoundEngine*>(lpContext);
thisptr->deviceList.append(*lpGuid);
thisptr->deviceSelector->addItem(lpcstrDescription, QVariant::fromValue(&thisptr->deviceList.last()));
}
return true;
}
DirectSoundEngine::DirectSoundEngine(HWND hwnd_in) :
AudioEngine("DirectSound"),
confWidget(new QWidget),
globalBufBox(new QCheckBox("Global buffer")),
deviceSelector(new QComboBox),
lpDS(NULL),
lpDSB(NULL),
bufSize(0),
deviceIndex(0),
offset(0),
hwnd(hwnd_in),
useGlobalBuf(false)
{
confWidget->setLayout(new QVBoxLayout);
confWidget->layout()->setMargin(0);
confWidget->layout()->addWidget(globalBufBox);
DirectSoundEnumerateA(enumCallback, this);
if (deviceSelector->count() < 1)
deviceSelector->addItem(QString(), QVariant::fromValue<GUID*>(NULL));
{
QVBoxLayout *const mainLayout = new QVBoxLayout;
mainLayout->setMargin(0);
if (deviceSelector->count() > 1) {
QHBoxLayout *const hlayout = new QHBoxLayout;
hlayout->addWidget(new QLabel(QString("DirectSound device:")));
hlayout->addWidget(deviceSelector);
mainLayout->addLayout(hlayout);
}
mainLayout->addWidget(globalBufBox);
confWidget->setLayout(mainLayout);
}
{
QSettings settings;
settings.beginGroup("directsoundengine");
useGlobalBuf = settings.value("useGlobalBuf", useGlobalBuf).toBool();
if ((deviceIndex = settings.value("deviceIndex", deviceIndex).toUInt()) >= static_cast<unsigned>(deviceSelector->count()))
deviceIndex = 0;
settings.endGroup();
}
@ -49,15 +94,18 @@ DirectSoundEngine::~DirectSoundEngine() {
QSettings settings;
settings.beginGroup("directsoundengine");
settings.setValue("useGlobalBuf", useGlobalBuf);
settings.setValue("deviceIndex", deviceIndex);
settings.endGroup();
}
void DirectSoundEngine::acceptSettings() {
useGlobalBuf = globalBufBox->isChecked();
deviceIndex = deviceSelector->currentIndex();
}
void DirectSoundEngine::rejectSettings() {
globalBufBox->setChecked(useGlobalBuf);
deviceSelector->setCurrentIndex(deviceIndex);
}
static unsigned nearestPowerOf2(const unsigned in) {
@ -77,7 +125,7 @@ static unsigned nearestPowerOf2(const unsigned in) {
}
int DirectSoundEngine::init(const int rate, const unsigned latency) {
if (DirectSoundCreate(NULL, &lpDS, NULL) != DS_OK) {
if (DirectSoundCreate(deviceSelector->itemData(deviceIndex).value<GUID*>(), &lpDS, NULL) != DS_OK) {
lpDS = NULL;
goto fail;
}

View File

@ -20,21 +20,28 @@
#define DIRECTSOUNDENGINE_H
class QCheckBox;
class QComboBox;
#include "../audioengine.h"
#include <QList>
#include <memory>
#include <dsound.h>
class DirectSoundEngine : public AudioEngine {
const std::auto_ptr<QWidget> confWidget;
QCheckBox *const globalBufBox;
QComboBox *const deviceSelector;
LPDIRECTSOUND lpDS;
LPDIRECTSOUNDBUFFER lpDSB;
QList<GUID> deviceList;
unsigned bufSize;
unsigned deviceIndex;
DWORD offset;
HWND hwnd;
bool useGlobalBuf;
static BOOL CALLBACK enumCallback(LPGUID, const char*, const char*, LPVOID);
public:
DirectSoundEngine(HWND hwnd);
~DirectSoundEngine();

View File

@ -29,7 +29,7 @@
Q_DECLARE_METATYPE(GUID*)
BOOL WINAPI enumCallback(GUID FAR *lpGUID, char *lpDriverDescription, char */*lpDriverName*/, LPVOID lpContext, HMONITOR) {
BOOL WINAPI DirectDrawBlitter::enumCallback(GUID FAR *lpGUID, char *lpDriverDescription, char */*lpDriverName*/, LPVOID lpContext, HMONITOR) {
DirectDrawBlitter *const thisptr = static_cast<DirectDrawBlitter*>(lpContext);
GUID *guidptr = NULL;
@ -85,7 +85,7 @@ DirectDrawBlitter::DirectDrawBlitter(PixelBufferSetter setPixelBuffer, QWidget *
QVBoxLayout *const mainLayout = new QVBoxLayout;
mainLayout->setMargin(0);
if (deviceSelector->count() > 1) {
if (deviceSelector->count() > 2) {
QHBoxLayout *const hlayout = new QHBoxLayout;
hlayout->addWidget(new QLabel(QString(tr("DirectDraw device:"))));

View File

@ -28,8 +28,6 @@ class QCheckBox;
class QComboBox;
class DirectDrawBlitter : public BlitterWidget {
friend BOOL WINAPI enumCallback(GUID FAR *, char*, char*, LPVOID, HMONITOR);
const std::auto_ptr<QWidget> confWidget;
QCheckBox *const vblankBox;
QCheckBox *const flippingBox;
@ -53,6 +51,7 @@ class DirectDrawBlitter : public BlitterWidget {
bool exclusive;
bool flipping;
static BOOL WINAPI enumCallback(GUID FAR *, char*, char*, LPVOID, HMONITOR);
bool initPrimarySurface();
bool initVideoSurface();
bool restoreSurfaces();

View File

@ -33,7 +33,7 @@ int main(int argc, char *argv[]) {
source.generateButtonLabels(),
source.generateButtonDefaults(),
source.generateVideoSourceInfos(),
"Video Filter:",
"Video filter:",
QSize(160, 144),
source.generateSampleRates());
GambatteMenuHandler mh(mw, &source, argc, argv);

View File

@ -53,7 +53,7 @@ SoundDialog::SoundDialog(const std::vector<AudioEngine*> &engines, const std::ve
{
QHBoxLayout *const hLayout = new QHBoxLayout;
hLayout->addWidget(new QLabel(tr("Sound Engine:")));
hLayout->addWidget(new QLabel(tr("Sound engine:")));
for (std::size_t i = 0; i < engines.size(); ++i)
engineSelector->addItem(engines[i]->nameString);
@ -64,7 +64,7 @@ SoundDialog::SoundDialog(const std::vector<AudioEngine*> &engines, const std::ve
{
QHBoxLayout *const hLayout = new QHBoxLayout;
hLayout->addWidget(new QLabel(tr("Sample Rate:")));
hLayout->addWidget(new QLabel(tr("Sample rate:")));
for (unsigned i = 0; i < rates.size(); ++i)
rateSelector->addItem(QString::number(rates[i]) + " Hz", rates[i]);
@ -75,7 +75,7 @@ SoundDialog::SoundDialog(const std::vector<AudioEngine*> &engines, const std::ve
{
QHBoxLayout *const hLayout = new QHBoxLayout;
hLayout->addWidget(new QLabel(tr("Buffer Latency:")));
hLayout->addWidget(new QLabel(tr("Buffer latency:")));
latencySelector->setRange(4, 999);
latencySelector->setSuffix(" ms");
hLayout->addWidget(latencySelector);

View File

@ -87,7 +87,7 @@ sourceIndexStore(0)
for (unsigned i = 0; i < hzSelector.size(); ++i) {
hLayout = new QHBoxLayout;
hLayout->addWidget(new QLabel("Full Screen mode (screen " + QString::number(i) + "):"));
hLayout->addWidget(new QLabel("Full screen mode (screen " + QString::number(i) + "):"));
QHBoxLayout *hhLayout = new QHBoxLayout;
hhLayout->addWidget((fullResSelector[i] = new QComboBox));
hhLayout->addWidget((hzSelector[i] = new QComboBox));