亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? graph.cpp

?? < VC++視頻音頻開發(fā)>> 這本書的源碼
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
//------------------------------------------------------------------------------
// File: Graph.cpp
//
// Desc: Sample code for BDA graph building.
//
// Copyright (c) 2000-2002, Microsoft Corporation. All rights reserved.
//------------------------------------------------------------------------------

#include "graph.h"


// 
// NOTE: In this sample, text strings are hard-coded for 
// simplicity and for readability.  For product code, you should
// use string tables and LoadString().
//

//
// An application can advertise the existence of its filter graph
// by registering the graph with a global Running Object Table (ROT).
// The GraphEdit application can detect and remotely view the running
// filter graph, allowing you to 'spy' on the graph with GraphEdit.
//
// To enable registration in this sample, define REGISTER_FILTERGRAPH.
//
#define REGISTER_FILTERGRAPH

// We use channel 46 internally for testing.  Change this constant to any value.
#define DEFAULT_PHYSICAL_CHANNEL    46L


// Constructor, initializes member variables
// and calls InitializeGraphBuilder
CBDAFilterGraph::CBDAFilterGraph() :
    m_fGraphBuilt(FALSE),
    m_fGraphRunning(FALSE),
    m_NetworkType(ATSC),
    m_lMajorChannel(-1), 
    m_lMinorChannel(-1),
    m_lPhysicalChannel(DEFAULT_PHYSICAL_CHANNEL),
    m_dwGraphRegister (0)
{
    if(FAILED(InitializeGraphBuilder()))
        m_fGraphFailure = TRUE;
    else
        m_fGraphFailure = FALSE;
}


// Destructor
CBDAFilterGraph::~CBDAFilterGraph()
{
    if(m_fGraphRunning)
    {
        StopGraph();
    }

    if(m_fGraphBuilt || m_fGraphFailure)
    {
        TearDownGraph();
    }
}


// Instantiate graph object for filter graph building
HRESULT
CBDAFilterGraph::InitializeGraphBuilder()
{
    HRESULT hr = S_OK;
    
    // we have a graph already
    if (m_pFilterGraph)
        return S_OK;

    // create the filter graph
    if (FAILED (hr = m_pFilterGraph.CoCreateInstance (CLSID_FilterGraph)))
    {
        ErrorMessageBox(TEXT("Couldn't CoCreate IGraphBuilder\n"));
        m_fGraphFailure = true;
        return hr;
    }
    
    return hr;
}


// BuildGraph sets up devices, adds and connects filters
HRESULT
CBDAFilterGraph::BuildGraph(NETWORK_TYPE NetType)
{
    HRESULT hr = S_OK;
    m_NetworkType = NetType;

    // if we have already have a filter graph, tear it down
    if(m_fGraphBuilt)
    {
        if(m_fGraphRunning)
        {
            hr = StopGraph ();
        }

        hr = TearDownGraph ();
    }

    // STEP 1: load network provider first so that it can configure other
    // filters, such as configuring the demux to sprout output pins.
    // We also need to submit a tune request to the Network Provider so it will
    // tune to a channel
    if(FAILED (hr = LoadNetworkProvider()))
    {
        ErrorMessageBox(TEXT("Cannot load network provider\n"));
        TearDownGraph();
        m_fGraphFailure = true;
        return hr;
    }

    hr = m_pNetworkProvider->QueryInterface(__uuidof (ITuner), reinterpret_cast <void**> (&m_pITuner));
    if(FAILED (hr))
    {
        ErrorMessageBox(TEXT("pNetworkProvider->QI: Can't QI for ITuner.\n"));
        TearDownGraph();
        m_fGraphFailure = true;
        return hr;
    }

    // create a tune request to initialize the network provider
    // before connecting other filters
    CComPtr <IATSCChannelTuneRequest>  pATSCTuneRequest;
    if(FAILED (hr = CreateATSCTuneRequest(
                                        m_lPhysicalChannel,
                                        m_lMajorChannel, 
                                        m_lMinorChannel,
                                        &pATSCTuneRequest
                                        )))
    {
        ErrorMessageBox(TEXT("Cannot create tune request\n"));
        TearDownGraph();
        m_fGraphFailure = true;
        return hr;
    }

    //submit the tune request to the network provider
    hr = m_pITuner->put_TuneRequest(pATSCTuneRequest);
    if(FAILED(hr))
    {
        ErrorMessageBox(TEXT("Cannot submit the tune request\n"));
        TearDownGraph();
        m_fGraphFailure = true;
        return hr;
    }


    // STEP2: Load tuner device and connect to network provider
    if(FAILED (hr = LoadFilter (
                                KSCATEGORY_BDA_NETWORK_TUNER, 
                                &m_pTunerDevice,
                                m_pNetworkProvider, 
                                TRUE
                                )))
    {
        ErrorMessageBox(TEXT("Cannot load tuner device and connect network provider\n"));
        TearDownGraph();
        m_fGraphFailure = true;
        return hr;
    }

    // STEP3: Load tuner device and connect to demodulator device
    if(FAILED (hr = LoadFilter (
                                KSCATEGORY_BDA_RECEIVER_COMPONENT, 
                                &m_pDemodulatorDevice,
                                m_pTunerDevice, 
                                TRUE
                                )))
    {
        ErrorMessageBox(TEXT("Cannot load capture device and connect tuner\n"));
        TearDownGraph();
        m_fGraphFailure = true;
        return hr;
    }

    // Step4: Load capture device and connect to tuner device
    if(FAILED (hr = LoadFilter (
                                KSCATEGORY_BDA_RECEIVER_COMPONENT, 
                                &m_pCaptureDevice,
                                m_pDemodulatorDevice, 
                                TRUE
                                )))
    {
        ErrorMessageBox(TEXT("Cannot load capture device and connect tuner\n"));
        TearDownGraph();
        m_fGraphFailure = true;
        return hr;
    }

    // Step5: Load demux
    if(FAILED (hr = LoadDemux()))
    {
        ErrorMessageBox(TEXT("Cannot load demux\n"));
        TearDownGraph();
        m_fGraphFailure = true;
        return hr;
    }

    //
    // this next call loads and connects filters associated with
    // the demultiplexor. if you want to manually load individual
    // filters such as audio and video decoders, use the code at
    // the bottom of this file
    //
#ifdef REGISTER_FILTERGRAPH
    hr = AddGraphToRot (m_pFilterGraph, &m_dwGraphRegister);
    if (FAILED(hr))
    {
        ///ErrorMessageBox(TEXT("Failed to register filter graph with ROT!  hr=0x%x"), hr);
        m_dwGraphRegister = 0;
    }
#endif

    // Step6: Render demux pins
    if(FAILED (hr = RenderDemux()))
    {
        ErrorMessageBox(TEXT("Cannot load demux\n"));
        TearDownGraph();
        m_fGraphFailure = true;
        return hr;
    }

    m_fGraphBuilt = true;
    m_fGraphFailure = false;
    
    return S_OK;
}


// Loads the correct tuning space based on NETWORK_TYPE that got
// passed into BuildGraph()
HRESULT
CBDAFilterGraph::LoadTuningSpace()
{   
    CComPtr <ITuningSpaceContainer>  pITuningSpaceContainer;

    // get the tuningspace container for all the tuning spaces from SYSTEM_TUNING_SPACES
    HRESULT hr = pITuningSpaceContainer.CoCreateInstance(CLSID_SystemTuningSpaces);
    if (FAILED (hr))
    {
        ErrorMessageBox(TEXT("Could not CoCreate SystemTuningSpaces\n"));
        return hr;
    }

    CComVariant var (m_NetworkType);

    hr = pITuningSpaceContainer->get_Item(var, &m_pITuningSpace);

    if(FAILED(hr))
    {
        ErrorMessageBox(TEXT("Unable to retrieve Tuning Space\n"));
    }

    return hr;
}


// Creates an ATSC Tune Request
HRESULT
CBDAFilterGraph::CreateATSCTuneRequest(
        LONG lPhysicalChannel,
        LONG lMajorChannel, 
        LONG lMinorChannel,
        IATSCChannelTuneRequest**   pTuneRequest
    )
{
    HRESULT hr = S_OK;

    if (pTuneRequest == NULL)
    {
        ErrorMessageBox (TEXT("Invalid pointer\n"));
        return E_POINTER;
    }

    // Making sure we have a valid tuning space
    if (m_pITuningSpace == NULL)
    {
        ErrorMessageBox(TEXT("Tuning Space is NULL\n"));
        return E_FAIL;
    }

    //  Create an instance of the ATSC tuning space
    CComQIPtr <IATSCTuningSpace> pATSCTuningSpace (m_pITuningSpace);
    if (!pATSCTuningSpace)
    {
        ErrorMessageBox(TEXT("Cannot QI for an IATSCTuningSpace\n"));
        return E_FAIL;
    }

    //  Create an empty tune request.
    CComPtr <ITuneRequest> pNewTuneRequest;
    hr = pATSCTuningSpace->CreateTuneRequest(&pNewTuneRequest);

    if (FAILED (hr))
    {
        ErrorMessageBox(TEXT("CreateTuneRequest: Can't create tune request.\n"));
        return hr;
    }

    //query for an IATSCChannelTuneRequest interface pointer
    CComQIPtr <IATSCChannelTuneRequest> pATSCTuneRequest (pNewTuneRequest);
    if (!pATSCTuneRequest)
    {
        ErrorMessageBox(TEXT("CreateATSCTuneRequest: Can't QI for IATSCChannelTuneRequest.\n"));
        return E_FAIL;
    }

    //  Set the initial major and minor channels
    hr = pATSCTuneRequest->put_Channel(lMajorChannel);
    if(FAILED(hr))
    {
        ErrorMessageBox(TEXT("put_Channel failed\n"));
        return hr;
    }

    hr = pATSCTuneRequest->put_MinorChannel(lMinorChannel);
    if(FAILED(hr))
    {
        ErrorMessageBox(TEXT("put_MinorChannel failed\n"));
        return hr;
    }

    CComPtr <IATSCLocator> pATSCLocator;
    hr = pATSCLocator.CoCreateInstance (CLSID_ATSCLocator);
    if (FAILED( hr))
    {
        ErrorMessageBox(TEXT("Cannot create the ATSC locator failed\n"));
        return hr;
    }

    //  Set the initial physical channel.
    //
    hr = pATSCLocator->put_PhysicalChannel (lPhysicalChannel);
    if (FAILED( hr))
    {
        ErrorMessageBox(TEXT("Cannot put the physical channel\n"));
        return hr;
    }

    hr = pATSCTuneRequest->put_Locator (pATSCLocator);
    if (FAILED (hr))
    {
        ErrorMessageBox(TEXT("Cannot put the locator\n"));
        return hr;
    }

    hr = pATSCTuneRequest.QueryInterface (pTuneRequest);

    return hr;
}


// LoadNetworkProvider loads network provider
HRESULT
CBDAFilterGraph::LoadNetworkProvider()
{
    HRESULT     hr = S_OK;
    CComBSTR    bstrNetworkType;
    CLSID       CLSIDNetworkType;

    // obtain tuning space then load network provider
    if(m_pITuningSpace == NULL)
    {
        hr = LoadTuningSpace();
        if(FAILED(hr))
        {
            ErrorMessageBox(TEXT("Cannot load TuningSpace\n"));
            return hr;
        }
    }

    // Get the current Network Type clsid
    hr = m_pITuningSpace->get_NetworkType(&bstrNetworkType);
    if (FAILED (hr))
    {
        ErrorMessageBox(TEXT("ITuningSpace::Get Network Type failed\n"));
        return hr;
    }

    hr = CLSIDFromString(bstrNetworkType, &CLSIDNetworkType);
    if (FAILED (hr))
    {
        ErrorMessageBox(TEXT("Couldn't get CLSIDFromString\n"));
        return hr;
    }

    // create the network provider based on the clsid obtained from the tuning space
    hr = CoCreateInstance(CLSIDNetworkType, NULL, CLSCTX_INPROC_SERVER,
                          IID_IBaseFilter, 
                          reinterpret_cast<void**>(&m_pNetworkProvider));
    if (FAILED (hr))
    {
        ErrorMessageBox(TEXT("Couldn't CoCreate Network Provider\n"));
        return hr;
    }

    //add the Network Provider filter to the graph
    hr = m_pFilterGraph->AddFilter(m_pNetworkProvider, L"Network Provider");

    return hr;
}


// enumerates through registered filters
// instantiates the the filter object and adds it to the graph
// it checks to see if it connects to upstream filter
// if not,  on to the next enumerated filter
// used for tuner, capture, MPE Data Filters and decoders that
// could have more than one filter object
// if pUpstreamFilter is NULL don't bother connecting
HRESULT

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产真实乱对白精彩久久| 亚洲国产视频在线| 日韩综合在线视频| 色综合欧美在线| 久久久美女毛片| 婷婷综合在线观看| 色综合一区二区三区| 2023国产精品| 青青国产91久久久久久| 色婷婷香蕉在线一区二区| 天堂一区二区在线| 色综合久久久久网| 国产精品污网站| 狠狠色丁香婷婷综合| 制服.丝袜.亚洲.另类.中文| 亚洲精品大片www| 成人黄色电影在线 | 国产麻豆9l精品三级站| 欧美日韩成人在线| 亚洲综合一区在线| 91片黄在线观看| 国产精品久久夜| 国产一区二区三区av电影| 欧美一区二区精品| 天堂午夜影视日韩欧美一区二区| 色婷婷综合久久久久中文一区二区 | 蜜桃视频免费观看一区| 欧美三级日韩在线| 一区二区三区高清在线| 91亚洲国产成人精品一区二区三| 中文字幕va一区二区三区| 国产一区二区不卡老阿姨| 欧美一级淫片007| 日本一区中文字幕| 欧美日本在线视频| 亚洲成人手机在线| 欧美日韩国产综合草草| 天天影视网天天综合色在线播放| 欧美亚洲另类激情小说| 亚洲自拍偷拍麻豆| 欧美亚洲综合另类| 午夜精品爽啪视频| 91麻豆精品国产91久久久使用方法 | 欧美日韩高清在线| 婷婷久久综合九色综合伊人色| 欧美性大战久久久| 亚洲福利国产精品| 欧美高清视频不卡网| 天堂在线亚洲视频| 欧美一区二区三区在线观看| 奇米影视在线99精品| 日韩免费性生活视频播放| 久久不见久久见免费视频7| 久久色视频免费观看| 国模娜娜一区二区三区| 26uuu欧美| 成人妖精视频yjsp地址| 中文字幕一区二区三区在线播放| 99精品视频在线观看| 一区二区三区精品在线观看| 欧美日韩视频不卡| 蜜臀av一区二区三区| 久久综合国产精品| 成人永久免费视频| 亚洲精品成a人| 欧美精品三级在线观看| 另类成人小视频在线| 欧美激情在线一区二区三区| 91影院在线观看| 午夜视频在线观看一区| 欧美成人精品二区三区99精品| 国产一区在线看| 欧美aaa在线| 国产人伦精品一区二区| 99视频精品在线| 亚洲福利一区二区| 亚洲精品一区二区三区蜜桃下载| 风流少妇一区二区| 亚洲精品欧美在线| 日韩一区二区三| 国产成人精品www牛牛影视| 亚洲欧美在线视频观看| 欧美日韩午夜影院| 国产美女精品一区二区三区| 自拍偷拍亚洲欧美日韩| 欧美日韩一二三区| 国产黄色精品视频| 亚洲一区二区三区在线| 欧美精品一区二区三区视频| 91丝袜美腿高跟国产极品老师 | 久久久99精品免费观看不卡| 99精品1区2区| 蜜桃传媒麻豆第一区在线观看| 国产精品污污网站在线观看| 欧美另类高清zo欧美| 国产酒店精品激情| 亚洲一二三区在线观看| ww久久中文字幕| 日本精品一区二区三区四区的功能| 麻豆视频观看网址久久| 成人欧美一区二区三区| 日韩欧美一级二级三级久久久| 99视频国产精品| 麻豆91免费观看| 亚洲欧美国产77777| 日韩免费视频一区| 欧美主播一区二区三区美女| 国产精品一区二区三区乱码| 亚洲国产精品久久不卡毛片| 久久久久久97三级| 欧美日韩国产欧美日美国产精品| 国产91丝袜在线播放| 三级欧美韩日大片在线看| 国产精品美女一区二区三区| 欧美一区二区三区视频在线观看| 972aa.com艺术欧美| 国产主播一区二区| 无码av中文一区二区三区桃花岛| 国产视频在线观看一区二区三区| 51精品国自产在线| 91美女片黄在线观看| 国产成人综合亚洲网站| 日本一道高清亚洲日美韩| 伊人一区二区三区| 国产欧美日韩视频一区二区| 欧美一激情一区二区三区| 色系网站成人免费| 成人午夜电影久久影院| 久久精品国产**网站演员| 亚洲电影一级片| 国产 日韩 欧美大片| 美女一区二区在线观看| 亚洲国产精品尤物yw在线观看| 中文字幕一区二区视频| 国产视频一区二区在线观看| 日韩精品中文字幕一区| 在线成人免费观看| 欧美色综合影院| 色欧美88888久久久久久影院| 不卡一卡二卡三乱码免费网站| 国产一区二区三区黄视频| 久久91精品国产91久久小草| 免费观看日韩av| 日韩激情中文字幕| 天天av天天翘天天综合网| 亚洲电影第三页| 亚洲大片精品永久免费| 亚洲午夜在线观看视频在线| 一区二区三区欧美| 依依成人综合视频| 亚洲伊人色欲综合网| 一区二区在线观看免费| 一区二区在线观看免费视频播放| 一色屋精品亚洲香蕉网站| 国产精品毛片久久久久久久| 国产人成亚洲第一网站在线播放| 久久久久久电影| 国产欧美一区二区精品秋霞影院| 久久精品视频一区二区三区| 久久久久久久综合狠狠综合| 久久久精品蜜桃| 久久久精品综合| 中文字幕乱码一区二区免费| 国产日韩精品一区| 国产精品欧美综合在线| 国产精品白丝在线| 亚洲色图欧洲色图婷婷| 亚洲精品你懂的| 亚洲狠狠爱一区二区三区| 丝袜诱惑制服诱惑色一区在线观看 | 6080日韩午夜伦伦午夜伦| 在线综合+亚洲+欧美中文字幕| 欧美一区二区日韩一区二区| 精品免费日韩av| 久久久99久久| 中文字幕在线不卡| 曰韩精品一区二区| 五月激情六月综合| 久久99国产精品免费网站| 国产成人精品影视| 91丨porny丨户外露出| 欧美日韩一区小说| 日韩视频一区二区三区| 久久久精品欧美丰满| 中文字幕一区二区三| 亚洲国产日韩a在线播放性色| 蜜桃视频免费观看一区| 国产福利一区在线观看| 91免费版在线看| 欧美精品久久天天躁| 久久先锋影音av| 丁香五精品蜜臀久久久久99网站| 99精品视频在线免费观看| 欧美综合一区二区三区| 日韩欧美国产综合一区| 国产欧美日韩在线观看| 亚洲少妇30p| 美女一区二区久久| www.欧美.com| 91精品蜜臀在线一区尤物|