本文整理汇总了C++中LPDIRECTSOUNDBUFFER::Unlock方法的典型用法代码示例。如果您正苦于以下问题:C++ LPDIRECTSOUNDBUFFER::Unlock方法的具体用法?C++ LPDIRECTSOUNDBUFFER::Unlock怎么用?C++ LPDIRECTSOUNDBUFFER::Unlock使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类LPDIRECTSOUNDBUFFER
的用法示例。
在下文中一共展示了LPDIRECTSOUNDBUFFER::Unlock方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: AppMixintoPrimaryBuffer
BOOL AppMixintoPrimaryBuffer(
APPSTREAMINFO * lpAppStreamInfo,
LPDIRECTSOUNDBUFFER lpDsbPrimary,
DWORD dwDataBytes,
DWORD dwOldPos,
LPDWORD lpdwNewPos
){
LPVOID lpvPtr1;
DWORD dwBytes1;
LPVOID lpvPtr2;
DWORD dwBytes2;
HRESULT hr;
//得到写指针
hr = lpDsbPrimary->Lock(dwOld, dwDataBytes, &lpvPtr1, &dwBytes1, &lpvPtr2, &dwBytes2, 0);
if (DSERR_BUFFERLOST == hr)//需要重新装载并重试锁定
{
lpDsbPrimary->Restore();
hr = lpDsbPrimary->Lock(dwOld, dwDataBytes, &lpvPtr1, &dwBytes1, &lpvPtr2, &dwBytes2, 0);
}
if (SUCCEEDED(hr)){
CustomMixer(lpAppStreamInfo, lpvPtr1, dwBytes1);
*lpdwNewPos = dwOldPos + dwBytes1;
if (NULL != lpvPtr2){
CustomMixer(lpAppStreamInfo, lpvPtr2, dwBytes2);
*lpdwNewPos = dwBytes2;//
}
hr = lpDsbPrimary->Unlock(lpvPtr1, dwBytes1, lpvPtr2, dwBytes2);
if (SUCCEEDED(hr)){
return TRUE;
}
}
return FALSE;
}
示例2: streamwrite
static void streamwrite(DWORD pos) {
const SINT32 *pcm;
HRESULT hr;
LPBYTE blockptr1;
LPBYTE blockptr2;
DWORD blocksize1;
DWORD blocksize2;
pcm = sound_pcmlock();
if ((hr = pDSData3->Lock(pos, dsstreambytes,
(LPVOID *)&blockptr1, &blocksize1,
(LPVOID *)&blockptr2, &blocksize2, 0))
== DSERR_BUFFERLOST) {
pDSData3->Restore();
hr = pDSData3->Lock(pos, dsstreambytes,
(LPVOID *)&blockptr1, &blocksize1,
(LPVOID *)&blockptr2, &blocksize2, 0);
}
if (SUCCEEDED(hr)) {
if (pcm) {
(*fnmix)((SINT16 *)blockptr1, pcm, blocksize1);
}
else {
ZeroMemory(blockptr1, blocksize1);
}
pDSData3->Unlock(blockptr1, blocksize1, blockptr2, blocksize2);
}
sound_pcmunlock(pcm);
}
示例3: OpenSoundFile
static LPDIRECTSOUNDBUFFER OpenSoundFile(char *name)
{
DSBUFFERDESC DSBufDESC;
WAVEFORMATEX waveFormat;
void* buf;
DWORD size;
HMMIO hmmio;
MMCKINFO cParent, cSub;
LPDIRECTSOUNDBUFFER lpDSBuf = NULL;
MMIOINFO mem;
int fileSize;
char *data = LoadFile(name, &fileSize);
memset(&mem, 0, sizeof(MMIOINFO));
mem.pchBuffer = data;
mem.cchBuffer = fileSize;
mem.fccIOProc = FOURCC_MEM;
hmmio = mmioOpen(NULL, &mem, MMIO_ALLOCBUF | MMIO_READ);
cParent.fccType = mmioFOURCC('W','A','V','E');
if (mmioDescend(hmmio, &cParent, NULL, MMIO_FINDRIFF) != MMSYSERR_NOERROR) {
return NULL;
}
cSub.ckid = mmioFOURCC('f','m','t',' ');
if (mmioDescend(hmmio, &cSub, &cParent, MMIO_FINDCHUNK) != MMSYSERR_NOERROR) {
goto end;
}
mmioRead(hmmio, (char*)&waveFormat, cSub.cksize);
mmioAscend(hmmio, &cSub, 0);
if (waveFormat.wFormatTag != WAVE_FORMAT_PCM) {
goto end;
}
cSub.ckid = mmioFOURCC('d','a','t','a');
if (mmioDescend(hmmio, &cSub, &cParent, MMIO_FINDCHUNK) != MMSYSERR_NOERROR) {
goto end;
}
ZeroMemory(&DSBufDESC, sizeof(DSBUFFERDESC));
DSBufDESC.dwSize = sizeof(DSBUFFERDESC);
DSBufDESC.dwFlags = DSBCAPS_CTRLPAN|DSBCAPS_CTRLVOLUME|DSBCAPS_GLOBALFOCUS;
DSBufDESC.dwBufferBytes = cSub.cksize;
DSBufDESC.lpwfxFormat = &waveFormat;
lpDS->CreateSoundBuffer(&DSBufDESC, &lpDSBuf, NULL);
lpDSBuf->Lock(0, cSub.cksize, &buf, &size, NULL, 0, 0);
mmioRead(hmmio, (HPSTR)buf, (LONG)cSub.cksize);
lpDSBuf->Unlock(buf, size, NULL, 0);
mmioClose(hmmio, MMIO_FHOPEN);
return lpDSBuf;
end:
mmioClose(hmmio, MMIO_FHOPEN);
free(data);
return NULL;
}
示例4: LoadWave
// WAVE ファイルの読み込み
LPDIRECTSOUNDBUFFER LoadWave(char *name)
{
char *buf;
UINT readsize;
WAVEFORMATEX wf;
LPDIRECTSOUNDBUFFER lpDSB = NULL;
DSBUFFERDESC desc;
LPVOID pMem1,pMem2;
DWORD size1,size2;
// WAVE ファイルを開く
if (!YWaveOpen(name))
{
return NULL;
}
// メモリ領域の確保
buf = (char *)malloc(m_ckIn.cksize);
// 読み込み
ZeroMemory(&wf,sizeof(WAVEFORMATEX));
if (!YWaveRead(m_ckIn.cksize,buf,&readsize,&wf))
{
free(buf);
return NULL;
}
// サウンドバッファの作成
ZeroMemory(&desc,sizeof(DSBUFFERDESC));
desc.dwSize = sizeof(DSBUFFERDESC);
desc.dwFlags = DSBCAPS_GETCURRENTPOSITION2 | DSBCAPS_GLOBALFOCUS | DSBCAPS_LOCDEFER | DSBCAPS_CTRLVOLUME;
desc.dwBufferBytes = readsize;
desc.lpwfxFormat = &wf;
if (FAILED(lpDS->CreateSoundBuffer(&desc,&lpDSB,NULL)))
{
free(buf);
return NULL;
}
// 領域をロック
if (FAILED(lpDSB->Lock(0,readsize,&pMem1,&size1,&pMem2,&size2,0)))
{
free(buf);
return 0;
}
// 書き込み
memcpy(pMem1,buf,size1);
if (size2)
{
memcpy(pMem2,buf + size1,size2);
}
// ロック解除
lpDSB->Unlock(pMem1,size1,pMem2,size2);
free(buf);
// 閉じる
YWaveClose();
return lpDSB;
}
示例5: LoopBlank
static int LoopBlank(void)
{
void *mema=NULL,*memb=NULL;
DWORD sizea=0,sizeb=0;
LoopBuffer->Lock(0, LoopLen, &mema,&sizea, &memb,&sizeb, 0);
if (mema) memset(mema,0,sizea);
LoopBuffer->Unlock(mema,sizea, memb,sizeb);
return 0;
}
示例6: SNDDXClearAudioBuffer
void SNDDXClearAudioBuffer()
{
// we shouldn't need to provide 2 buffers since it's 1 contiguous range
// but maybe newer directsound implementations have issues
LPVOID buffer1;
LPVOID buffer2;
DWORD buffer1_size, buffer2_size;
HRESULT hr = lpDSB2->Lock(0, 0, &buffer1, &buffer1_size, &buffer2, &buffer2_size, DSBLOCK_ENTIREBUFFER);
if(FAILED(hr))
return;
memset(buffer1, 0, buffer1_size);
if(buffer2)
memset(buffer2, 0, buffer2_size);
lpDSB2->Unlock(buffer1, buffer1_size, buffer2, buffer2_size);
}
示例7: memcpy
BOOL LC3Sound::WriteDataToBuffer(
LPDIRECTSOUNDBUFFER lpDsb,
DWORD dwOffset,
LPBYTE lpbSoundData,
DWORD dwSoundBytes)
{
LPVOID lpvPtr1;
DWORD dwBytes1;
LPVOID lpvPtr2;
DWORD dwBytes2;
HRESULT hr;
// lpDirectSound->lpVtbl->SetCooperativeLevel( lpDirectSound, hwnd, DSSCL_EXCLUSIVE);
// Obtain write pointer.
hr = lpDsb->Lock(dwOffset, dwSoundBytes, &lpvPtr1, &dwBytes1, &lpvPtr2, &dwBytes2, 0);
// If we got DSERR_BUFFERLOST, restore and retry lock.
if(DSERR_BUFFERLOST == hr) {
lpDsb->Restore();
hr = lpDsb->Lock(dwOffset, dwSoundBytes, &lpvPtr1,
&dwBytes1, &lpvPtr2, &dwBytes2, 0);
}
if(DS_OK == hr) {
// Write to pointers.
memcpy(lpvPtr1, lpbSoundData, dwBytes1);
if(NULL != lpvPtr2) {
memcpy(lpvPtr2, lpbSoundData+dwBytes1, dwBytes2);
}
// Release the data back to DirectSound.
hr = lpDsb->Unlock(lpvPtr1, dwBytes1, lpvPtr2, dwBytes2);
if(DS_OK == hr) {
// Success!
return TRUE;
}
}
// lpDirectSound->lpVtbl->SetCooperativeLevel( lpDirectSound, hwnd, DSSCL_NORMAL);
// If we got here, then we failed Lock, Unlock, or Restore.
return FALSE;
}
示例8: soundmng_reset
void soundmng_reset(void) {
LPBYTE blockptr1;
LPBYTE blockptr2;
DWORD blocksize1;
DWORD blocksize2;
if ((pDSData3) &&
(SUCCEEDED(pDSData3->Lock(0, dsstreambytes * 2,
(LPVOID *)&blockptr1, &blocksize1,
(LPVOID *)&blockptr2, &blocksize2, 0)))) {
ZeroMemory(blockptr1, blocksize1);
if ((blockptr2 != NULL) && (blocksize2 != 0)) {
ZeroMemory(blockptr2, blocksize2);
}
pDSData3->Unlock(blockptr1, blocksize1, blockptr2, blocksize2);
pDSData3->SetCurrentPosition(0);
dsstreamevent = (UINT8)-1;
}
}
示例9: WriteBuffer
void WriteBuffer(int * DestBuf, short * SrcBuf, int datalen)
{
void * writePtr1;
void * writePtr2;
unsigned long length1;
unsigned long length2;
LPDIRECTSOUNDBUFFER dsBuffer = (LPDIRECTSOUNDBUFFER) DestBuf;
unsigned long WriteCur;
dsBuffer->GetCurrentPosition(NULL, &WriteCur);
dsBuffer->Lock(WriteCur, datalen, &writePtr1, &length1, &writePtr2, &length2, 0);
memcpy(writePtr1, SrcBuf, length1);
memcpy(writePtr2, SrcBuf + length1, length2);
dsBuffer->Unlock(writePtr1, length1, writePtr2, length2);
dsBuffer->SetCurrentPosition(WriteCur);
}
示例10: CreateOutputBuffer
LPDIRECTSOUNDBUFFER SoundBuffersMG::CreateOutputBuffer(const long int BufferBytes, const long int SamplesPerSec=8000,
const int BitsPerSample=32, const int Channels=1, void* pData=NULL)
{
DSBUFFERDESC desc;
desc.dwSize = sizeof(DSBUFFERDESC);
desc.dwFlags = DSBCAPS_CTRLFREQUENCY|DSBCAPS_CTRLVOLUME;
desc.guid3DAlgorithm = DS3DALG_DEFAULT;
desc.dwBufferBytes = BufferBytes;
desc.dwReserved = 0;
WAVEFORMATEX waveFmt;
waveFmt.cbSize = sizeof(WAVEFORMATEX);
waveFmt.nChannels = Channels;
waveFmt.nSamplesPerSec = SamplesPerSec;
waveFmt.wBitsPerSample = BitsPerSample;
waveFmt.nBlockAlign = (waveFmt.nChannels*waveFmt.wBitsPerSample)/8;
waveFmt.nAvgBytesPerSec = waveFmt.nSamplesPerSec*waveFmt.nBlockAlign;
waveFmt.wFormatTag = WAVE_FORMAT_PCM;
desc.lpwfxFormat = &waveFmt;
LPDIRECTSOUNDBUFFER pStaticBuffer;
hr = pDSound->CreateSoundBuffer( &desc, &pStaticBuffer,NULL);
if( FAILED(hr) )
return NULL;
if( pData != NULL )
{
LPVOID pBufferData = NULL;
DWORD dataSize = 0;
pStaticBuffer->Lock(0, NULL, &pBufferData, &dataSize, NULL, NULL, DSBLOCK_ENTIREBUFFER);
memcpy(pBufferData, (LPVOID)pData, desc.dwBufferBytes);
pStaticBuffer->Unlock(pBufferData, desc.dwBufferBytes, NULL, NULL);
}
OutputBuffers.push_back(pStaticBuffer);
return pStaticBuffer;
}
示例11: WriteSeg
static int WriteSeg(const void *buff)
{
void *mema=NULL,*memb=NULL;
DWORD sizea=0,sizeb=0;
int ret;
// Lock the segment at 'LoopWrite' and copy the next segment in
ret = LoopBuffer->Lock(LoopWrite, LoopSeg, &mema, &sizea, &memb, &sizeb, 0);
if (ret != DS_OK)
lprintf("LoopBuffer->Lock() failed: %i\n", ret);
if (mema) memcpy(mema,buff,sizea);
// if (memb) memcpy(memb,DSoundNext+sizea,sizeb);
if (sizeb != 0) lprintf("sizeb is not 0! (%i)\n", sizeb);
ret = LoopBuffer->Unlock(mema,sizea, memb, sizeb);
if (ret != DS_OK)
lprintf("LoopBuffer->Unlock() failed: %i\n", ret);
return 0;
}
示例12: _CreateSoundBuffer
LPDIRECTSOUNDBUFFER MkSoundBuffer::_CreateSoundBuffer(LPDIRECTSOUND directSound, const WAVEFORMATEX& waveFormatEx, const MkByteArray& dataBuffer)
{
// 사운드 버퍼 생성
DSBUFFERDESC desc;
::ZeroMemory(&desc, sizeof(DSBUFFERDESC));
desc.dwSize = sizeof(DSBUFFERDESC);
desc.dwFlags = DSBCAPS_LOCSOFTWARE | DSBCAPS_CTRLVOLUME | DSBCAPS_CTRLFREQUENCY | DSBCAPS_CTRLPAN;
desc.dwBufferBytes = dataBuffer.GetSize();
desc.lpwfxFormat = const_cast<LPWAVEFORMATEX>(&waveFormatEx);
LPDIRECTSOUNDBUFFER soundBuffer = NULL;
do
{
if (FAILED(directSound->CreateSoundBuffer(&desc, &soundBuffer, NULL)))
break;
// 사운드 버퍼에 데이터 복사
LPVOID primarySoundBuffer = NULL;
LPVOID secondarySoundBuffer = NULL;
DWORD primaryLength, secondaryLength;
if (FAILED(soundBuffer->Lock(0, desc.dwBufferBytes, &primarySoundBuffer, &primaryLength, &secondarySoundBuffer, &secondaryLength, 0)))
break;
memcpy_s(primarySoundBuffer, primaryLength, dataBuffer.GetPtr(), primaryLength); // 순환 버퍼의 앞부분 복사
memcpy_s(secondarySoundBuffer, secondaryLength, dataBuffer.GetPtr() + primaryLength, secondaryLength); // 순환 버퍼의 뒷부분 복사
if (FAILED(soundBuffer->Unlock(primarySoundBuffer, primaryLength, secondarySoundBuffer, secondaryLength)))
break;
return soundBuffer;
}
while (false);
if (soundBuffer != NULL)
{
soundBuffer->Release();
}
return NULL;
}
示例13: DSUtil_FillSoundBuffer
//-----------------------------------------------------------------------------
// Name:
// Desc:
//-----------------------------------------------------------------------------
HRESULT DSUtil_FillSoundBuffer( LPDIRECTSOUNDBUFFER pDSB, BYTE* pbWaveData,
DWORD dwWaveSize )
{
VOID* pMem1;
VOID* pMem2;
DWORD dwSize1;
DWORD dwSize2;
if( NULL == pDSB || NULL == pbWaveData || 0 == dwWaveSize )
return E_FAIL;
if( FAILED( pDSB->Lock( 0, dwWaveSize, &pMem1, &dwSize1, &pMem2,
&dwSize2, 0 ) ) )
return E_FAIL;
if( 0 != dwSize1 ) CopyMemory( pMem1, pbWaveData, dwSize1 );
if( 0 != dwSize2 ) CopyMemory( pMem2, pbWaveData+dwSize1, dwSize2 );
pDSB->Unlock( pMem1, dwSize1, pMem2, dwSize2);
return S_OK;
}
示例14: creatBuffer
//--------------------------------
// DirectSound用バッファの確保
//--------------------------------
LPDIRECTSOUNDBUFFER Sound::creatBuffer()
{
LPDIRECTSOUNDBUFFER pDSBuffer = NULL;
if(m_pDirectSound)
{
DSBUFFERDESC Desc;
ZeroMemory(&Desc,sizeof(DSBUFFERDESC));
Desc.dwSize = sizeof(DSBUFFERDESC);
Desc.dwFlags = DSBCAPS_STATIC|DSBCAPS_LOCSOFTWARE|DSBCAPS_GLOBALFOCUS;
Desc.dwBufferBytes = getWaveData()->getDataSize();
Desc.lpwfxFormat = getWaveData()->getFormat();
m_pDirectSound->CreateSoundBuffer(&Desc,&pDSBuffer,NULL);
if(pDSBuffer)
{
LPVOID pData1;
DWORD dwBytes1;
pDSBuffer->Lock(0,getWaveData()->getDataSize(),&pData1,&dwBytes1,NULL,NULL,0);
CopyMemory(pData1,getWaveData()->getWaveData(),dwBytes1);
pDSBuffer->Unlock(pData1,dwBytes1,NULL,0);
}
}
return pDSBuffer;
}
示例15: DS_UploadSample
/*------------------------------------------------------------------------
*
* PROTOTYPE : BOOL static DS_UploadSample(uint16_t channel, uint32_t offset, char *buffer, uint32_t size, int mode)
*
* DESCRIPTION : Upload a raw sample into a DSound buffer.
*
*/
static BOOL DS_UploadSample(uint16_t channel, uint32_t offset, void *buffer, uint32_t size)
{
HRESULT hr;
void *lpP1 = NULL;
ULONG dwB1 = 0;
void *lpP2 = NULL;
ULONG dwB2 = 0;
LPDIRECTSOUNDBUFFER pDS = g_pDSHandles[channel].pbuffer;
if ((!pDS)||(!buffer))
{
return FALSE;
}
do
{
hr = pDS->Lock(offset, size, &lpP1, &dwB1, &lpP2, &dwB2, 0);
if (hr == DSERR_BUFFERLOST)
pDS->Restore();
}while(hr==DSERR_BUFFERLOST);
if (hr != DS_OK)
{
return FALSE;
}
if (lpP1)
sysMemCpy(lpP1, buffer , dwB1);
if (lpP2)
sysMemCpy(lpP2, (uint8_t*)buffer+ dwB1, dwB2);
hr = pDS->Unlock( lpP1, dwB1, lpP2, dwB2);
if (hr != DS_OK)
{
return FALSE;
}
return TRUE;
}