다음을 통해 공유


오디오를 S/PDIF로 디코딩하려면

[이 페이지와 연결된 기능인 Windows Media Format 11 SDK는 레거시 기능입니다. 원본 판독기 및 싱크 작성기에 의해 대체되었습니다. 원본 판독기 및 싱크 작성기는 Windows 10 및 Windows 11 최적화되었습니다. 가능한 경우 새 코드에서 Windows Media Format 11 SDK 대신 소스 판독기 및 싱크 작성기를 사용하는 것이 좋습니다. 가능한 경우 레거시 API를 사용하는 기존 코드를 다시 작성하여 새 API를 사용하도록 제안합니다.]

Windows Media Audio 9 Professional 코덱으로 인코딩된 오디오는 소니/필립스 디지털 상호 연결 형식(S/PDIF)으로 디코딩할 수 있습니다. S/PDIF 출력을 생성하려면 다음 단계를 수행합니다.

  1. IWMReader::Open 메서드를 호출하여 Windows Media Audio 9 Professional 스트림이 포함된 파일을 엽니다.
  2. 원하는 스트림의 출력 번호를 식별합니다. 자세한 내용은 출력 번호 식별을 참조하세요.
  3. IWMReaderAdvanced2::SetOutputSetting 메서드를 호출하여 S/PDIF 출력을 구성합니다. 설정 이름에 g_wszEnableWMAProSPDIFOutput 사용합니다. 데이터 형식은 WMT_TYPE_BOOL. 값을 TRUE 로 설정하여 S/PDIF 출력을 사용하도록 설정합니다.
  4. IWMReader::GetOutputFormat 메서드를 호출하여 원하는 출력 형식의 출력 속성 인터페이스(IWMOutputMediaProps)를 가져옵니다. 출력 형식을 열거하는 방법에 대한 자세한 내용은 출력 형식 할당을 참조하세요.
  5. IWMReader::SetOutputProps 메서드를 호출하여 출력 형식을 설정합니다. 4단계에서 가져온 IWMOutputMediaProps 인터페이스에 대한 포인터를 전달합니다.
  6. 다른 구성을 변경하고 재생을 시작합니다.

참고

IWMSyncReader 인터페이스의 해당 메서드를 사용하여 동기 판독기에서 이전 단계를 수행할 수 있습니다.

 

다음 예제 코드에서는 오디오 스트림을 설정하여 오디오를 S/PDIF 데이터로 출력하는 방법을 보여 줍니다. 이 함수는 파일이 판독기에서 이미 로드되었으며 출력 번호가 식별되었다고 가정합니다. 이 코드를 사용하는 방법에 대한 자세한 내용은 코드 예제 사용을 참조하세요.

HRESULT SetSPDIF(DWORD dwOutputNum, IWMReader* pReader)
{
    HRESULT hr = S_OK;

    IWMReaderAdvanced2*  pReaderAdv   = NULL;
    IWMOutputMediaProps* pOutputProps = NULL; 

    BOOL fValue = TRUE;

    // Get the advanced reader interface.
    hr = pReader->QueryInterface(IID_IWMReaderAdvanced2,
                                 (void**)&pReaderAdv);
    GOTO_EXIT_IF_FAILED(hr);

    // Set S/PDIF output.
    hr = pReaderAdv->SetOutputSetting(dwOutputNum, 
                                      g_wszEnableWMAProSPDIFOutput, 
                                      WMT_TYPE_BOOL, 
                                      (BYTE*)&fValue, 
                                      sizeof(BOOL));
    GOTO_EXIT_IF_FAILED(hr);

    // Get the first output format for the stream.
    // NOTE: You could also enumerate the available output formats
    // and pick one to use.

    hr = pReader->GetOutputFormat(dwOutputNum, 0, &pOutputProps);
    GOTO_EXIT_IF_FAILED(hr);

    // Set the output properties back on the reader.
    hr = pReader->SetOutputProps(dwOutputNum, pOutputProps);

Exit:
    SAFE_RELEASE(pReaderAdv);
    SAFE_RELEASE(pOutputProps);

    return hr;
}

고급 항목

ASF 파일 읽기

IWMReader 인터페이스

IWMReaderAdvanced2 인터페이스

IWMSyncReader 인터페이스