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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? ddgrab.cpp

?? 用matlab進行視頻讀取的程序
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
/***************************************************
This is the main Grabber code.  It builds the Direct Show graphs 
and then inserts SampleGrabbers right before the renderers.  It 
then changes all of the renderers to NullRenderers.  This code 
supports any number of audio or video streams.  Raw midi streams
are not supported -- I didn't think I should bother.

This code was intended to be used inside of a matlab interface,
but can be used as a generic grabber class for anyone who needs 
one.

Written by Micah Richert.
07/14/2005
**************************************************/

#include "DDGrab.h"

GUID NULLGUID = {0};

CSampleGrabberCB::CSampleGrabberCB()
{
	pbFormat = NULL;
	frameNr = 0;
	disabled = FALSE;
}

CSampleGrabberCB::~CSampleGrabberCB()
{
	if (pbFormat) free(pbFormat);
	for (int f=0;f<frames.size();f++) if (frames[f]) free(frames[f]);
}

// Fake out any COM QI'ing
//
STDMETHODIMP CSampleGrabberCB::QueryInterface(REFIID riid, void ** ppv)
{
	if (!ppv) return E_POINTER;
	
	if( riid == IID_ISampleGrabberCB || riid == IID_IUnknown ) 
	{
		*ppv = (void *) static_cast<ISampleGrabberCB*> ( this );
		return NOERROR;
	}	

	return E_NOINTERFACE;
}

// The sample grabber is calling us back on its deliver thread.
// This is NOT the main app thread!
//
STDMETHODIMP CSampleGrabberCB::BufferCB( double dblSampleTime, BYTE * pBuffer, long lBufferSize )
{
	if (disabled) return 0;

	if (!pBuffer) return E_POINTER;

	frameNr++;

	bool foundNr = false;
	for (int i=0;i<frameNrs.size();i++) if (frameNrs[i] == frameNr) foundNr = true;

	if (frameNrs.size() == 0 || foundNr)
	{
		BYTE* tmp = new BYTE[lBufferSize];
		if (!tmp) return E_OUTOFMEMORY;

		memcpy(tmp,pBuffer,lBufferSize);
		frames.push_back(tmp);
		frameBytes.push_back(lBufferSize);
	}

	return 0;
}

void DDGrabber::cleanUp()
{
	IEnumFilters* filterList;
	IBaseFilter* filt;
	ULONG tmp;
	int i;

	for (i=0; i<VideoCBs.size(); i++) delete VideoCBs[i];
	for (i=0; i<AudioCBs.size(); i++) delete AudioCBs[i];

	VideoCBs.clear();
	AudioCBs.clear();

	if (!FAILED(pGraphBuilder->EnumFilters(&filterList)))
	{
		filterList->Reset();
		while (filterList->Next(1, &filt, &tmp) == S_OK)
		{
			filt->Release();
		}	
		filterList->Release();
	}
	pGraphBuilder = NULL;
}

void DDGrabber::MyFreeMediaType(AM_MEDIA_TYPE& mt)
{
	if (mt.cbFormat != 0)
	{
		CoTaskMemFree((PVOID)mt.pbFormat);
		mt.cbFormat = 0;
		mt.pbFormat = NULL;
	}
	if (mt.pUnk != NULL)
	{
		// Unecessary because pUnk should not be used, but safest.
		mt.pUnk->Release();
		mt.pUnk = NULL;
	}
}

PIN_INFO DDGrabber::getPinInfo(IPin* pin)
{
	PIN_INFO	info = {0};

	if (pin)
	{
		if (!FAILED(pin->QueryPinInfo(&info)))
		{
			info.pFilter->Release();
		}
	}

	return info;
}

IPin* DDGrabber::getInputPin(IBaseFilter* filt)
{
	IPin* pin = NULL;
	IEnumPins* pinList;
	ULONG tmp;
	
	if (!filt) return NULL;

	//get the input
	if (!FAILED(filt->EnumPins(&pinList)))
	{
		pinList->Reset();
		while (pinList->Next(1, &pin, &tmp) == S_OK && getPinInfo(pin).dir != PINDIR_INPUT);
		pinList->Release();

		if (getPinInfo(pin).dir != PINDIR_INPUT) return NULL;
	}

	return pin;
}

IPin* DDGrabber::getOutputPin(IBaseFilter* filt)
{
	IPin* pin = NULL;
	IEnumPins* pinList;
	ULONG tmp;

	if (!filt) return NULL;

	//get the output
	if (!FAILED(filt->EnumPins(&pinList)))
	{
		pinList->Reset();
		while (pinList->Next(1, &pin, &tmp) == S_OK && getPinInfo(pin).dir != PINDIR_OUTPUT);
		pinList->Release();
	
		if (getPinInfo(pin).dir != PINDIR_OUTPUT) return NULL;
	}

	return pin;
}

bool DDGrabber::isRenderer(IBaseFilter* filt)
{
	if (!filt) return false;

	IEnumPins*	pinList;
	int nrOutput = 0;
	int nrInput = 0;
	IPin*		pin = NULL;
	ULONG		tmp;

	if (FAILED(filt->EnumPins(&pinList))) return false;
	pinList->Reset();
	while (pinList->Next(1, &pin, &tmp) == S_OK)
	{
		if (getPinInfo(pin).dir == PINDIR_OUTPUT) nrOutput++;
		else nrInput++;
	}
	pinList->Release();

	#ifdef _DEBUG
		FILTER_INFO info;
		filt->QueryFilterInfo(&info);
		char str[100];
		WideCharToMultiByte( CP_ACP, 0, info.achName, -1, str, 100, NULL, NULL );
		_RPT0(_CRT_WARN,str);
		_RPT2(_CRT_WARN," %d %d\n", nrOutput, nrInput);
	#endif

	return nrOutput == 0 && nrInput == 1;  // the only filters that have no outputs are renderers
}

IPin* DDGrabber::connectedToInput(IBaseFilter* filt)
{
	if (!filt) return NULL;

	IPin* inPin;
	IPin* outPin;

	inPin = getInputPin(filt);
	if (!inPin) return NULL;

	if (FAILED(inPin->ConnectedTo(&outPin))) return NULL;
	return outPin;
}

GUID DDGrabber::getMajorType(IBaseFilter* filt)
{
	if (!filt) return NULLGUID;

	IPin* inPin;
	inPin = getInputPin(filt);
	if (!inPin) return NULLGUID;
	
	AM_MEDIA_TYPE mt = {0};
//	ZeroMemory(&MediaType,sizeof(MediaType));
	if (FAILED(inPin->ConnectionMediaType(&mt))) return NULLGUID;
	
	GUID ret = mt.majortype;
	MyFreeMediaType(mt);

	return ret;
}

HRESULT DDGrabber::getVideoInfo(unsigned int id, int* width, int* height, int* nrFramesCaptured, int* nrFramesTotal)
{
	if (!width || !height || !nrFramesCaptured || !nrFramesTotal) return E_POINTER;

	if (id >= VideoCBs.size()) return E_NOINTERFACE;
	CSampleGrabberCB* CB = VideoCBs[id];

	if (!CB) return E_POINTER;

	if (CB->frameNr == 0)
	{
		*width = 0;
		*height = 0;
	} else {
		VIDEOINFOHEADER * h = (VIDEOINFOHEADER*) CB->pbFormat;
		if (!h) return E_POINTER;
		*width  = h->bmiHeader.biWidth;
		*height = h->bmiHeader.biHeight;
	}
	*nrFramesCaptured = CB->frames.size();
	*nrFramesTotal = CB->frameNr;

	return S_OK;
}

HRESULT DDGrabber::getAudioInfo(unsigned int id, int* nrChannels, int* rate, int* bits, int* nrFramesCaptured, int* nrFramesTotal)
{
	if (!nrChannels || !rate || !bits || !nrFramesCaptured || !nrFramesTotal) return E_POINTER;

	if (id >= AudioCBs.size()) return E_NOINTERFACE;
	CSampleGrabberCB* CB = AudioCBs[id];

	if (!CB) return E_POINTER;

	if (CB->frameNr == 0)
	{
		*nrChannels = 0;
		*rate = 0;
		*bits = 0;
	} else {
		WAVEFORMATEX * h = (WAVEFORMATEX*) CB->pbFormat;
		if (!h) return E_POINTER;
		*nrChannels = h->nChannels;
		*rate = h->nSamplesPerSec;
		*bits = h->wBitsPerSample;
	}
	*nrFramesCaptured = CB->frames.size();
	*nrFramesTotal = CB->frameNr;

	return S_OK;
}

void DDGrabber::getCaptureInfo(int* nrVideo, int* nrAudio)
{
	if (!nrVideo || !nrAudio) return;

	*nrVideo = (VideoCBs.size()>0&&VideoCBs[0]&&VideoCBs[0]->disabled)?0:VideoCBs.size();

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲激情综合网| 国产欧美一区二区精品婷婷 | 97久久人人超碰| 粉嫩av亚洲一区二区图片| 韩国在线一区二区| 国产黄人亚洲片| 成人app网站| 色综合一个色综合亚洲| 欧美中文一区二区三区| 欧美日韩精品电影| 日韩视频中午一区| 欧美大胆一级视频| 精品成人一区二区三区四区| 精品成人一区二区三区四区| 国产精品视频线看| 亚洲一区二区三区四区五区黄 | 精品免费国产二区三区| 久久久久久夜精品精品免费| 图片区小说区区亚洲影院| 亚洲免费看黄网站| 天天爽夜夜爽夜夜爽精品视频| 香蕉久久一区二区不卡无毒影院| 午夜精品免费在线观看| 久久激五月天综合精品| 成人v精品蜜桃久久一区| 色综合久久88色综合天天6| 欧美日韩国产乱码电影| www精品美女久久久tv| 亚洲综合免费观看高清完整版在线| 一区二区三区精品| 久久精品二区亚洲w码| 国产99精品国产| 欧美日韩高清在线| 欧美国产精品久久| 午夜精品爽啪视频| 99久久精品情趣| 日韩色视频在线观看| 一区二区中文字幕在线| 欧美aⅴ一区二区三区视频| 懂色av中文字幕一区二区三区| 欧美日韩精品一区二区三区四区| 久久久久久久电影| 日韩精彩视频在线观看| av资源网一区| www国产亚洲精品久久麻豆| 亚洲愉拍自拍另类高清精品| 国产精品影音先锋| 欧美一级免费观看| 夜夜操天天操亚洲| 91在线精品一区二区三区| 日韩免费性生活视频播放| 亚洲视频免费看| 粉嫩蜜臀av国产精品网站| 91精品国产91久久综合桃花 | 欧美亚洲一区三区| 国产精品人人做人人爽人人添| 日本中文一区二区三区| 91久久精品一区二区三| 中文字幕国产一区| 国产精品一区二区不卡| 精品美女被调教视频大全网站| 亚洲国产精品久久久久秋霞影院 | 欧美大尺度电影在线| 午夜精品视频在线观看| 在线观看亚洲一区| 一区二区三区国产豹纹内裤在线| 成人av网站在线| 国产日韩三级在线| 国产99久久久国产精品潘金| 久久久久久久国产精品影院| 激情五月婷婷综合网| 精品国产髙清在线看国产毛片| 日本aⅴ亚洲精品中文乱码| 在线播放中文一区| 日韩av中文字幕一区二区三区 | 国产成人免费视频一区| 国产亚洲综合在线| 国产精品18久久久久久久久 | 麻豆91精品91久久久的内涵| 欧美三级在线播放| 免费高清在线一区| 日韩一级免费观看| 欧美三级视频在线观看| 亚洲图片欧美视频| 制服丝袜国产精品| 精品在线观看视频| 欧美国产视频在线| 91免费国产在线| 亚洲第四色夜色| 日韩欧美另类在线| 国产成人精品亚洲777人妖 | 亚洲电影在线免费观看| 欧美精品免费视频| 国产精品资源网| 亚洲精品国产精华液| 欧美疯狂性受xxxxx喷水图片| 久久精品噜噜噜成人av农村| 久久久久久**毛片大全| 成人免费视频网站在线观看| 一区二区国产视频| 欧美成人一区二区三区片免费| 国产精品自拍三区| 一区二区三区高清在线| 日韩欧美中文一区二区| 成人一区二区在线观看| 亚洲一二三四久久| 久久久99免费| 在线亚洲免费视频| 精品一区中文字幕| 亚洲精品成人在线| 精品国产一区二区亚洲人成毛片| 波多野洁衣一区| 久久激情综合网| 亚洲专区一二三| 久久嫩草精品久久久久| 欧美亚洲综合网| 国产91丝袜在线播放| 天堂久久一区二区三区| 国产精品网站一区| 日韩美女视频一区二区在线观看| av色综合久久天堂av综合| 久久成人综合网| 亚洲二区在线视频| 中文字幕亚洲成人| 久久久不卡影院| 欧美一区二区三区成人| 欧美亚洲一区二区三区四区| 成人免费视频免费观看| 久久狠狠亚洲综合| 日本欧美加勒比视频| 亚洲午夜久久久久久久久电影院| 国产欧美日韩在线看| 欧美成人伊人久久综合网| 欧美男女性生活在线直播观看| 色一情一伦一子一伦一区| 国产成人免费视频网站| 狠狠狠色丁香婷婷综合激情| 欧美aaaaaa午夜精品| 亚洲成av人片一区二区三区| 亚洲欧美电影一区二区| 国产精品免费久久久久| 久久精品欧美日韩精品| 精品国产123| 久久久久99精品国产片| 精品国免费一区二区三区| 欧美一区二区观看视频| 欧美日韩在线播放一区| 色乱码一区二区三区88| 91麻豆福利精品推荐| 99视频超级精品| 91无套直看片红桃| 色中色一区二区| 欧美性色aⅴ视频一区日韩精品| 色综合久久中文字幕综合网| 波多野结衣精品在线| 91在线国产福利| 色乱码一区二区三区88| 欧美日韩极品在线观看一区| 在线观看91精品国产麻豆| 日韩欧美一区二区三区在线| 久久综合色一综合色88| 国产精品萝li| 一区二区激情小说| 日韩1区2区日韩1区2区| 久久99精品久久只有精品| 国产在线国偷精品免费看| 国产成人av影院| 色综合久久天天综合网| 欧美三级韩国三级日本三斤 | 国产一区 二区| 高清国产一区二区| 色婷婷综合中文久久一本| 欧美视频一区二区三区| 欧美xfplay| 中文字幕一区不卡| 日本在线不卡一区| 成人午夜免费视频| 91传媒视频在线播放| 91精品国产91久久久久久最新毛片| 久久久美女毛片| 亚洲午夜久久久久| 国产999精品久久| 精品视频一区三区九区| 久久先锋影音av鲁色资源| 亚洲另类在线视频| 国内精品自线一区二区三区视频| 97久久久精品综合88久久| 欧美日韩夫妻久久| 日本一区二区三级电影在线观看 | 精品少妇一区二区三区日产乱码| 久久精品一二三| 日韩精品亚洲专区| 懂色av一区二区三区蜜臀| 91精品国产综合久久久久久久久久| 久久精品视频一区二区| 丝袜诱惑亚洲看片| 色综合视频一区二区三区高清| 精品国产一区二区三区久久影院| 亚洲国产日韩综合久久精品| 国产精品系列在线播放|