mirror of
https://github.com/halpz/re3.git
synced 2024-12-31 19:05:27 +00:00
1349 lines
48 KiB
Plaintext
1349 lines
48 KiB
Plaintext
|
|
/*++
|
|
|
|
Copyright (c) 2002 Microsoft Corporation
|
|
|
|
Module Name:
|
|
|
|
sbe.idl
|
|
|
|
Abstract:
|
|
|
|
This module the StreamBuffer interface definitions & CLSIDs, public
|
|
|
|
--*/
|
|
|
|
import "unknwn.idl" ;
|
|
import "wtypes.idl" ;
|
|
import "objidl.idl";
|
|
import "strmif.idl" ;
|
|
|
|
// ============================================================================
|
|
|
|
// interfaces
|
|
interface IStreamBufferSink ; // locking & recording
|
|
interface IStreamBufferSink2 ; // ext locking
|
|
interface IStreamBufferSink3 ; // specify the minimum
|
|
interface IStreamBufferSource ; // associates with IStreamBufferSink
|
|
interface IStreamBufferRecordControl ; // recording control
|
|
interface IStreamBufferRecordingAttribute ; // StreamBuffer attribute creation
|
|
interface IEnumStreamBufferRecordingAttrib ; // StreamBuffer attribute enumeration
|
|
interface IStreamBufferConfigure ; // configuration interface
|
|
interface IStreamBufferConfigure2 ; // configuration interface; more
|
|
interface IStreamBufferMediaSeeking ; // IMediaSeeking but with different GUID
|
|
interface IStreamBufferMediaSeeking2 ; // + available filter & frame rate on FF/RW
|
|
interface IStreamBufferPolicy ; // StreamBuffer policies
|
|
interface IStreamBufferInitialize ; // allows 3rd party app to set HKEY
|
|
interface IStreamBufferDataCounters ; // collect data rate from the pins
|
|
|
|
[
|
|
object,
|
|
uuid(9ce50f2d-6ba7-40fb-a034-50b1a674ec78),
|
|
pointer_default(unique)
|
|
]
|
|
[local] interface IStreamBufferInitialize : IUnknown
|
|
{
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
SetHKEY ()
|
|
|
|
Implemented on StreamBufferStreamSink and StreamBufferSource filters.
|
|
Gives a hosting application the ability to specify HKEY root in
|
|
registry. This method must called **early**: after the filter is
|
|
instantiated, but before StreamBufferSource is locked (explicitly or
|
|
implicitely) if calling the method on StreamBufferSource, or before
|
|
a source is set (via IStreamBufferSource or IFileSourceFilter) if
|
|
calling the method on StreamBufferStreamSource. If a call is made
|
|
after either filter has been initialized internally, the call will
|
|
fail with E_UNEXPECTED. The hosting application is responsible for
|
|
ensuring that the HKEY passed in is writable & readable per the
|
|
logged-on user privileges. The HKEY is duplicated internally,
|
|
so the caller can close it after making this call.
|
|
--*/
|
|
HRESULT
|
|
SetHKEY (
|
|
[in] HKEY hkeyRoot
|
|
) ;
|
|
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
SetSIDs ()
|
|
|
|
Implemented on StreamBufferStreamSink and StreamBufferSource filters.
|
|
Provides a way for the hosting application to specify security-level
|
|
sharing between capture and render processes and contexts. By
|
|
default security attributes are inherited from the hosting process,
|
|
unless the application overrides the defaults and provides them via
|
|
this method.
|
|
--*/
|
|
HRESULT
|
|
SetSIDs (
|
|
[in] DWORD cSIDs,
|
|
[in, size_is (cSIDs)] PSID * ppSID
|
|
) ;
|
|
} ;
|
|
|
|
/*++
|
|
============================================================================
|
|
============================================================================
|
|
IStreamBufferSink
|
|
|
|
Stream Source interface;
|
|
implemented on the StreamBufferSink filter;
|
|
Only way to get a recorder object's IUnknown (object will subsequently
|
|
be associated with this Sink)
|
|
--*/
|
|
|
|
enum {
|
|
RECORDING_TYPE_CONTENT = 0, // no post-recording or overlapped
|
|
RECORDING_TYPE_REFERENCE, // allows post-recording & overlapped
|
|
} ;
|
|
|
|
[
|
|
object,
|
|
uuid(afd1f242-7efd-45ee-ba4e-407a25c9a77a),
|
|
pointer_default(unique)
|
|
]
|
|
interface IStreamBufferSink : IUnknown
|
|
{
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
LockProfile ()
|
|
|
|
1. Locks the profile;
|
|
2. No *new* input pin connections will be accepted;
|
|
3. Existing pins that are, or have ever been, connected can be
|
|
reconnected if the media type is exactly the same as the first
|
|
successful connection;
|
|
4. Can be called multiple times with the same parameter as the initial
|
|
LockProfile() call was made with i.e. more than once with NULL if
|
|
initially locked with NULL, or more than once with a string if
|
|
initially locked with a string; if the profile is already locked,
|
|
and the parameters are the same, returns S_FALSE, else the call
|
|
fails (if trying to lock a locked profile with a different
|
|
parameter)
|
|
5. Must be called before the filter that implements this interface is
|
|
ever run; when it is run, it locks implicitely and this method has
|
|
no effect if called with NULL parameters, or fails if called with
|
|
non-NULL parameter for the reasons listed above;
|
|
6. Errors with VFW_E_UNSUPPORTED_STREAM if there are no streams in the
|
|
profile;
|
|
|
|
Parameter Detail
|
|
----------------
|
|
|
|
pszStreamBufferFilename
|
|
|
|
Is a NULL-terminated filename string. If the content written by
|
|
this sink is to be shared cross-process, this parameter specifies a
|
|
filename that will be opened by any reader(s) to read & render the
|
|
content sent into the sink.
|
|
|
|
Can be NULL (not specified)
|
|
|
|
Must be a full-path filename; if no path is specified, the file is
|
|
created in a "current" directory
|
|
|
|
If the file already exists, the call fails
|
|
|
|
Is opened with DELETE_ON_CLOSE flag, so is automatically deleted
|
|
when the sink is unlocked, or when the hosting process terminates
|
|
--*/
|
|
HRESULT
|
|
LockProfile (
|
|
[in] LPCWSTR pszStreamBufferFilename
|
|
) ;
|
|
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
CreateRecorder ()
|
|
|
|
1. Returns a *new* recorder object's IUnknown;
|
|
2. Caller can call QueryInterface() on the returned pointer to get
|
|
interface pointers to configure & control the recording;
|
|
3. Returned IUnknown pointer is ref'd & must be Release()'d by the
|
|
caller
|
|
4. IStreamBufferSink interface must have been locked (explicitely or
|
|
implicitely) prior to call
|
|
|
|
To create an ordinary recording, specify RECORDING_TYPE_CONTENT for the
|
|
dwRecordType parammeter. This will record the content directly into
|
|
the specified file. These recording types only accept start and stop
|
|
times that occur in the future.
|
|
|
|
A recording of type RECORDING_TYPE_REFERENCE generates a small file
|
|
that references content saved in temporary storage. Recordings of this
|
|
type can have start and stop times that occurs in the past, and can
|
|
overlap other same-type recordings.
|
|
|
|
Reference recording *content* will be saved in the same subdirectory as
|
|
the specified reference file, but with hidden and system attributes.
|
|
The naming convention of the files will append a _1.sbe, _2.sbe, etc...
|
|
to the filename (minus extension) specified in the call e.g. a
|
|
"seinfeld01.sbe" reference file will have saved content in hidden
|
|
and system files "seinfeld01_1.sbe", "seinfeld01_2.sbe", etc...
|
|
|
|
--*/
|
|
HRESULT
|
|
CreateRecorder (
|
|
[in] LPCWSTR pszFilename,
|
|
[in] DWORD dwRecordType, // RECORDING_TYPE_CONTENT or RECORDING_TYPE_REFERENCE
|
|
[out] IUnknown ** pRecordingIUnknown
|
|
) ;
|
|
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
IsProfileLocked ()
|
|
|
|
1. Returns S_OK if the profile is locked and S_FALSE if it is not.
|
|
2. Returns E_FAIL on error.
|
|
--*/
|
|
HRESULT
|
|
IsProfileLocked (
|
|
) ;
|
|
} ;
|
|
|
|
/*++
|
|
============================================================================
|
|
============================================================================
|
|
IStreamBufferSink2 ()
|
|
|
|
Stream Source interface;
|
|
implemented on the StreamBufferSink filter;
|
|
--*/
|
|
[
|
|
object,
|
|
uuid(DB94A660-F4FB-4bfa-BCC6-FE159A4EEA93),
|
|
pointer_default(unique)
|
|
]
|
|
interface IStreamBufferSink2 : IStreamBufferSink
|
|
{
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
UnlockProfile ()
|
|
|
|
1. Unlocks a profile explicitely.
|
|
2. Is a noop if the sink is not locked & returns S_FALSE.
|
|
3. Can only be called when the graph & filter are stopped.
|
|
4. Since recordings are bound to the "lock session", incomplete
|
|
recordings i.e. those that have never been started, are
|
|
invalidated & must be re-created under the next "lock session".
|
|
5. Profile still unlocks implicitly when the filter is stopped.
|
|
--*/
|
|
HRESULT
|
|
UnlockProfile (
|
|
) ;
|
|
} ;
|
|
|
|
/*++
|
|
============================================================================
|
|
============================================================================
|
|
IStreamBufferSink3 ()
|
|
|
|
Stream Source interface;
|
|
implemented on the StreamBufferSink filter;
|
|
--*/
|
|
[
|
|
object,
|
|
uuid(974723f2-887a-4452-9366-2cff3057bc8f),
|
|
pointer_default(unique)
|
|
]
|
|
interface IStreamBufferSink3 : IStreamBufferSink2
|
|
{
|
|
/*++
|
|
-----------------------------------------------------------------------
|
|
SetAvailableFilter ()
|
|
|
|
Bounds the minimum. This affects readers so they cannot seek past
|
|
the specified minimum.
|
|
|
|
Parameter Detail
|
|
----------------
|
|
|
|
prtMin
|
|
|
|
min time relative to "now"
|
|
|
|
cannot be NULL
|
|
|
|
[in]: time, specified relative to the last sample written, to set
|
|
as the minimum time available to readers; valid values are <= 0;
|
|
use -MAXLONGLONG if all the backing store should be made available.
|
|
|
|
[out]: actual min time; if the [in] value further back than what is
|
|
available, the [out] value will be set to the actual time made
|
|
available.
|
|
|
|
Return Values
|
|
-------------
|
|
|
|
success S_OK
|
|
|
|
failure error code
|
|
--*/
|
|
HRESULT
|
|
SetAvailableFilter (
|
|
[in, out] REFERENCE_TIME * prtMin
|
|
) ;
|
|
} ;
|
|
|
|
/*++
|
|
============================================================================
|
|
============================================================================
|
|
IStreamBufferSource ()
|
|
|
|
Stream Source reader interface;
|
|
Implemented on the StreamBufferSource filter;
|
|
--*/
|
|
[
|
|
object,
|
|
uuid(1c5bd776-6ced-4f44-8164-5eab0e98db12),
|
|
pointer_default(unique)
|
|
]
|
|
interface IStreamBufferSource : IUnknown
|
|
{
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
SetStreamSink ()
|
|
|
|
1. Sets the StreamBuffer Sink that streams from this Source;
|
|
2. IStreamBufferSink object must be in the same process as this object;
|
|
3. Interface is AddRef()'d if the call succeeds;
|
|
|
|
Parameter Detail
|
|
----------------
|
|
|
|
pIStreamBufferSink
|
|
|
|
Sink that will stream to this Source
|
|
--*/
|
|
HRESULT
|
|
SetStreamSink (
|
|
[in] IStreamBufferSink * pIStreamBufferSink
|
|
) ;
|
|
} ;
|
|
|
|
/*++
|
|
============================================================================
|
|
============================================================================
|
|
IStreamBufferRecordControl
|
|
|
|
obtained by QIing IStreamBufferSink::CreateRecorder()-returned IUnknown *
|
|
--*/
|
|
[
|
|
object,
|
|
uuid(ba9b6c99-f3c7-4ff2-92db-cfdd4851bf31),
|
|
pointer_default(unique)
|
|
]
|
|
interface IStreamBufferRecordControl : IUnknown
|
|
{
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
Start ()
|
|
|
|
1. Starts a recording;
|
|
2. Will save to the filename that is specified when this interface's
|
|
IUnknown is requested (IStreamBufferSink::CreateRecorder());
|
|
|
|
Parameter Detail
|
|
----------------
|
|
|
|
rtStart
|
|
|
|
Start time relative to "now;
|
|
|
|
If the recording type is a content recording, can only refer to
|
|
seconds in the future; allowed seconds are [0,5]
|
|
|
|
If the recording type is a reference recording, can refer to any
|
|
time that still has valid content i.e. content that has not yet
|
|
become stale
|
|
|
|
If the recording is a reference recording and (* prtStart) is
|
|
earlier than the earliest still-valid content, the call will reset
|
|
it to the earliest content; the value when the recording was
|
|
actually started will be [out]
|
|
--*/
|
|
HRESULT
|
|
Start (
|
|
[in,out] REFERENCE_TIME * prtStart
|
|
) ;
|
|
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
Stop ()
|
|
|
|
1. Stops a recording;
|
|
2. Closes out the file;
|
|
|
|
Parameter Detail
|
|
----------------
|
|
|
|
rtStart
|
|
|
|
Stop time relative to "now;
|
|
|
|
If the recording type is a content recording, can only refer to
|
|
seconds in the future; allowed seconds are [0,5]
|
|
|
|
If the recording type is a reference recording, can refer to any
|
|
time that still has valid content i.e. content that has not yet
|
|
become stale; stop time cannot be <= start time
|
|
--*/
|
|
HRESULT
|
|
Stop (
|
|
[in] REFERENCE_TIME rtStop
|
|
) ;
|
|
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
GetRecordingStatus ()
|
|
|
|
1. Retrieves the status of the recording
|
|
|
|
Parameter Detail
|
|
----------------
|
|
|
|
phResult
|
|
|
|
The (current) status of writing or closing the recording file;
|
|
|
|
Can be NULL;
|
|
|
|
pbStarted
|
|
|
|
If supplied, set to a non-zero value if the recording has been
|
|
started
|
|
|
|
Can be NULL;
|
|
|
|
pbStopped
|
|
|
|
If supplied, set to a non-zero value if the recording has been
|
|
stopped;
|
|
|
|
Can be NULL;
|
|
|
|
NOTE: If the recording has never been started, it will not be flagged
|
|
as stopped.
|
|
|
|
--*/
|
|
HRESULT
|
|
GetRecordingStatus (
|
|
[out] HRESULT * phResult,
|
|
[out] BOOL * pbStarted,
|
|
[out] BOOL * pbStopped
|
|
) ;
|
|
} ;
|
|
|
|
/*++
|
|
============================================================================
|
|
============================================================================
|
|
IStreamBufferRecComp
|
|
|
|
CoCreateInstance CLSID_StreamBufferComposeRecording and QueryInterface for
|
|
this interface; this interface allows the creation of a single target
|
|
content recording which consists of a number of concatenated recordings
|
|
(reference or content; can mix & match if desired)
|
|
--*/
|
|
|
|
[
|
|
object,
|
|
uuid(9E259A9B-8815-42ae-B09F-221970B154FD),
|
|
pointer_default(unique)
|
|
]
|
|
interface IStreamBufferRecComp : IUnknown
|
|
{
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
Initialize ()
|
|
|
|
1. Initializes for a target recording
|
|
|
|
Parameter Detail
|
|
----------------
|
|
|
|
pszTargetFilename
|
|
|
|
Sets the target filename
|
|
|
|
Fails if the file already exists
|
|
|
|
pszSBRecProfileRef
|
|
|
|
Must be a completed, SBE-generated recording
|
|
|
|
This recording's profile will be used to define the target profile
|
|
|
|
Appended files must have exactly the same profile
|
|
--*/
|
|
HRESULT
|
|
Initialize (
|
|
[in] LPCWSTR pszTargetFilename,
|
|
[in] LPCWSTR pszSBRecProfileRef
|
|
) ;
|
|
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
Append ()
|
|
|
|
1. appends an entire recording
|
|
2. fails if the recording is live
|
|
--*/
|
|
HRESULT
|
|
Append (
|
|
[in] LPCWSTR pszSBRecording
|
|
) ;
|
|
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
AppendEx ()
|
|
|
|
1. appends the specified portion of the recording; the parameters must
|
|
be accurate; the call will not readjust them within the boundaries
|
|
2. the time spread must be at least 2 seconds
|
|
3. fails if the recording is live
|
|
--*/
|
|
HRESULT
|
|
AppendEx (
|
|
[in] LPCWSTR pszSBRecording,
|
|
[in] REFERENCE_TIME rtStart,
|
|
[in] REFERENCE_TIME rtStop
|
|
) ;
|
|
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
GetCurrentLength ()
|
|
|
|
1. returns the current length of the recording; updates as recordings
|
|
are appended;
|
|
2. can be called repeatedly during a Append() call on another
|
|
thread;
|
|
--*/
|
|
HRESULT
|
|
GetCurrentLength (
|
|
[out] DWORD * pcSeconds
|
|
) ;
|
|
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
Close ()
|
|
|
|
1. explicitely closes the recording
|
|
|
|
2. final release of interface closes the recording as well
|
|
--*/
|
|
HRESULT
|
|
Close (
|
|
) ;
|
|
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
Cancel ()
|
|
|
|
1. cancels an in-progress appending operation; has no effect otherwise
|
|
--*/
|
|
HRESULT
|
|
Cancel (
|
|
) ;
|
|
} ;
|
|
|
|
/*++
|
|
============================================================================
|
|
============================================================================
|
|
IStreamBufferRecordingAttribute
|
|
|
|
obtained by calling QueryInterface on a recorder
|
|
|
|
well-known attributes:
|
|
|
|
NAME DESCRIPTION
|
|
------------------- ----------------------------------------------------
|
|
|
|
Title String containing the content title.
|
|
|
|
Author String containing the name of the content author.
|
|
|
|
Description String containing a description of the content.
|
|
|
|
Rating String containing a content rating.
|
|
|
|
Copyright String containing a content copyright message.
|
|
|
|
Duration Quadruple word value containing the playing duration
|
|
of the file, in 100-nanosecond units.
|
|
|
|
Bitrate Double word value containing the bit rate.
|
|
|
|
Seekable Boolean value; true denoting that the content is
|
|
seekable.
|
|
|
|
Stridable Boolean value, true denoting that the content is
|
|
stridable (fast forward and rewind are enabled).
|
|
|
|
Broadcast Boolean value; true denoting that the content is not
|
|
copyright-protected, and can be broadcast.
|
|
|
|
Use_DRM reserved
|
|
|
|
DRM_Flags reserved
|
|
|
|
DRM_Level reserved
|
|
|
|
Is_Protected reserved
|
|
|
|
Is_Trusted reserved
|
|
|
|
Signature_Name reserved
|
|
|
|
HasAudio Boolean, true denoting the content includes an
|
|
audio stream.
|
|
|
|
HasImage Boolean, true denoting the content includes a still
|
|
image stream (such as JPEG images).
|
|
|
|
HasScript Boolean, true denoting the content includes a script
|
|
stream.
|
|
|
|
HasVideo Boolean, true denoting the content includes a video
|
|
stream.
|
|
|
|
CurrentBitrate Double word containing the current total bitrate,
|
|
usually used for MEB (multi-bit rate) streams.
|
|
|
|
OptimalBitrate Double word containing the minimum total bitrate
|
|
recommended to stream the content and get
|
|
maximum quality.
|
|
|
|
WM/AlbumTitle String containing the album title.
|
|
|
|
WM/Track Double word containing the track number.
|
|
|
|
WM/PromotionURL String with a URL to an HTML page that contains
|
|
information about products and events (such as
|
|
concerts) that are related to this music.
|
|
|
|
WM/AlbumCoverURL String with a URL to an HTML page that contains an
|
|
image of the album cover and information about
|
|
the album.
|
|
|
|
WM/Genre String with the genre of the music.
|
|
|
|
WM/Year String with the year of publication of the music.
|
|
|
|
WM/GenreID
|
|
|
|
WM/MCDI
|
|
|
|
BannerImageType One member of the WMT_ATTR_IMAGETYPE enumeration
|
|
type.
|
|
|
|
BannerImageData The actual image data: a bitmap, JPEG, or GIF image.
|
|
|
|
|
|
BannerImageURL If the banner image is clicked on then this URL is
|
|
activated.
|
|
|
|
CopyrightURL An URL to a copyright page.
|
|
|
|
NSC_Name String containing the multicast station contact
|
|
name (read-only).
|
|
|
|
NSC_Address String containing the multicast station contact
|
|
address (read-only).
|
|
|
|
NSC_Phone String containing the multicast station contact
|
|
phone number (read-only).
|
|
|
|
NSC_Email String containing the multicast station contact
|
|
email address (read-only).
|
|
|
|
NSC_Description String containing the multicast station contact
|
|
description (read-only).
|
|
|
|
--*/
|
|
|
|
cpp_quote( "////////////////////////////////////////////////////////////////" )
|
|
cpp_quote( "//" )
|
|
cpp_quote( "// List of pre-defined attributes " )
|
|
cpp_quote( "//" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingDuration[] =L\"Duration\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingBitrate[] =L\"Bitrate\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingSeekable[] =L\"Seekable\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingStridable[] =L\"Stridable\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingBroadcast[] =L\"Broadcast\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingProtected[] =L\"Is_Protected\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingTrusted[] =L\"Is_Trusted\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingSignature_Name[] =L\"Signature_Name\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingHasAudio[] =L\"HasAudio\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingHasImage[] =L\"HasImage\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingHasScript[] =L\"HasScript\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingHasVideo[] =L\"HasVideo\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingCurrentBitrate[] =L\"CurrentBitrate\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingOptimalBitrate[] =L\"OptimalBitrate\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingHasAttachedImages[] =L\"HasAttachedImages\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingSkipBackward[] =L\"Can_Skip_Backward\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingSkipForward[] =L\"Can_Skip_Forward\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingNumberOfFrames[] =L\"NumberOfFrames\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingFileSize[] =L\"FileSize\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingHasArbitraryDataStream[] =L\"HasArbitraryDataStream\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingHasFileTransferStream[] =L\"HasFileTransferStream\";" )
|
|
cpp_quote( "" )
|
|
cpp_quote( "////////////////////////////////////////////////////////////////" )
|
|
cpp_quote( "//" )
|
|
cpp_quote( "// The content description object supports 5 basic attributes." )
|
|
cpp_quote( "//" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingTitle[] =L\"Title\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingAuthor[] =L\"Author\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingDescription[] =L\"Description\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingRating[] =L\"Rating\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingCopyright[] =L\"Copyright\";" )
|
|
cpp_quote( "" )
|
|
cpp_quote( "////////////////////////////////////////////////////////////////" )
|
|
cpp_quote( "//" )
|
|
cpp_quote( "// These attributes are used to configure DRM using IWMDRMWriter::SetDRMAttribute." )
|
|
cpp_quote( "//" )
|
|
cpp_quote( "static const WCHAR *g_wszStreamBufferRecordingUse_DRM = L\"Use_DRM\";" )
|
|
cpp_quote( "static const WCHAR *g_wszStreamBufferRecordingDRM_Flags = L\"DRM_Flags\";" )
|
|
cpp_quote( "static const WCHAR *g_wszStreamBufferRecordingDRM_Level = L\"DRM_Level\";" )
|
|
cpp_quote( "" )
|
|
cpp_quote( "////////////////////////////////////////////////////////////////" )
|
|
cpp_quote( "//" )
|
|
cpp_quote( "// These are the additional attributes defined in the WM attribute" )
|
|
cpp_quote( "// namespace that give information about the content." )
|
|
cpp_quote( "//" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingAlbumTitle[] =L\"WM/AlbumTitle\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingTrack[] =L\"WM/Track\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingPromotionURL[] =L\"WM/PromotionURL\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingAlbumCoverURL[] =L\"WM/AlbumCoverURL\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingGenre[] =L\"WM/Genre\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingYear[] =L\"WM/Year\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingGenreID[] =L\"WM/GenreID\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingMCDI[] =L\"WM/MCDI\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingComposer[] =L\"WM/Composer\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingLyrics[] =L\"WM/Lyrics\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingTrackNumber[] =L\"WM/TrackNumber\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingToolName[] =L\"WM/ToolName\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingToolVersion[] =L\"WM/ToolVersion\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingIsVBR[] =L\"IsVBR\";" )
|
|
|
|
//
|
|
// WM/AlbumArtist is a potentially different value than Author
|
|
//
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingAlbumArtist[] =L\"WM/AlbumArtist\";" )
|
|
cpp_quote( "" )
|
|
|
|
cpp_quote( "////////////////////////////////////////////////////////////////" )
|
|
cpp_quote( "//" )
|
|
cpp_quote( "// These optional attributes may be used to give information " )
|
|
cpp_quote( "// about the branding of the content." )
|
|
cpp_quote( "//" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingBannerImageType[] =L\"BannerImageType\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingBannerImageData[] =L\"BannerImageData\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingBannerImageURL[] =L\"BannerImageURL\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingCopyrightURL[] =L\"CopyrightURL\";" )
|
|
|
|
cpp_quote( "////////////////////////////////////////////////////////////////" )
|
|
cpp_quote( "//" )
|
|
cpp_quote( "// Optional attributes, used to give information " )
|
|
cpp_quote( "// about video stream properties." )
|
|
cpp_quote( "//" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingAspectRatioX[] =L\"AspectRatioX\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingAspectRatioY[] =L\"AspectRatioY\";" )
|
|
|
|
cpp_quote( "////////////////////////////////////////////////////////////////" )
|
|
cpp_quote( "//" )
|
|
cpp_quote( "// The NSC file supports the following attributes." )
|
|
cpp_quote( "//" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingNSCName[] =L\"NSC_Name\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingNSCAddress[] =L\"NSC_Address\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingNSCPhone[] =L\"NSC_Phone\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingNSCEmail[] =L\"NSC_Email\";" )
|
|
cpp_quote( "static const WCHAR g_wszStreamBufferRecordingNSCDescription[] =L\"NSC_Description\";" )
|
|
cpp_quote( "" )
|
|
|
|
//
|
|
// StreamBuffer Attribute datatypes;
|
|
//
|
|
typedef enum {
|
|
STREAMBUFFER_TYPE_DWORD = 0,
|
|
STREAMBUFFER_TYPE_STRING = 1,
|
|
STREAMBUFFER_TYPE_BINARY = 2,
|
|
STREAMBUFFER_TYPE_BOOL = 3,
|
|
STREAMBUFFER_TYPE_QWORD = 4,
|
|
STREAMBUFFER_TYPE_WORD = 5,
|
|
STREAMBUFFER_TYPE_GUID = 6,
|
|
} STREAMBUFFER_ATTR_DATATYPE ;
|
|
|
|
[
|
|
object,
|
|
uuid(16CA4E03-FE69-4705-BD41-5B7DFC0C95F3),
|
|
pointer_default(unique)
|
|
]
|
|
interface IStreamBufferRecordingAttribute : IUnknown
|
|
{
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
SetAttribute ()
|
|
|
|
1. Sets an attribute on a recording object;
|
|
2. Fails if the IStreamBufferRecordControl::Start has already been successfully
|
|
called;
|
|
3. If an attribute of the same name already exists, overwrites the old;
|
|
--*/
|
|
HRESULT
|
|
SetAttribute (
|
|
[in] ULONG ulReserved,
|
|
[in] LPCWSTR pszAttributeName,
|
|
[in] STREAMBUFFER_ATTR_DATATYPE StreamBufferAttributeType,
|
|
[in, size_is (cbAttributeLength)] BYTE * pbAttribute,
|
|
[in] WORD cbAttributeLength
|
|
) ;
|
|
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
GetAttributeCount ()
|
|
|
|
1. Returns the count of attributes currently set;
|
|
--*/
|
|
HRESULT
|
|
GetAttributeCount (
|
|
[in] ULONG ulReserved,
|
|
[out] WORD * pcAttributes
|
|
) ;
|
|
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
GetAttributeByName ()
|
|
|
|
1. Given a name, returns the attribute data;
|
|
2. If the provided buffer is too small, returns VFW_E_BUFFER_OVERFLOW,
|
|
and (* pcbLength) contains the minimum required length of the buffer
|
|
3. To learn the length of the attribute, pass in non-NULL pcbLength,
|
|
and NULL pbAttribute parameter; [out] value will be the length of
|
|
the attribute
|
|
--*/
|
|
HRESULT
|
|
GetAttributeByName (
|
|
[in] LPCWSTR pszAttributeName,
|
|
[in] ULONG * pulReserved,
|
|
[out] STREAMBUFFER_ATTR_DATATYPE * pStreamBufferAttributeType,
|
|
[out, size_is (* pcbLength)] BYTE * pbAttribute,
|
|
[in, out] WORD * pcbLength
|
|
) ;
|
|
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
GetAttributeByIndex ()
|
|
|
|
1. Given an 0-based index, returns the attribute name and data
|
|
2. If either buffer is too small, returns VFW_E_BUFFER_OVERFLOW, and
|
|
(* pcbLength) and (* pcchNameLength) contain the minimum required
|
|
length of each buffer
|
|
3. The length returned by pcchNameLength includes the null-terminator
|
|
4. To learn the length of the name & attribute, pass in non-NULL
|
|
pcchNameLength & pcbLength, and NULL pszAttributeName & pbAttribute
|
|
parameters; [out] value of the non-NULL parameters will be the
|
|
lengths of the name and attribute
|
|
--*/
|
|
HRESULT
|
|
GetAttributeByIndex (
|
|
[in] WORD wIndex,
|
|
[in] ULONG * pulReserved,
|
|
[out] WCHAR * pszAttributeName,
|
|
[in, out] WORD * pcchNameLength, // includes NULL-terminator; in BYTES
|
|
[out] STREAMBUFFER_ATTR_DATATYPE * pStreamBufferAttributeType,
|
|
[out, size_is (* pcbLength)] BYTE * pbAttribute,
|
|
[in, out] WORD * pcbLength
|
|
) ;
|
|
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
EnumAttributes ()
|
|
|
|
1. Returns a StreamBuffer attribute enumeration object that snapshots
|
|
the attributes at time-of-call
|
|
--*/
|
|
HRESULT
|
|
EnumAttributes (
|
|
[out] IEnumStreamBufferRecordingAttrib ** ppIEnumStreamBufferAttrib
|
|
) ;
|
|
} ;
|
|
|
|
/*++
|
|
============================================================================
|
|
============================================================================
|
|
IEnumStreamBufferRecordingAttrib
|
|
|
|
obtained by calling IStreamBufferRecordingAttribute::EnumAttributes, or
|
|
calling clone on this interface
|
|
--*/
|
|
|
|
typedef struct {
|
|
LPWSTR pszName ; // allocated by callee; freed by caller
|
|
STREAMBUFFER_ATTR_DATATYPE StreamBufferAttributeType ;
|
|
BYTE * pbAttribute ; // allocated by callee; freed by caller
|
|
WORD cbLength ;
|
|
} STREAMBUFFER_ATTRIBUTE ;
|
|
|
|
[
|
|
object,
|
|
uuid (C18A9162-1E82-4142-8C73-5690FA62FE33),
|
|
pointer_default(unique)
|
|
]
|
|
interface IEnumStreamBufferRecordingAttrib : IUnknown
|
|
{
|
|
HRESULT
|
|
Next (
|
|
[in] ULONG cRequest,
|
|
[in, out, size_is (cRequest)] STREAMBUFFER_ATTRIBUTE * pStreamBufferAttribute,
|
|
[out] ULONG * pcReceived
|
|
) ;
|
|
|
|
HRESULT
|
|
Skip (
|
|
[in] ULONG cRecords
|
|
) ;
|
|
|
|
HRESULT
|
|
Reset (
|
|
) ;
|
|
|
|
HRESULT
|
|
Clone (
|
|
[out] IEnumStreamBufferRecordingAttrib ** ppIEnumStreamBufferAttrib
|
|
) ;
|
|
} ;
|
|
|
|
/*++
|
|
============================================================================
|
|
============================================================================
|
|
IStreamBufferConfigure
|
|
|
|
--*/
|
|
[
|
|
object,
|
|
uuid(ce14dfae-4098-4af7-bbf7-d6511f835414),
|
|
pointer_default(unique)
|
|
]
|
|
interface IStreamBufferConfigure : IUnknown
|
|
{
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
SetStreamBufferDirectory ()
|
|
|
|
1. Sets the directory where all content is saved, ringbuffer &
|
|
StreamBuffer;
|
|
2. Creates directory if necessary;
|
|
3. All TEMP files have hidden+system attributes
|
|
--*/
|
|
HRESULT
|
|
SetDirectory (
|
|
[in] LPCWSTR pszDirectoryName
|
|
) ;
|
|
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
GetStreamBufferDirectory ()
|
|
|
|
1. Retrieves previously set backing store directory, or default
|
|
location if none was specified
|
|
--*/
|
|
HRESULT
|
|
GetDirectory (
|
|
[out] LPWSTR * ppszDirectoryName
|
|
) ;
|
|
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
SetBackingFileCount ()
|
|
|
|
1. Sets the number of backing files
|
|
2. valid values
|
|
|
|
4 <= min <= 100
|
|
6 <= max <= 102
|
|
min max delta >= 2
|
|
--*/
|
|
HRESULT
|
|
SetBackingFileCount (
|
|
[in] DWORD dwMin,
|
|
[in] DWORD dwMax
|
|
) ;
|
|
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
GetBackingFileCount ()
|
|
|
|
1. Retrieves previously set backing file counts, or defaults if none
|
|
have have been set
|
|
--*/
|
|
HRESULT
|
|
GetBackingFileCount (
|
|
[out] DWORD * pdwMin,
|
|
[out] DWORD * pdwMax
|
|
) ;
|
|
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
SetEachBackingFileDuration ()
|
|
|
|
1. Sets the seconds of content each backing file will hold
|
|
2. valid values:
|
|
|
|
dwSeconds >= 15
|
|
--*/
|
|
HRESULT
|
|
SetBackingFileDuration (
|
|
[in] DWORD dwSeconds
|
|
) ;
|
|
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
GetEachBackingFileDuration ()
|
|
|
|
1. Retrieves previously set backing file duration, or default of none
|
|
is set
|
|
--*/
|
|
HRESULT
|
|
GetBackingFileDuration (
|
|
[out] DWORD * pdwSeconds
|
|
) ;
|
|
} ;
|
|
|
|
/*++
|
|
============================================================================
|
|
============================================================================
|
|
IStreamBufferConfigure2
|
|
|
|
--*/
|
|
[
|
|
object,
|
|
uuid(53E037BF-3992-4282-AE34-2487B4DAE06B),
|
|
pointer_default(unique)
|
|
]
|
|
interface IStreamBufferConfigure2 : IStreamBufferConfigure
|
|
{
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
SetMultiplexedPacketSize ()
|
|
|
|
1. sets the size of the target multiplexed packet size
|
|
2. valid values:
|
|
|
|
8192 <= cbBytesPerPacket <= 65535
|
|
|
|
This is useful if low-bitrate streams are used, and the time to fill a
|
|
multiplexed packet is excessive when the default value of 65535 bytes
|
|
is used.
|
|
--*/
|
|
HRESULT
|
|
SetMultiplexedPacketSize (
|
|
[in] DWORD cbBytesPerPacket
|
|
) ;
|
|
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
GetMultiplexedPacketSize ()
|
|
|
|
1. gets the size of the target multiplexed packet size
|
|
--*/
|
|
HRESULT
|
|
GetMultiplexedPacketSize (
|
|
[out] DWORD * pcbBytesPerPacket
|
|
) ;
|
|
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
SetFFTransitionRates ()
|
|
|
|
1. sets the fast forward (FF) rates for which the Stream Buffer Engine
|
|
transitions from FullFrame to KeyFrame to KeyFrame + Seeks.
|
|
2. valid values:
|
|
|
|
1 < dwMaxFullFrameRate < dwMaxNonSkippingRate
|
|
|
|
FF playback transitions from full-frame play, then to all keyframes,
|
|
then to keyframes + seekaheads. This method allows the transition
|
|
rates to be set. By default they are 4 and 6. If the rate is in (0,4]
|
|
all the frames are sent to the codec. If the rate is in (4,6] just
|
|
keyframes are sent. If the rate is > 6, then only keyframes are sent,
|
|
and a seekahead between keyframes is used that is proportionally
|
|
aggressive to the specified rate.
|
|
--*/
|
|
HRESULT
|
|
SetFFTransitionRates (
|
|
[in] DWORD dwMaxFullFrameRate,
|
|
[in] DWORD dwMaxNonSkippingRate
|
|
) ;
|
|
|
|
/*++
|
|
------------------------------------------------------------------------
|
|
GetFFTransitionRates ()
|
|
|
|
1. gets the fast forward (FF) rates for which the Stream Buffer Engine
|
|
transitions from FullFrame to KeyFrame to KeyFrameWithSeeks.
|
|
--*/
|
|
HRESULT
|
|
GetFFTransitionRates (
|
|
[out] DWORD * pdwMaxFullFrameRate,
|
|
[out] DWORD * pdwMaxNonSkippingRate
|
|
) ;
|
|
} ;
|
|
|
|
/*++
|
|
============================================================================
|
|
============================================================================
|
|
IStreamBufferMediaSeeking
|
|
|
|
Implemented on the StreamBufferSource filter. Used to seek and set the
|
|
playback rate.
|
|
|
|
--*/
|
|
|
|
[
|
|
object,
|
|
uuid(f61f5c26-863d-4afa-b0ba-2f81dc978596),
|
|
pointer_default(unique)
|
|
]
|
|
interface IStreamBufferMediaSeeking : IMediaSeeking
|
|
{
|
|
// no additional methods have been added
|
|
} ;
|
|
|
|
/*++
|
|
============================================================================
|
|
============================================================================
|
|
IStreamBufferMediaSeeking2
|
|
|
|
Implemented on the StreamBufferSource filter. Used to seek and set the
|
|
playback rate.
|
|
|
|
--*/
|
|
|
|
[
|
|
object,
|
|
uuid(3a439ab0-155f-470a-86a6-9ea54afd6eaf),
|
|
pointer_default(unique)
|
|
]
|
|
interface IStreamBufferMediaSeeking2 : IStreamBufferMediaSeeking
|
|
{
|
|
/*++
|
|
-----------------------------------------------------------------------
|
|
SetRateEx ()
|
|
|
|
Allows the application to override SBE's trick mode seekahead
|
|
computation.
|
|
|
|
The specified frame rate will, on average, be correct, but may
|
|
have some variance if averaged over short periods of time. This is
|
|
due to the content's compression schema.
|
|
|
|
The frame rate is applied to the video stream, if one exists. If no
|
|
video stream exists, the rate call fails. The framerate parameter
|
|
(dwFramesPerSec) is ignored when the specified abs(rate) is less than or
|
|
equal to the maximum non-skipping rate (see IStreamBufferConfigure2::
|
|
SetFFTransitionRates ()).
|
|
|
|
Parameter Detail
|
|
----------------
|
|
|
|
dRate rate at which the content is to be played.
|
|
valid values are all rates, excluding the following
|
|
range: (-0.1, 0.1)
|
|
|
|
dwFramesPerSec frames per second
|
|
cannot be 0
|
|
SBE does not enforce this parameter with respect to
|
|
the screen refresh rate
|
|
ignored if the abs(dRate) value is <= max non-
|
|
skipping rate (see IStreamBufferConfigure2::
|
|
SetFFTransitionRates ()).
|
|
|
|
Return Values
|
|
-------------
|
|
|
|
success S_OK
|
|
|
|
failure error code
|
|
--*/
|
|
HRESULT
|
|
SetRateEx (
|
|
[in] double dRate,
|
|
[in] DWORD dwFramesPerSec
|
|
) ;
|
|
} ;
|
|
|
|
|
|
/*++
|
|
============================================================================
|
|
============================================================================
|
|
IStreamBufferDataCounters
|
|
|
|
Implemented on the StreamBufferSource & StreamBufferSink filter pins. Used
|
|
to get instantaneous traffic counters for the pin.
|
|
|
|
--*/
|
|
|
|
typedef struct {
|
|
ULONGLONG cDataBytes ; // total sample payload bytes
|
|
ULONGLONG cSamplesProcessed ; // samples processed
|
|
ULONGLONG cDiscontinuities ; // number of discontinuities
|
|
ULONGLONG cSyncPoints ; // number of syncpoints
|
|
ULONGLONG cTimestamps ; // number of timestamps
|
|
} SBE_PIN_DATA ;
|
|
|
|
[
|
|
object,
|
|
uuid(9D2A2563-31AB-402e-9A6B-ADB903489440),
|
|
pointer_default(unique)
|
|
]
|
|
interface IStreamBufferDataCounters : IUnknown
|
|
{
|
|
// retrieves the instantaneous values in the data structure
|
|
HRESULT
|
|
GetData (
|
|
[out] SBE_PIN_DATA * pPinData
|
|
) ;
|
|
|
|
// sets all the data structure values to 0
|
|
HRESULT
|
|
ResetData (
|
|
) ;
|
|
} ;
|
|
|
|
/*++
|
|
============================================================================
|
|
============================================================================
|
|
events
|
|
--*/
|
|
|
|
// see evcode.h comment for range
|
|
// stream buffer engine (PVR) 0x0326 - 0x0350 (sbe.idl)
|
|
|
|
cpp_quote ("#define STREAMBUFFER_EC_BASE 0x0326")
|
|
|
|
cpp_quote ("enum {")
|
|
cpp_quote (" // timehole event")
|
|
cpp_quote (" // param1 = timehole stream offset ms")
|
|
cpp_quote (" // param1 = timehole size ms")
|
|
cpp_quote (" STREAMBUFFER_EC_TIMEHOLE = STREAMBUFFER_EC_BASE,")
|
|
cpp_quote (" ")
|
|
cpp_quote (" STREAMBUFFER_EC_STALE_DATA_READ,")
|
|
cpp_quote (" ")
|
|
cpp_quote (" STREAMBUFFER_EC_STALE_FILE_DELETED,")
|
|
cpp_quote (" STREAMBUFFER_EC_CONTENT_BECOMING_STALE,")
|
|
cpp_quote (" STREAMBUFFER_EC_WRITE_FAILURE,")
|
|
cpp_quote (" //")
|
|
cpp_quote (" // unexpected read failure")
|
|
cpp_quote (" // param1 = HRESULT failure")
|
|
cpp_quote (" // param2 = undefined")
|
|
cpp_quote (" STREAMBUFFER_EC_READ_FAILURE,")
|
|
cpp_quote (" //")
|
|
cpp_quote (" // playback rate change")
|
|
cpp_quote (" // param1 = old_playback_rate * 10000 e.g. 2x is 20000")
|
|
cpp_quote (" // param2 = new_playback_rate * 10000")
|
|
cpp_quote (" STREAMBUFFER_EC_RATE_CHANGED,")
|
|
cpp_quote ("} ;")
|
|
|
|
/*++
|
|
============================================================================
|
|
============================================================================
|
|
trick mode
|
|
|
|
We've extended the 1.0 interfaces as follows:
|
|
|
|
1. source filter presents timestamps that monotonically increase overtime
|
|
|
|
2. flushes should have no effect over queued rate segments
|
|
|
|
3. discontinuities have no effect over queued rate segments
|
|
|
|
To use the interface, continue to use AM_KSPROPSETID_TSRateChange, but use
|
|
dwPropId that is higher
|
|
|
|
--*/
|
|
|
|
#ifdef USE_AM_PROPERTY_TS_RATE_CHANGE_11
|
|
cpp_quote ("typedef enum {")
|
|
cpp_quote (" AM_RATE_UseRateVersion = AM_RATE_Step + 1,")
|
|
cpp_quote (" AM_RATE_QueryFullFrameRate,")
|
|
cpp_quote (" AM_RATE_QueryLastRateSegPTS")
|
|
cpp_quote ("} AM_PROPERTY_TS_RATE_CHANGE_11 ;")
|
|
|
|
// AM_RATE_QueryRate; this is the max full-frame rate; source filter can use
|
|
// up to this; it can use less
|
|
cpp_quote ("typedef struct {")
|
|
cpp_quote (" LONG lMaxForwardFullFrame ; // rate * 10000")
|
|
cpp_quote (" LONG lMaxReverseFullFrame ; // rate * 10000")
|
|
cpp_quote ("} AM_QueryRate ;")
|
|
#endif // USE_AM_PROPERTY_TS_RATE_CHANGE_11
|
|
|
|
/*
|
|
================================================================================
|
|
AM_RATE_UseRateVersion
|
|
--------------------------------------------------------------------------------
|
|
Specifies the rate change version to be used.
|
|
|
|
The default behavior should be per 1.0.
|
|
|
|
Use a WORD value. The high-order byte specifies the minor version (revision)
|
|
number; the low-order byte specifies the major version number. On a
|
|
little-endian system (e.g. x86), the WORD value version for the contents of
|
|
this specification is 0x0101.
|
|
|
|
If the specified rate version is not supported, the call should fail with
|
|
an E_NOINTERFACE error code.
|
|
|
|
================================================================================
|
|
AM_RATE_QueryFullFrameRate
|
|
--------------------------------------------------------------------------------
|
|
Allows a source filter to query for maximum full-frame rates the timestamp
|
|
scaling filter is capable of. Maximum full-frame forward and reverse rates
|
|
are queried for.
|
|
|
|
Use AM_QueryRate structure. Timestamp scaling filter must set
|
|
lMaxReverseFullFrame struct member to negative rate.
|
|
|
|
The sourcing filter can still choose to set the full-frame rate to a value
|
|
smaller than the value returned by the timestamp scaling filter. For example,
|
|
there may be IO issues that prevent a full-frame playback, even if the timestamp
|
|
scaling filter is capable.
|
|
|
|
Non-full frame playback will consist of groups of continuous samples sent to
|
|
the timestamp scaling filter, separated by discontinuities. The timestamps for
|
|
each group of samples will jump across the discontinuities, but still increase
|
|
per the RunTimePlus timeline, when compared to RenderTime, once a steady state
|
|
runstate has been achieved.
|
|
|
|
Note that Rate is used this call, vs. speed.
|
|
|
|
================================================================================
|
|
AM_RATE_QueryLastRateSegPTS
|
|
--------------------------------------------------------------------------------
|
|
Allows a source filter to query the timestamp scaling filter for the last-set
|
|
rate-segment's effective PTS, regardless of rate-segment position.
|
|
|
|
Note that Rate is used this call, vs. speed.
|
|
|
|
================================================================================
|
|
AM_RATE_SimpleRateChange (with 1.1 semantics)
|
|
--------------------------------------------------------------------------------
|
|
If the rate is to be set to the most forward sample, the
|
|
AM_SimpleRateChange.StartTime member is set to value -1 by the sourcing filter.
|
|
This has meaning to the timestamp scaling filter to set the rate to the most
|
|
forward sample, and return that sample's presentation time via the method call's
|
|
[out] parameter.
|
|
|
|
If the specified rate segment is incompatible, all queued samples with PTS in
|
|
rate-incompatible segment can be discarded.
|
|
|
|
If the current rate is incompatible i.e. samples are being dropped by the
|
|
timestamp scaling filter and it is not keeping an internal queued, it should
|
|
fail the querying call (AM_SimpleRateChagne.StartTime = -1) with return error
|
|
VFW_E_DVD_WRONG_SPEED. The sourcing filter will then set a rate with an
|
|
effective PTS.
|
|
|
|
*/
|
|
|