Compartilhar via


IMediaObject::GetOutputType (Compact 2013)

3/26/2014

This method retrieves a preferred media type for a specified output stream.

Syntax

HRESULT GetOutputType(
  DWORD dwOutputStreamIndex,
  DWORD dwTypeIndex,
  DMO_MEDIA_TYPE* pmt
);

Parameters

  • dwOutputStreamIndex
    Zero-based index of an output stream on the DMO.
  • dwTypeIndex
    Zero-based index on the set of acceptable media types.
  • pmt
    [out] Pointer to a DMO_MEDIA_TYPE structure allocated by the caller. The method fills the structure with the media type. The format block might be NULL, in which case the format type GUID is GUID_NULL.

Return Value

Returns an HRESULT value. Possible values include the following.

Value

Description

S_OK

Success

DMO_E_INVALIDSTREAMINDEX

Invalid stream index

DMO_E_NO_MORE_ITEMS

Type index is out of range

E_OUTOFMEMORY

Insufficient memory

E_POINTER

NULL pointer argument

Remarks

Call this method to enumerate an output stream's preferred media types. The DMO assigns each media type an index value in order of preference. The most preferred type has an index of zero. To enumerate all the types, make successive calls while incrementing the type index until the method returns DMO_E_NO_MORE_ITEMS.

If the method succeeds, call MoFreeMediaType to free the format block.

To set the media type, call the IMediaObject::SetOutputType method.

Setting the media type on one stream can change another stream's preferred types. In fact, a stream might not have a preferred type until the type is set on another stream. For example, a decoder might not have a preferred output type until the input type is set.

The DMO is not required to update its preferred types dynamically in this fashion. Thus, the types returned by this method are not guaranteed to be valid; they might fail when used in the SetOutputType method. Conversely, the DMO is not guaranteed to enumerate every media type that it supports.

To test whether a particular media type is acceptable, call SetOutputType with the DMO_SET_TYPEF_TEST_ONLY flag.

Requirements

Header

dmo.h

Library

Dmoguid.lib

See Also

Reference

IMediaObject
IMediaObject::SetOutputType
MoFreeMediaType
DMO Error Codes
DMO Error Codes
DMO_MEDIA_TYPE