IInfo2::GetAudioLanguage 方法 (strmif.h)

[與此頁面相關的功能 DirectShow 是舊版功能。 它已被 MediaPlayerIMFMediaEngineMedia Foundation 中的音訊/視訊擷取取代。 這些功能已針對 Windows 10 和 Windows 11 進行優化。 Microsoft 強烈建議新程式代碼盡可能使用 MediaPlayerIMFMediaEngine音訊/視訊擷取 ,而不是 DirectShow。 Microsoft 建議使用舊版 API 的現有程式代碼盡可能重寫為使用新的 API。

方法 GetAudioLanguage 會擷取目前標題內指定音訊數據流的語言。

語法

HRESULT GetAudioLanguage(
  [in]  ULONG ulStream,
  [out] LCID  *pLanguage
);

參數

[in] ulStream

所擷取語言的音訊數據流編號。

[out] pLanguage

接收語言資訊。

傳回值

傳回下列其中一個 HRESULT 值。

傳回碼 描述
S_OK
成功。
E_INVALIDARG
無效引數。
E_POINTER
pLanguage 參數為 NULL
E_UNEXPECTED
DVD 導覽器未初始化。
VFW_E_DVD_INVALIDDOMAIN
DVD 導覽器不在有效的網域中。

備註

這個方法不會傳回功能表的語言。 如果數據流包含未知的語言,它會將 pLanguage 所指向的值設定為零。 呼叫 GetLocaleInfo 函式,從 pLanguage 建立人類可讀取的字串名稱:

C++
LCID Language;
hr = pDvdInfo->GetAudioLanguage(ulStream, &Language);
if (SUCCEEDED(hr))
{
    int cchSize = GetLocaleInfo(Language, LOCALE_SENGLANGUAGE, 0, 0);
    TCHAR *szString = new TCHAR[cchSize];
    if (szString)
    {
        GetLocaleInfo(Language, LOCALE_SENGLANGUAGE, szString, cchSize);
        /* ... */
        delete [] szString;
    }
}

規格需求

需求
最低支援的用戶端 Windows XP [僅限傳統型應用程式]
最低支援的伺服器 Windows Server 2003 [僅限傳統型應用程式]
目標平台 Windows
標頭 strmif.h (包含 Dshow.h)
程式庫 Strmiids.lib

另請參閱

DVD 應用程式

錯誤和成功碼

IInfo2 介面