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
d07f46e8
Commit
d07f46e8
authored
Apr 06, 2011
by
Aric Stewart
Committed by
Alexandre Julliard
Apr 07, 2011
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
wineqtdecoder: Optimizations for audio extraction.
parent
75a01058
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
28 additions
and
30 deletions
+28
-30
qtsplitter.c
dlls/wineqtdecoder/qtsplitter.c
+28
-30
No files found.
dlls/wineqtdecoder/qtsplitter.c
View file @
d07f46e8
...
@@ -356,6 +356,9 @@ static OSErr QT_Create_Extract_Session(QTSplitter *filter)
...
@@ -356,6 +356,9 @@ static OSErr QT_Create_Extract_Session(QTSplitter *filter)
{
{
AudioStreamBasicDescription
aDesc
;
AudioStreamBasicDescription
aDesc
;
OSErr
err
;
OSErr
err
;
WAVEFORMATEX
*
pvi
;
pvi
=
(
WAVEFORMATEX
*
)
filter
->
pAudio_Pin
->
pmt
->
pbFormat
;
err
=
MovieAudioExtractionBegin
(
filter
->
pQTMovie
,
0
,
&
filter
->
aSession
);
err
=
MovieAudioExtractionBegin
(
filter
->
pQTMovie
,
0
,
&
filter
->
aSession
);
if
(
err
!=
noErr
)
if
(
err
!=
noErr
)
...
@@ -381,11 +384,11 @@ kQTMovieAudioExtractionAudioPropertyID_AudioStreamBasicDescription,
...
@@ -381,11 +384,11 @@ kQTMovieAudioExtractionAudioPropertyID_AudioStreamBasicDescription,
aDesc
.
mFormatFlags
=
kLinearPCMFormatFlagIsSignedInteger
+
aDesc
.
mFormatFlags
=
kLinearPCMFormatFlagIsSignedInteger
+
kAudioFormatFlagIsPacked
;
kAudioFormatFlagIsPacked
;
aDesc
.
mFramesPerPacket
=
1
;
aDesc
.
mFramesPerPacket
=
1
;
aDesc
.
mChannelsPerFrame
=
2
;
aDesc
.
mChannelsPerFrame
=
pvi
->
nChannels
;
aDesc
.
mBitsPerChannel
=
16
;
aDesc
.
mBitsPerChannel
=
pvi
->
wBitsPerSample
;
aDesc
.
mSampleRate
=
pvi
->
nSamplesPerSec
;
aDesc
.
mBytesPerFrame
=
(
aDesc
.
mBitsPerChannel
*
aDesc
.
mChannelsPerFrame
)
/
8
;
aDesc
.
mBytesPerFrame
=
(
aDesc
.
mBitsPerChannel
*
aDesc
.
mChannelsPerFrame
)
/
8
;
aDesc
.
mBytesPerPacket
=
aDesc
.
mBytesPerFrame
*
aDesc
.
mFramesPerPacket
;
aDesc
.
mBytesPerPacket
=
aDesc
.
mBytesPerFrame
*
aDesc
.
mFramesPerPacket
;
aDesc
.
mSampleRate
=
48000
;
err
=
MovieAudioExtractionSetProperty
(
filter
->
aSession
,
err
=
MovieAudioExtractionSetProperty
(
filter
->
aSession
,
kQTPropertyClass_MovieAudioExtraction_Audio
,
kQTPropertyClass_MovieAudioExtraction_Audio
,
...
@@ -408,17 +411,17 @@ kQTMovieAudioExtractionAudioPropertyID_AudioStreamBasicDescription,
...
@@ -408,17 +411,17 @@ kQTMovieAudioExtractionAudioPropertyID_AudioStreamBasicDescription,
ERR
(
"Unhandled Frames per packet %li
\n
"
,
aDesc
.
mFramesPerPacket
);
ERR
(
"Unhandled Frames per packet %li
\n
"
,
aDesc
.
mFramesPerPacket
);
err
=
-
1
;
err
=
-
1
;
}
}
if
(
aDesc
.
mChannelsPerFrame
!=
2
)
if
(
aDesc
.
mChannelsPerFrame
!=
pvi
->
nChannels
)
{
{
ERR
(
"Unhandled channel count %li
\n
"
,
aDesc
.
mChannelsPerFrame
);
ERR
(
"Unhandled channel count %li
\n
"
,
aDesc
.
mChannelsPerFrame
);
err
=
-
1
;
err
=
-
1
;
}
}
if
(
aDesc
.
mBitsPerChannel
!=
16
)
if
(
aDesc
.
mBitsPerChannel
!=
pvi
->
wBitsPerSample
)
{
{
ERR
(
"Unhandled bits per channel %li
\n
"
,
aDesc
.
mBitsPerChannel
);
ERR
(
"Unhandled bits per channel %li
\n
"
,
aDesc
.
mBitsPerChannel
);
err
=
-
1
;
err
=
-
1
;
}
}
if
(
aDesc
.
mSampleRate
!=
48000
)
if
(
aDesc
.
mSampleRate
!=
pvi
->
nSamplesPerSec
)
{
{
ERR
(
"Unhandled sample rate %f
\n
"
,
aDesc
.
mSampleRate
);
ERR
(
"Unhandled sample rate %f
\n
"
,
aDesc
.
mSampleRate
);
err
=
-
1
;
err
=
-
1
;
...
@@ -463,8 +466,6 @@ static DWORD WINAPI QTSplitter_thread(LPVOID data)
...
@@ -463,8 +466,6 @@ static DWORD WINAPI QTSplitter_thread(LPVOID data)
LONGLONG
tStart
=
0
,
tStop
=
0
;
LONGLONG
tStart
=
0
,
tStop
=
0
;
float
time
;
float
time
;
MoviesTask
(
This
->
pQTMovie
,
0
);
QTVisualContextTask
(
This
->
vContext
);
GetMovieNextInterestingTime
(
This
->
pQTMovie
,
nextTimeStep
,
0
,
NULL
,
movie_time
,
1
,
&
next_time
,
NULL
);
GetMovieNextInterestingTime
(
This
->
pQTMovie
,
nextTimeStep
,
0
,
NULL
,
movie_time
,
1
,
&
next_time
,
NULL
);
if
(
next_time
==
-
1
)
if
(
next_time
==
-
1
)
...
@@ -497,26 +498,9 @@ static DWORD WINAPI QTSplitter_thread(LPVOID data)
...
@@ -497,26 +498,9 @@ static DWORD WINAPI QTSplitter_thread(LPVOID data)
UInt32
frames
;
UInt32
frames
;
WAVEFORMATEX
*
pvi
;
WAVEFORMATEX
*
pvi
;
float
duration
;
float
duration
;
static
int
audio_frame_size
=
0
;
pvi
=
(
WAVEFORMATEX
*
)
This
->
pAudio_Pin
->
pmt
->
pbFormat
;
pvi
=
(
WAVEFORMATEX
*
)
This
->
pAudio_Pin
->
pmt
->
pbFormat
;
if
(
audio_frame_size
==
0
)
audio_frame_size
=
(
pvi
->
wBitsPerSample
*
pvi
->
nChannels
)
/
8
;
tr
.
value
=
SInt64ToWide
(
movie_time
);
err
=
MovieAudioExtractionSetProperty
(
This
->
aSession
,
kQTPropertyClass_MovieAudioExtraction_Movie
,
kQTMovieAudioExtractionMoviePropertyID_CurrentTime
,
sizeof
(
TimeRecord
),
&
tr
);
if
(
err
!=
noErr
)
{
ERR
(
"Failed to set audio media time
\n
"
);
goto
audio_error
;
}
hr
=
BaseOutputPinImpl_GetDeliveryBuffer
((
BaseOutputPin
*
)
This
->
pAudio_Pin
,
&
sample
,
NULL
,
NULL
,
0
);
hr
=
BaseOutputPinImpl_GetDeliveryBuffer
((
BaseOutputPin
*
)
This
->
pAudio_Pin
,
&
sample
,
NULL
,
NULL
,
0
);
if
(
FAILED
(
hr
))
if
(
FAILED
(
hr
))
...
@@ -539,7 +523,7 @@ static DWORD WINAPI QTSplitter_thread(LPVOID data)
...
@@ -539,7 +523,7 @@ static DWORD WINAPI QTSplitter_thread(LPVOID data)
TRACE
(
"Need audio for %f seconds (%li frames)
\n
"
,
duration
,
frames
);
TRACE
(
"Need audio for %f seconds (%li frames)
\n
"
,
duration
,
frames
);
data_size
=
IMediaSample_GetSize
(
sample
);
data_size
=
IMediaSample_GetSize
(
sample
);
if
(
data_size
<
frames
*
audio_frame_size
)
if
(
data_size
<
frames
*
pvi
->
nBlockAlign
)
FIXME
(
"Audio buffer is too small
\n
"
);
FIXME
(
"Audio buffer is too small
\n
"
);
aData
.
mNumberBuffers
=
1
;
aData
.
mNumberBuffers
=
1
;
...
@@ -550,7 +534,7 @@ static DWORD WINAPI QTSplitter_thread(LPVOID data)
...
@@ -550,7 +534,7 @@ static DWORD WINAPI QTSplitter_thread(LPVOID data)
err
=
MovieAudioExtractionFillBuffer
(
This
->
aSession
,
&
frames
,
&
aData
,
&
flags
);
err
=
MovieAudioExtractionFillBuffer
(
This
->
aSession
,
&
frames
,
&
aData
,
&
flags
);
TRACE
(
"Got %i frames
\n
"
,(
int
)
frames
);
TRACE
(
"Got %i frames
\n
"
,(
int
)
frames
);
IMediaSample_SetActualDataLength
(
sample
,
frames
*
audio_frame_size
);
IMediaSample_SetActualDataLength
(
sample
,
frames
*
pvi
->
nBlockAlign
);
IMediaSample_SetMediaTime
(
sample
,
&
tStart
,
&
tStop
);
IMediaSample_SetMediaTime
(
sample
,
&
tStart
,
&
tStop
);
if
(
tStart
)
if
(
tStart
)
...
@@ -850,6 +834,12 @@ static HRESULT QT_Process_Audio_Track(QTSplitter* filter, Track trk)
...
@@ -850,6 +834,12 @@ static HRESULT QT_Process_Audio_Track(QTSplitter* filter, Track trk)
PIN_INFO
piOutput
;
PIN_INFO
piOutput
;
HRESULT
hr
=
S_OK
;
HRESULT
hr
=
S_OK
;
static
const
WCHAR
szwAudioOut
[]
=
{
'A'
,
'u'
,
'd'
,
'i'
,
'o'
,
0
};
static
const
WCHAR
szwAudioOut
[]
=
{
'A'
,
'u'
,
'd'
,
'i'
,
'o'
,
0
};
Media
audioMedia
;
SoundDescriptionHandle
aDesc
=
(
SoundDescriptionHandle
)
NewHandle
(
sizeof
(
SoundDescription
));
audioMedia
=
GetTrackMedia
(
trk
);
GetMediaSampleDescription
(
audioMedia
,
1
,
(
SampleDescriptionHandle
)
aDesc
);
ZeroMemory
(
&
amt
,
sizeof
(
amt
));
ZeroMemory
(
&
amt
,
sizeof
(
amt
));
amt
.
formattype
=
FORMAT_WaveFormatEx
;
amt
.
formattype
=
FORMAT_WaveFormatEx
;
...
@@ -864,12 +854,20 @@ static HRESULT QT_Process_Audio_Track(QTSplitter* filter, Track trk)
...
@@ -864,12 +854,20 @@ static HRESULT QT_Process_Audio_Track(QTSplitter* filter, Track trk)
pvi
->
cbSize
=
sizeof
(
WAVEFORMATEX
);
pvi
->
cbSize
=
sizeof
(
WAVEFORMATEX
);
pvi
->
wFormatTag
=
WAVE_FORMAT_PCM
;
pvi
->
wFormatTag
=
WAVE_FORMAT_PCM
;
pvi
->
nChannels
=
2
;
pvi
->
nChannels
=
((
SoundDescription
)
**
aDesc
).
numChannels
;
pvi
->
nSamplesPerSec
=
48000
;
if
(
pvi
->
nChannels
<
1
||
pvi
->
nChannels
>
2
)
pvi
->
wBitsPerSample
=
16
;
pvi
->
nChannels
=
2
;
pvi
->
nSamplesPerSec
=
(((
SoundDescription
)
**
aDesc
).
sampleRate
/
65536
);
if
(
pvi
->
nSamplesPerSec
<
8000
||
pvi
->
nChannels
>
48000
)
pvi
->
nSamplesPerSec
=
44100
;
pvi
->
wBitsPerSample
=
((
SoundDescription
)
**
aDesc
).
sampleSize
;
if
(
pvi
->
wBitsPerSample
<
8
||
pvi
->
wBitsPerSample
>
32
)
pvi
->
wBitsPerSample
=
16
;
pvi
->
nBlockAlign
=
(
pvi
->
nChannels
*
pvi
->
wBitsPerSample
)
/
8
;
pvi
->
nBlockAlign
=
(
pvi
->
nChannels
*
pvi
->
wBitsPerSample
)
/
8
;
pvi
->
nAvgBytesPerSec
=
pvi
->
nSamplesPerSec
*
pvi
->
nBlockAlign
;
pvi
->
nAvgBytesPerSec
=
pvi
->
nSamplesPerSec
*
pvi
->
nBlockAlign
;
DisposeHandle
((
Handle
)
aDesc
);
piOutput
.
dir
=
PINDIR_OUTPUT
;
piOutput
.
dir
=
PINDIR_OUTPUT
;
piOutput
.
pFilter
=
(
IBaseFilter
*
)
filter
;
piOutput
.
pFilter
=
(
IBaseFilter
*
)
filter
;
lstrcpyW
(
piOutput
.
achName
,
szwAudioOut
);
lstrcpyW
(
piOutput
.
achName
,
szwAudioOut
);
...
...
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