mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-11 00:29:11 +01:00
just some minor cleanup (texdecoder, dsoundstream)
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@2394 8ced0084-cf51-0410-be5f-012b33b47a6e
This commit is contained in:
parent
a09a3e08f1
commit
3b7875bf3f
@ -22,13 +22,12 @@
|
|||||||
#include "TextureDecoder.h"
|
#include "TextureDecoder.h"
|
||||||
#include "LookUpTables.h"
|
#include "LookUpTables.h"
|
||||||
|
|
||||||
//Uncomment this to enable Texture Format ID overlays
|
|
||||||
#define OVERLAY_TEXFMT
|
|
||||||
|
|
||||||
#ifdef OVERLAY_TEXFMT
|
|
||||||
bool TexFmt_Overlay_Enable=false;
|
bool TexFmt_Overlay_Enable=false;
|
||||||
bool TexFmt_Overlay_Center=false;
|
bool TexFmt_Overlay_Center=false;
|
||||||
#endif
|
|
||||||
|
extern const char* texfmt[];
|
||||||
|
extern const unsigned char sfont_map[];
|
||||||
|
extern const unsigned char sfont_raw[][9*10];
|
||||||
|
|
||||||
// TRAM
|
// TRAM
|
||||||
// STATE_TO_SAVE
|
// STATE_TO_SAVE
|
||||||
@ -344,11 +343,7 @@ void decodeDXTBlock(u32 *dst, const DXTBlock *src, int pitch)
|
|||||||
//TODO: to save memory, don't blindly convert everything to argb8888
|
//TODO: to save memory, don't blindly convert everything to argb8888
|
||||||
//also ARGB order needs to be swapped later, to accommodate modern hardware better
|
//also ARGB order needs to be swapped later, to accommodate modern hardware better
|
||||||
//need to add DXT support too
|
//need to add DXT support too
|
||||||
#ifdef OVERLAY_TEXFMT
|
|
||||||
PC_TexFormat TexDecoder_Decode_real(u8 *dst, const u8 *src, int width, int height, int texformat, int tlutaddr, int tlutfmt)
|
PC_TexFormat TexDecoder_Decode_real(u8 *dst, const u8 *src, int width, int height, int texformat, int tlutaddr, int tlutfmt)
|
||||||
#else
|
|
||||||
PC_TexFormat TexDecoder_Decode(u8 *dst, const u8 *src, int width, int height, int texformat, int tlutaddr, int tlutfmt)
|
|
||||||
#endif
|
|
||||||
{
|
{
|
||||||
switch (texformat)
|
switch (texformat)
|
||||||
{
|
{
|
||||||
@ -491,16 +486,10 @@ void TexDecoder_SetTexFmtOverlayOptions(bool enable, bool center)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef OVERLAY_TEXFMT
|
|
||||||
extern const char* texfmt[];
|
|
||||||
extern const unsigned char sfont_map[];
|
|
||||||
extern const unsigned char sfont_raw[][9*10];
|
|
||||||
|
|
||||||
PC_TexFormat TexDecoder_Decode(u8 *dst, const u8 *src, int width, int height, int texformat, int tlutaddr, int tlutfmt)
|
PC_TexFormat TexDecoder_Decode(u8 *dst, const u8 *src, int width, int height, int texformat, int tlutaddr, int tlutfmt)
|
||||||
{
|
{
|
||||||
PC_TexFormat retval = TexDecoder_Decode_real(dst,src,width,height,texformat,tlutaddr,tlutfmt);
|
PC_TexFormat retval = TexDecoder_Decode_real(dst,src,width,height,texformat,tlutaddr,tlutfmt);
|
||||||
|
if ((!TexFmt_Overlay_Enable)||(retval==PC_TEX_FMT_NONE))
|
||||||
if((!TexFmt_Overlay_Enable)||(retval==PC_TEX_FMT_NONE))
|
|
||||||
return retval;
|
return retval;
|
||||||
|
|
||||||
int w = min(width,40);
|
int w = min(width,40);
|
||||||
@ -509,23 +498,23 @@ PC_TexFormat TexDecoder_Decode(u8 *dst, const u8 *src, int width, int height, in
|
|||||||
int xoff = (width-w)>>1;
|
int xoff = (width-w)>>1;
|
||||||
int yoff = (height-h)>>1;
|
int yoff = (height-h)>>1;
|
||||||
|
|
||||||
if(!TexFmt_Overlay_Center)
|
if (!TexFmt_Overlay_Center)
|
||||||
{
|
{
|
||||||
xoff=0;
|
xoff=0;
|
||||||
yoff=0;
|
yoff=0;
|
||||||
}
|
}
|
||||||
|
|
||||||
const char* fmt = texfmt[texformat&15];
|
const char* fmt = texfmt[texformat&15];
|
||||||
while(*fmt)
|
while (*fmt)
|
||||||
{
|
{
|
||||||
int xcnt = 0;
|
int xcnt = 0;
|
||||||
int nchar = sfont_map[(int)*fmt];
|
int nchar = sfont_map[(int)*fmt];
|
||||||
|
|
||||||
const unsigned char *ptr = sfont_raw[nchar]; // each char is up to 9x10
|
const unsigned char *ptr = sfont_raw[nchar]; // each char is up to 9x10
|
||||||
|
|
||||||
for(int x=0;x<9;x++)
|
for(int x = 0; x < 9;x++)
|
||||||
{
|
{
|
||||||
if(ptr[x]==0x78)
|
if (ptr[x] == 0x78)
|
||||||
break;
|
break;
|
||||||
xcnt++;
|
xcnt++;
|
||||||
}
|
}
|
||||||
@ -1309,5 +1298,3 @@ const unsigned char sfont_raw[][9*10] = {
|
|||||||
0xff, 0xff, 0xff, 0xff, 0xff, 0x78, 0x78, 0x78, 0x78,
|
0xff, 0xff, 0xff, 0xff, 0xff, 0x78, 0x78, 0x78, 0x78,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
#endif
|
|
||||||
|
|
||||||
|
@ -106,7 +106,7 @@ void DSound::SoundLoop()
|
|||||||
while (!threadData)
|
while (!threadData)
|
||||||
{
|
{
|
||||||
// No blocking inside the csection
|
// No blocking inside the csection
|
||||||
soundCriticalSection->Enter();
|
soundCriticalSection.Enter();
|
||||||
dsBuffer->GetCurrentPosition((DWORD*)¤tPos, 0);
|
dsBuffer->GetCurrentPosition((DWORD*)¤tPos, 0);
|
||||||
int numBytesToRender = FIX128(ModBufferSize(currentPos - lastPos));
|
int numBytesToRender = FIX128(ModBufferSize(currentPos - lastPos));
|
||||||
if (numBytesToRender >= 256)
|
if (numBytesToRender >= 256)
|
||||||
@ -120,8 +120,10 @@ void DSound::SoundLoop()
|
|||||||
lastPos = currentPos;
|
lastPos = currentPos;
|
||||||
}
|
}
|
||||||
|
|
||||||
soundCriticalSection->Leave();
|
soundCriticalSection.Leave();
|
||||||
soundSyncEvent->Wait();
|
if (threadData)
|
||||||
|
break;
|
||||||
|
soundSyncEvent.Wait();
|
||||||
}
|
}
|
||||||
|
|
||||||
dsBuffer->Stop();
|
dsBuffer->Stop();
|
||||||
@ -129,13 +131,10 @@ void DSound::SoundLoop()
|
|||||||
|
|
||||||
bool DSound::Start()
|
bool DSound::Start()
|
||||||
{
|
{
|
||||||
soundSyncEvent = new Common::Event();
|
soundSyncEvent.Init();
|
||||||
soundSyncEvent->Init();
|
|
||||||
|
|
||||||
soundCriticalSection = new Common::CriticalSection();
|
|
||||||
if (FAILED(DirectSoundCreate8(0, &ds, 0)))
|
if (FAILED(DirectSoundCreate8(0, &ds, 0)))
|
||||||
return false;
|
return false;
|
||||||
if(hWnd)
|
if (hWnd)
|
||||||
ds->SetCooperativeLevel((HWND)hWnd, DSSCL_NORMAL);
|
ds->SetCooperativeLevel((HWND)hWnd, DSSCL_NORMAL);
|
||||||
if (!CreateBuffer())
|
if (!CreateBuffer())
|
||||||
return false;
|
return false;
|
||||||
@ -152,24 +151,21 @@ bool DSound::Start()
|
|||||||
|
|
||||||
void DSound::Update()
|
void DSound::Update()
|
||||||
{
|
{
|
||||||
soundSyncEvent->Set();
|
soundSyncEvent.Set();
|
||||||
}
|
}
|
||||||
|
|
||||||
void DSound::Stop()
|
void DSound::Stop()
|
||||||
{
|
{
|
||||||
soundCriticalSection->Enter();
|
soundCriticalSection.Enter();
|
||||||
threadData = 1;
|
threadData = 1;
|
||||||
// kick the thread if it's waiting
|
// kick the thread if it's waiting
|
||||||
soundSyncEvent->Set();
|
soundSyncEvent.Set();
|
||||||
soundCriticalSection->Leave();
|
soundCriticalSection.Leave();
|
||||||
delete soundCriticalSection;
|
|
||||||
delete thread;
|
delete thread;
|
||||||
|
|
||||||
dsBuffer->Release();
|
dsBuffer->Release();
|
||||||
ds->Release();
|
ds->Release();
|
||||||
|
|
||||||
soundSyncEvent->Shutdown();
|
soundSyncEvent.Shutdown();
|
||||||
delete soundSyncEvent;
|
|
||||||
soundSyncEvent = NULL;
|
|
||||||
thread = NULL;
|
thread = NULL;
|
||||||
}
|
}
|
||||||
|
@ -36,8 +36,8 @@ class DSound : public SoundStream
|
|||||||
{
|
{
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
Common::Thread *thread;
|
Common::Thread *thread;
|
||||||
Common::CriticalSection *soundCriticalSection;
|
Common::CriticalSection soundCriticalSection;
|
||||||
Common::Event *soundSyncEvent;
|
Common::Event soundSyncEvent;
|
||||||
void *hWnd;
|
void *hWnd;
|
||||||
|
|
||||||
IDirectSound8* ds;
|
IDirectSound8* ds;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user