Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
e9ebbfc0
Commit
e9ebbfc0
authored
Sep 02, 2003
by
Robert Reif
Committed by
Alexandre Julliard
Sep 02, 2003
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Now that reference counting is correct, there is no need to check if
the base object goes away.
parent
5cab2b35
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
91 additions
and
146 deletions
+91
-146
buffer.c
dlls/dsound/buffer.c
+0
-10
dsound_private.h
dlls/dsound/dsound_private.h
+0
-1
sound3d.c
dlls/dsound/sound3d.c
+91
-135
No files found.
dlls/dsound/buffer.c
View file @
e9ebbfc0
...
@@ -400,16 +400,6 @@ static DWORD WINAPI IDirectSoundBufferImpl_Release(LPDIRECTSOUNDBUFFER8 iface) {
...
@@ -400,16 +400,6 @@ static DWORD WINAPI IDirectSoundBufferImpl_Release(LPDIRECTSOUNDBUFFER8 iface) {
}
}
}
}
if
(
This
->
ds3db
)
{
WARN
(
"ds3db still has reference
\n
"
);
EnterCriticalSection
(
&
(
This
->
ds3db
->
lock
));
This
->
ds3db
->
dsb
=
NULL
;
LeaveCriticalSection
(
&
(
This
->
ds3db
->
lock
));
}
if
(
This
->
iks
)
IKsPropertySet_Release
((
LPKSPROPERTYSET
)
This
->
iks
);
if
(
This
->
notifies
!=
NULL
)
if
(
This
->
notifies
!=
NULL
)
HeapFree
(
GetProcessHeap
(),
0
,
This
->
notifies
);
HeapFree
(
GetProcessHeap
(),
0
,
This
->
notifies
);
...
...
dlls/dsound/dsound_private.h
View file @
e9ebbfc0
...
@@ -342,7 +342,6 @@ struct IDirectSound3DBufferImpl
...
@@ -342,7 +342,6 @@ struct IDirectSound3DBufferImpl
DWORD
ref
;
DWORD
ref
;
/* IDirectSound3DBufferImpl fields */
/* IDirectSound3DBufferImpl fields */
IDirectSoundBufferImpl
*
dsb
;
IDirectSoundBufferImpl
*
dsb
;
CRITICAL_SECTION
lock
;
};
};
HRESULT
WINAPI
IDirectSound3DBufferImpl_Create
(
HRESULT
WINAPI
IDirectSound3DBufferImpl_Create
(
...
...
dlls/dsound/sound3d.c
View file @
e9ebbfc0
...
@@ -397,7 +397,6 @@ static ULONG WINAPI IDirectSound3DBufferImpl_Release(LPDIRECTSOUND3DBUFFER iface
...
@@ -397,7 +397,6 @@ static ULONG WINAPI IDirectSound3DBufferImpl_Release(LPDIRECTSOUND3DBUFFER iface
if
(
!
ulReturn
)
{
if
(
!
ulReturn
)
{
This
->
dsb
->
ds3db
=
NULL
;
This
->
dsb
->
ds3db
=
NULL
;
IDirectSoundBuffer_Release
((
LPDIRECTSOUNDBUFFER8
)
This
->
dsb
);
IDirectSoundBuffer_Release
((
LPDIRECTSOUNDBUFFER8
)
This
->
dsb
);
DeleteCriticalSection
(
&
(
This
->
lock
));
HeapFree
(
GetProcessHeap
(),
0
,
This
);
HeapFree
(
GetProcessHeap
(),
0
,
This
);
TRACE
(
"(%p) released
\n
"
,
This
);
TRACE
(
"(%p) released
\n
"
,
This
);
}
}
...
@@ -423,10 +422,8 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetAllParameters(
...
@@ -423,10 +422,8 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetAllParameters(
return
DSERR_INVALIDPARAM
;
return
DSERR_INVALIDPARAM
;
}
}
if
(
This
->
dsb
)
{
TRACE
(
"returning: all parameters
\n
"
);
TRACE
(
"returning: all parameters
\n
"
);
*
lpDs3dBuffer
=
This
->
dsb
->
ds3db_ds3db
;
*
lpDs3dBuffer
=
This
->
dsb
->
ds3db_ds3db
;
}
return
DS_OK
;
return
DS_OK
;
}
}
...
@@ -436,12 +433,10 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetConeAngles(
...
@@ -436,12 +433,10 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetConeAngles(
LPDWORD
lpdwOutsideConeAngle
)
LPDWORD
lpdwOutsideConeAngle
)
{
{
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
if
(
This
->
dsb
)
{
TRACE
(
"returning: Inside Cone Angle = %ld degrees; Outside Cone Angle = %ld degrees
\n
"
,
TRACE
(
"returning: Inside Cone Angle = %ld degrees; Outside Cone Angle = %ld degrees
\n
"
,
This
->
dsb
->
ds3db_ds3db
.
dwInsideConeAngle
,
This
->
dsb
->
ds3db_ds3db
.
dwOutsideConeAngle
);
This
->
dsb
->
ds3db_ds3db
.
dwInsideConeAngle
,
This
->
dsb
->
ds3db_ds3db
.
dwOutsideConeAngle
);
*
lpdwInsideConeAngle
=
This
->
dsb
->
ds3db_ds3db
.
dwInsideConeAngle
;
*
lpdwInsideConeAngle
=
This
->
dsb
->
ds3db_ds3db
.
dwInsideConeAngle
;
*
lpdwOutsideConeAngle
=
This
->
dsb
->
ds3db_ds3db
.
dwOutsideConeAngle
;
*
lpdwOutsideConeAngle
=
This
->
dsb
->
ds3db_ds3db
.
dwOutsideConeAngle
;
}
return
DS_OK
;
return
DS_OK
;
}
}
...
@@ -450,13 +445,11 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetConeOrientation(
...
@@ -450,13 +445,11 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetConeOrientation(
LPD3DVECTOR
lpvConeOrientation
)
LPD3DVECTOR
lpvConeOrientation
)
{
{
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
if
(
This
->
dsb
)
{
TRACE
(
"returning: Cone Orientation vector = (%f,%f,%f)
\n
"
,
TRACE
(
"returning: Cone Orientation vector = (%f,%f,%f)
\n
"
,
This
->
dsb
->
ds3db_ds3db
.
vConeOrientation
.
u1
.
x
,
This
->
dsb
->
ds3db_ds3db
.
vConeOrientation
.
u1
.
x
,
This
->
dsb
->
ds3db_ds3db
.
vConeOrientation
.
u2
.
y
,
This
->
dsb
->
ds3db_ds3db
.
vConeOrientation
.
u2
.
y
,
This
->
dsb
->
ds3db_ds3db
.
vConeOrientation
.
u3
.
z
);
This
->
dsb
->
ds3db_ds3db
.
vConeOrientation
.
u3
.
z
);
*
lpvConeOrientation
=
This
->
dsb
->
ds3db_ds3db
.
vConeOrientation
;
*
lpvConeOrientation
=
This
->
dsb
->
ds3db_ds3db
.
vConeOrientation
;
}
return
DS_OK
;
return
DS_OK
;
}
}
...
@@ -465,10 +458,8 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetConeOutsideVolume(
...
@@ -465,10 +458,8 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetConeOutsideVolume(
LPLONG
lplConeOutsideVolume
)
LPLONG
lplConeOutsideVolume
)
{
{
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
if
(
This
->
dsb
)
{
TRACE
(
"returning: Cone Outside Volume = %ld
\n
"
,
This
->
dsb
->
ds3db_ds3db
.
lConeOutsideVolume
);
TRACE
(
"returning: Cone Outside Volume = %ld
\n
"
,
This
->
dsb
->
ds3db_ds3db
.
lConeOutsideVolume
);
*
lplConeOutsideVolume
=
This
->
dsb
->
ds3db_ds3db
.
lConeOutsideVolume
;
*
lplConeOutsideVolume
=
This
->
dsb
->
ds3db_ds3db
.
lConeOutsideVolume
;
}
return
DS_OK
;
return
DS_OK
;
}
}
...
@@ -477,10 +468,8 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetMaxDistance(
...
@@ -477,10 +468,8 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetMaxDistance(
LPD3DVALUE
lpfMaxDistance
)
LPD3DVALUE
lpfMaxDistance
)
{
{
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
if
(
This
->
dsb
)
{
TRACE
(
"returning: Max Distance = %f
\n
"
,
This
->
dsb
->
ds3db_ds3db
.
flMaxDistance
);
TRACE
(
"returning: Max Distance = %f
\n
"
,
This
->
dsb
->
ds3db_ds3db
.
flMaxDistance
);
*
lpfMaxDistance
=
This
->
dsb
->
ds3db_ds3db
.
flMaxDistance
;
*
lpfMaxDistance
=
This
->
dsb
->
ds3db_ds3db
.
flMaxDistance
;
}
return
DS_OK
;
return
DS_OK
;
}
}
...
@@ -489,10 +478,8 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetMinDistance(
...
@@ -489,10 +478,8 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetMinDistance(
LPD3DVALUE
lpfMinDistance
)
LPD3DVALUE
lpfMinDistance
)
{
{
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
if
(
This
->
dsb
)
{
TRACE
(
"returning: Min Distance = %f
\n
"
,
This
->
dsb
->
ds3db_ds3db
.
flMinDistance
);
TRACE
(
"returning: Min Distance = %f
\n
"
,
This
->
dsb
->
ds3db_ds3db
.
flMinDistance
);
*
lpfMinDistance
=
This
->
dsb
->
ds3db_ds3db
.
flMinDistance
;
*
lpfMinDistance
=
This
->
dsb
->
ds3db_ds3db
.
flMinDistance
;
}
return
DS_OK
;
return
DS_OK
;
}
}
...
@@ -501,10 +488,8 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetMode(
...
@@ -501,10 +488,8 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetMode(
LPDWORD
lpdwMode
)
LPDWORD
lpdwMode
)
{
{
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
if
(
This
->
dsb
)
{
TRACE
(
"returning: Mode = %ld
\n
"
,
This
->
dsb
->
ds3db_ds3db
.
dwMode
);
TRACE
(
"returning: Mode = %ld
\n
"
,
This
->
dsb
->
ds3db_ds3db
.
dwMode
);
*
lpdwMode
=
This
->
dsb
->
ds3db_ds3db
.
dwMode
;
*
lpdwMode
=
This
->
dsb
->
ds3db_ds3db
.
dwMode
;
}
return
DS_OK
;
return
DS_OK
;
}
}
...
@@ -513,13 +498,11 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetPosition(
...
@@ -513,13 +498,11 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetPosition(
LPD3DVECTOR
lpvPosition
)
LPD3DVECTOR
lpvPosition
)
{
{
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
if
(
This
->
dsb
)
{
TRACE
(
"returning: Position vector = (%f,%f,%f)
\n
"
,
TRACE
(
"returning: Position vector = (%f,%f,%f)
\n
"
,
This
->
dsb
->
ds3db_ds3db
.
vPosition
.
u1
.
x
,
This
->
dsb
->
ds3db_ds3db
.
vPosition
.
u1
.
x
,
This
->
dsb
->
ds3db_ds3db
.
vPosition
.
u2
.
y
,
This
->
dsb
->
ds3db_ds3db
.
vPosition
.
u2
.
y
,
This
->
dsb
->
ds3db_ds3db
.
vPosition
.
u3
.
z
);
This
->
dsb
->
ds3db_ds3db
.
vPosition
.
u3
.
z
);
*
lpvPosition
=
This
->
dsb
->
ds3db_ds3db
.
vPosition
;
*
lpvPosition
=
This
->
dsb
->
ds3db_ds3db
.
vPosition
;
}
return
DS_OK
;
return
DS_OK
;
}
}
...
@@ -528,13 +511,11 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetVelocity(
...
@@ -528,13 +511,11 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetVelocity(
LPD3DVECTOR
lpvVelocity
)
LPD3DVECTOR
lpvVelocity
)
{
{
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
if
(
This
->
dsb
)
{
TRACE
(
"returning: Velocity vector = (%f,%f,%f)
\n
"
,
TRACE
(
"returning: Velocity vector = (%f,%f,%f)
\n
"
,
This
->
dsb
->
ds3db_ds3db
.
vVelocity
.
u1
.
x
,
This
->
dsb
->
ds3db_ds3db
.
vVelocity
.
u1
.
x
,
This
->
dsb
->
ds3db_ds3db
.
vVelocity
.
u2
.
y
,
This
->
dsb
->
ds3db_ds3db
.
vVelocity
.
u2
.
y
,
This
->
dsb
->
ds3db_ds3db
.
vVelocity
.
u3
.
z
);
This
->
dsb
->
ds3db_ds3db
.
vVelocity
.
u3
.
z
);
*
lpvVelocity
=
This
->
dsb
->
ds3db_ds3db
.
vVelocity
;
*
lpvVelocity
=
This
->
dsb
->
ds3db_ds3db
.
vVelocity
;
}
return
DS_OK
;
return
DS_OK
;
}
}
...
@@ -558,22 +539,15 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetAllParameters(
...
@@ -558,22 +539,15 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetAllParameters(
return
status
;
return
status
;
}
}
EnterCriticalSection
(
&
This
->
lock
);
TRACE
(
"setting: all parameters; dwApply = %ld
\n
"
,
dwApply
);
This
->
dsb
->
ds3db_ds3db
=
*
lpcDs3dBuffer
;
if
(
This
->
dsb
)
{
TRACE
(
"setting: all parameters; dwApply = %ld
\n
"
,
dwApply
);
This
->
dsb
->
ds3db_ds3db
=
*
lpcDs3dBuffer
;
if
(
dwApply
==
DS3D_IMMEDIATE
)
{
DSOUND_Mix3DBuffer
(
This
->
dsb
);
}
This
->
dsb
->
ds3db_need_recalc
=
TRUE
;
status
=
DS_OK
;
}
else
WARN
(
"pointer no longer valid
\n
"
);
LeaveCriticalSection
(
&
This
->
lock
);
if
(
dwApply
==
DS3D_IMMEDIATE
)
{
DSOUND_Mix3DBuffer
(
This
->
dsb
);
}
This
->
dsb
->
ds3db_need_recalc
=
TRUE
;
status
=
DS_OK
;
return
status
;
return
status
;
}
}
...
@@ -587,15 +561,13 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetConeAngles(
...
@@ -587,15 +561,13 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetConeAngles(
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
TRACE
(
"setting: Inside Cone Angle = %ld; Outside Cone Angle = %ld; dwApply = %ld
\n
"
,
TRACE
(
"setting: Inside Cone Angle = %ld; Outside Cone Angle = %ld; dwApply = %ld
\n
"
,
dwInsideConeAngle
,
dwOutsideConeAngle
,
dwApply
);
dwInsideConeAngle
,
dwOutsideConeAngle
,
dwApply
);
if
(
This
->
dsb
)
{
This
->
dsb
->
ds3db_ds3db
.
dwInsideConeAngle
=
dwInsideConeAngle
;
This
->
dsb
->
ds3db_ds3db
.
dwInsideConeAngle
=
dwInsideConeAngle
;
This
->
dsb
->
ds3db_ds3db
.
dwOutsideConeAngle
=
dwOutsideConeAngle
;
This
->
dsb
->
ds3db_ds3db
.
dwOutsideConeAngle
=
dwOutsideConeAngle
;
if
(
dwApply
==
DS3D_IMMEDIATE
)
if
(
dwApply
==
DS3D_IMMEDIATE
)
{
{
DSOUND_Mix3DBuffer
(
This
->
dsb
);
DSOUND_Mix3DBuffer
(
This
->
dsb
);
}
This
->
dsb
->
ds3db_need_recalc
=
TRUE
;
}
}
This
->
dsb
->
ds3db_need_recalc
=
TRUE
;
return
DS_OK
;
return
DS_OK
;
}
}
...
@@ -606,17 +578,15 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetConeOrientation(
...
@@ -606,17 +578,15 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetConeOrientation(
{
{
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
TRACE
(
"setting: Cone Orientation vector = (%f,%f,%f); dwApply = %ld
\n
"
,
x
,
y
,
z
,
dwApply
);
TRACE
(
"setting: Cone Orientation vector = (%f,%f,%f); dwApply = %ld
\n
"
,
x
,
y
,
z
,
dwApply
);
if
(
This
->
dsb
)
{
This
->
dsb
->
ds3db_ds3db
.
vConeOrientation
.
u1
.
x
=
x
;
This
->
dsb
->
ds3db_ds3db
.
vConeOrientation
.
u1
.
x
=
x
;
This
->
dsb
->
ds3db_ds3db
.
vConeOrientation
.
u2
.
y
=
y
;
This
->
dsb
->
ds3db_ds3db
.
vConeOrientation
.
u2
.
y
=
y
;
This
->
dsb
->
ds3db_ds3db
.
vConeOrientation
.
u3
.
z
=
z
;
This
->
dsb
->
ds3db_ds3db
.
vConeOrientation
.
u3
.
z
=
z
;
if
(
dwApply
==
DS3D_IMMEDIATE
)
if
(
dwApply
==
DS3D_IMMEDIATE
)
{
{
This
->
dsb
->
ds3db_need_recalc
=
FALSE
;
This
->
dsb
->
ds3db_need_recalc
=
FALSE
;
DSOUND_Mix3DBuffer
(
This
->
dsb
);
DSOUND_Mix3DBuffer
(
This
->
dsb
);
}
This
->
dsb
->
ds3db_need_recalc
=
TRUE
;
}
}
This
->
dsb
->
ds3db_need_recalc
=
TRUE
;
return
DS_OK
;
return
DS_OK
;
}
}
...
@@ -627,15 +597,13 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetConeOutsideVolume(
...
@@ -627,15 +597,13 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetConeOutsideVolume(
{
{
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
TRACE
(
"setting: ConeOutsideVolume = %ld; dwApply = %ld
\n
"
,
lConeOutsideVolume
,
dwApply
);
TRACE
(
"setting: ConeOutsideVolume = %ld; dwApply = %ld
\n
"
,
lConeOutsideVolume
,
dwApply
);
if
(
This
->
dsb
)
{
This
->
dsb
->
ds3db_ds3db
.
lConeOutsideVolume
=
lConeOutsideVolume
;
This
->
dsb
->
ds3db_ds3db
.
lConeOutsideVolume
=
lConeOutsideVolume
;
if
(
dwApply
==
DS3D_IMMEDIATE
)
if
(
dwApply
==
DS3D_IMMEDIATE
)
{
{
This
->
dsb
->
ds3db_need_recalc
=
FALSE
;
This
->
dsb
->
ds3db_need_recalc
=
FALSE
;
DSOUND_Mix3DBuffer
(
This
->
dsb
);
DSOUND_Mix3DBuffer
(
This
->
dsb
);
}
This
->
dsb
->
ds3db_need_recalc
=
TRUE
;
}
}
This
->
dsb
->
ds3db_need_recalc
=
TRUE
;
return
DS_OK
;
return
DS_OK
;
}
}
...
@@ -646,15 +614,13 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetMaxDistance(
...
@@ -646,15 +614,13 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetMaxDistance(
{
{
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
TRACE
(
"setting: MaxDistance = %f; dwApply = %ld
\n
"
,
fMaxDistance
,
dwApply
);
TRACE
(
"setting: MaxDistance = %f; dwApply = %ld
\n
"
,
fMaxDistance
,
dwApply
);
if
(
This
->
dsb
)
{
This
->
dsb
->
ds3db_ds3db
.
flMaxDistance
=
fMaxDistance
;
This
->
dsb
->
ds3db_ds3db
.
flMaxDistance
=
fMaxDistance
;
if
(
dwApply
==
DS3D_IMMEDIATE
)
if
(
dwApply
==
DS3D_IMMEDIATE
)
{
{
This
->
dsb
->
ds3db_need_recalc
=
FALSE
;
This
->
dsb
->
ds3db_need_recalc
=
FALSE
;
DSOUND_Mix3DBuffer
(
This
->
dsb
);
DSOUND_Mix3DBuffer
(
This
->
dsb
);
}
This
->
dsb
->
ds3db_need_recalc
=
TRUE
;
}
}
This
->
dsb
->
ds3db_need_recalc
=
TRUE
;
return
DS_OK
;
return
DS_OK
;
}
}
...
@@ -665,15 +631,13 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetMinDistance(
...
@@ -665,15 +631,13 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetMinDistance(
{
{
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
TRACE
(
"setting: MinDistance = %f; dwApply = %ld
\n
"
,
fMinDistance
,
dwApply
);
TRACE
(
"setting: MinDistance = %f; dwApply = %ld
\n
"
,
fMinDistance
,
dwApply
);
if
(
This
->
dsb
)
{
This
->
dsb
->
ds3db_ds3db
.
flMinDistance
=
fMinDistance
;
This
->
dsb
->
ds3db_ds3db
.
flMinDistance
=
fMinDistance
;
if
(
dwApply
==
DS3D_IMMEDIATE
)
if
(
dwApply
==
DS3D_IMMEDIATE
)
{
{
This
->
dsb
->
ds3db_need_recalc
=
FALSE
;
This
->
dsb
->
ds3db_need_recalc
=
FALSE
;
DSOUND_Mix3DBuffer
(
This
->
dsb
);
DSOUND_Mix3DBuffer
(
This
->
dsb
);
}
This
->
dsb
->
ds3db_need_recalc
=
TRUE
;
}
}
This
->
dsb
->
ds3db_need_recalc
=
TRUE
;
return
DS_OK
;
return
DS_OK
;
}
}
...
@@ -684,15 +648,13 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetMode(
...
@@ -684,15 +648,13 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetMode(
{
{
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
TRACE
(
"setting: Mode = %ld; dwApply = %ld
\n
"
,
dwMode
,
dwApply
);
TRACE
(
"setting: Mode = %ld; dwApply = %ld
\n
"
,
dwMode
,
dwApply
);
if
(
This
->
dsb
)
{
This
->
dsb
->
ds3db_ds3db
.
dwMode
=
dwMode
;
This
->
dsb
->
ds3db_ds3db
.
dwMode
=
dwMode
;
if
(
dwApply
==
DS3D_IMMEDIATE
)
if
(
dwApply
==
DS3D_IMMEDIATE
)
{
{
This
->
dsb
->
ds3db_need_recalc
=
FALSE
;
This
->
dsb
->
ds3db_need_recalc
=
FALSE
;
DSOUND_Mix3DBuffer
(
This
->
dsb
);
DSOUND_Mix3DBuffer
(
This
->
dsb
);
}
This
->
dsb
->
ds3db_need_recalc
=
TRUE
;
}
}
This
->
dsb
->
ds3db_need_recalc
=
TRUE
;
return
DS_OK
;
return
DS_OK
;
}
}
...
@@ -703,17 +665,15 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetPosition(
...
@@ -703,17 +665,15 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetPosition(
{
{
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
TRACE
(
"setting: Position vector = (%f,%f,%f); dwApply = %ld
\n
"
,
x
,
y
,
z
,
dwApply
);
TRACE
(
"setting: Position vector = (%f,%f,%f); dwApply = %ld
\n
"
,
x
,
y
,
z
,
dwApply
);
if
(
This
->
dsb
)
{
This
->
dsb
->
ds3db_ds3db
.
vPosition
.
u1
.
x
=
x
;
This
->
dsb
->
ds3db_ds3db
.
vPosition
.
u1
.
x
=
x
;
This
->
dsb
->
ds3db_ds3db
.
vPosition
.
u2
.
y
=
y
;
This
->
dsb
->
ds3db_ds3db
.
vPosition
.
u2
.
y
=
y
;
This
->
dsb
->
ds3db_ds3db
.
vPosition
.
u3
.
z
=
z
;
This
->
dsb
->
ds3db_ds3db
.
vPosition
.
u3
.
z
=
z
;
if
(
dwApply
==
DS3D_IMMEDIATE
)
if
(
dwApply
==
DS3D_IMMEDIATE
)
{
{
This
->
dsb
->
ds3db_need_recalc
=
FALSE
;
This
->
dsb
->
ds3db_need_recalc
=
FALSE
;
DSOUND_Mix3DBuffer
(
This
->
dsb
);
DSOUND_Mix3DBuffer
(
This
->
dsb
);
}
This
->
dsb
->
ds3db_need_recalc
=
TRUE
;
}
}
This
->
dsb
->
ds3db_need_recalc
=
TRUE
;
return
DS_OK
;
return
DS_OK
;
}
}
...
@@ -724,17 +684,15 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetVelocity(
...
@@ -724,17 +684,15 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetVelocity(
{
{
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
ICOM_THIS
(
IDirectSound3DBufferImpl
,
iface
);
TRACE
(
"setting: Velocity vector = (%f,%f,%f); dwApply = %ld
\n
"
,
x
,
y
,
z
,
dwApply
);
TRACE
(
"setting: Velocity vector = (%f,%f,%f); dwApply = %ld
\n
"
,
x
,
y
,
z
,
dwApply
);
if
(
This
->
dsb
)
{
This
->
dsb
->
ds3db_ds3db
.
vVelocity
.
u1
.
x
=
x
;
This
->
dsb
->
ds3db_ds3db
.
vVelocity
.
u1
.
x
=
x
;
This
->
dsb
->
ds3db_ds3db
.
vVelocity
.
u2
.
y
=
y
;
This
->
dsb
->
ds3db_ds3db
.
vVelocity
.
u2
.
y
=
y
;
This
->
dsb
->
ds3db_ds3db
.
vVelocity
.
u3
.
z
=
z
;
This
->
dsb
->
ds3db_ds3db
.
vVelocity
.
u3
.
z
=
z
;
if
(
dwApply
==
DS3D_IMMEDIATE
)
if
(
dwApply
==
DS3D_IMMEDIATE
)
{
{
This
->
dsb
->
ds3db_need_recalc
=
FALSE
;
This
->
dsb
->
ds3db_need_recalc
=
FALSE
;
DSOUND_Mix3DBuffer
(
This
->
dsb
);
DSOUND_Mix3DBuffer
(
This
->
dsb
);
}
This
->
dsb
->
ds3db_need_recalc
=
TRUE
;
}
}
This
->
dsb
->
ds3db_need_recalc
=
TRUE
;
return
DS_OK
;
return
DS_OK
;
}
}
...
@@ -804,8 +762,6 @@ HRESULT WINAPI IDirectSound3DBufferImpl_Create(
...
@@ -804,8 +762,6 @@ HRESULT WINAPI IDirectSound3DBufferImpl_Create(
ds3db
->
dsb
->
ds3db_need_recalc
=
TRUE
;
ds3db
->
dsb
->
ds3db_need_recalc
=
TRUE
;
InitializeCriticalSection
(
&
(
ds3db
->
lock
));
IDirectSoundBuffer_AddRef
((
LPDIRECTSOUNDBUFFER8
)
dsb
);
IDirectSoundBuffer_AddRef
((
LPDIRECTSOUNDBUFFER8
)
dsb
);
*
pds3db
=
ds3db
;
*
pds3db
=
ds3db
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment