【熱聞】AMCAP程序詳解:AMCeGraphBuilder
AMCAP程序詳解
DirectShow提供了用應用程序從適當的硬件中捕捉和預覽音/視頻的能力。數據源包括:VCR,Camera,TVTuner,Microphone,或其他的數據源。一個應用程序可以立刻顯示捕捉的數據(預覽),或是保存到一個文件中。
(資料圖)
在這個例子中,ICaptureGraphBuilder接口是處理捕捉工作的主要接口。你可以在你自己的捕捉程序中使用同樣的方法和接口。在這里主要討論ICaptureGraphBuilder如何執行音/視頻的捕捉。我們假設你已經熟悉了DirectShow的filtergraph的體系和一般的capturefiltergraph的結構(可以參考DirectShow基礎指南)。
ICaptureGraphBuilder接口提供了一個filtergraph builder對象,讓你的應用程序在建立capture filtergraph時,省去處理很多單調乏味的工作,集中精力于捕捉中。它提供的方法滿足了基本的捕捉和預覽功能的要求。
FindInterface方法,在filtergraph中查找一個與捕捉有關的詳細的接口。使得你可以訪問一個詳細接口的功能,而不需要你去列舉filtergraph中的pins和filters。 RenderStream方法,連接源過濾器和渲染過濾器,選擇添加一些中間的過濾器。ControlStream方法,獨立地精確地控制graph的開始和結束幀。
既然是硬件捕捉,當然要和硬件打交道,接著介紹設備列舉和捕捉接口。
通過ICreateDevEnum::CreateClassEnumerator方法列舉捕捉系統中的設備。之后,實例化一個DirectShow的filter去使用這個設備。用ICaptureGraphBuilder::FindInterface去獲得與捕捉相關的接口指針IAMDroppedFrames,IAMVideoCompression, IAMStreamConfig,以及 IAMVfwCaptureDialogs。因為設備列舉和捕捉接口比較長,放在這會打亂結構,所有專門寫了一篇(參考設備列舉和捕捉接口)。
NOTE: 這個示例是DirectShow自帶的例子。你可以在DirectShowSDK的目錄Sample\DS\Caputre看這個例子代碼(AMCap.cpp)。這里只是他的一些片斷代碼。可以說是他的中文模塊的說明。AMCap例子中,把所有的接口指針和一些成員變量保存在一個全局結構gcap中了。
當不在需要保存在gcap中的接口指針是,一定要釋放這些接口指針,一般是在程序的析構函數中,或是在別的同等功能函數中。如下:
if (gcap.pBuilder) gcap.pBuilder->Release(); gcap.pBuilder = NULL; if (gcap.pSink) gcap.pSink->Release(); gcap.pSink = NULL; if (gcap.pConfigAviMux) gcap.pConfigAviMux->Release(); gcap.pConfigAviMux = NULL; if (gcap.pRender) gcap.pRender->Release(); gcap.pRender = NULL; if (gcap.pVW) gcap.pVW->Release(); gcap.pVW = NULL; if (gcap.pME) gcap.pME->Release(); gcap.pME = NULL; if (gcap.pFg) gcap.pFg->Release(); gcap.pFg = NULL;
設置文件名
使用普通的OpenFileDialog獲得捕捉文件的信息。通過調用AllocCaptureFile函數為捕捉文件分配空間。這一點是重要的,因為這是個巨大的空間。這樣可以提高捕捉操作的速度。ICaptureGraphBuilder::AllocCapFile執行實際的文件分配,IFileSinkFilter::SetFileName指示file writerfilter使用用戶選擇的文件名保存數據。ICaptureGraphBuilder::SetOutputFileName把filewriter filter加入filter graph(后面會介紹,它是ICaptureGraphBuilderd自代的)。
SetCaptureFile 和 AllocCaptureFile 函數如下:
BOOL SetCaptureFile(HWND hWnd) {if(OpenFileDialog(hWnd, gcap.szCaptureFile, _MAX_PATH)) {OFSTRUCTos;//We have a capture file nameif(OpenFile(gcap.szCaptureFile, &os, OF_EXIST) ==HFILE_ERROR) {//Bring up dialog, and set new file size BOOLf = AllocCaptureFile(hWnd); if(!f) returnFALSE; } } else{returnFALSE; }SetAppCaption();// need a new app caption//Tell the file writer to use the new file name if(gcap.pSink) {WCHARwach[_MAX_PATH]; MultiByteToWideChar(CP_ACP,MB_PRECOMPOSED, gcap.szCaptureFile, -1, wach, _MAX_PATH); gcap.pSink->SetFileName(wach,NULL); } return TRUE; }// Preallocate the capturefile // BOOL AllocCaptureFile(HWND hWnd) {// We"ll get into an infinite loop in the dlgproc setting a value if (gcap.szCaptureFile[0] == 0) returnFALSE;if (DoDialog(hWnd, IDD_AllocCapFileSpace, AllocCapFileProc, 0)){//Ensure repaint after dismissing dialog before //possibly lengthy operation UpdateWindow(ghwndApp);//User has hit OK. Alloc requested capture file space BOOLf = MakeBuilder(); if(!f) returnFALSE; WCHARwach[_MAX_PATH]; MultiByteToWideChar(CP_ACP,MB_PRECOMPOSED, gcap.szCaptureFile, -1, wach, _MAX_PATH); if(gcap.pBuilder->AllocCapFile(wach,gcap.wCapFileSize* 1024L * 1024L) != NOERROR) {MessageBoxA(ghwndApp, "Error","Failed to pre-allocate capture filespace",MB_OK | MB_ICONEXCLAMATION); return FALSE; } returnTRUE; } else {returnFALSE; } }
建立GraphBuilder對象
AMCap的MakeBuilder函數建立了一個capturegraph builer對象,通過調用 CoCreateInstance獲得了ICaptureGraphBuilder接口指針。AMCap把他存儲到gcap結構的pBuilder中。
// Make a graph builderobject we can use for capture graph building // BOOL MakeBuilder() {//We have one already if(gcap.pBuilder) returnTRUE;HRESULThr = CoCreateInstance((REFCLSID)CLSID_CaptureGraphBuilder, NULL,CLSCTX_INPROC, (REFIID)IID_ICaptureGraphBuilder,(void**)&gcap.pBuilder); return(hr == NOERROR) ? TRUE : FALSE; }
建立Graph的渲染部分,并告訴它寫文件(用先前決定的文件)
這包括一個multiplexerfilter 和 file writer。DirectShow 提供了一個AVIMUX(multiplexer)filter。在這里ICaptureGraphBuilder::SetOutputFileName是一個關鍵的方法。它把multiplexer 和 file writer添加到filtergraph中,連接他們,并設置文件的名字。第一個參數MEDIASUBTYPE_Avi,指出capture graph builder對象將插入一個AVI multiplexer filter,因此,filewriter將以AVI文件格式記錄捕捉的數據。第二個參數(wach)是文件名。最后的兩個參數指出multiplexer filter(gcap.pRender) 和file writer filter(gcap.pSink),這兩個是通過SetOutputFileName函數初始化的。AMCap存儲這些指針到全局結構gcap中。capture graph builder 對象建立了一個filtergraph對象(IGraphBuilder),把這兩個filter加入到filter graph中去。他告訴filewriter使用指定的文件保存數據。下面的例子演示了如何調用SetOutputFileName。
// // We need a rendering section that will write the capture file outin AVI // file format //WCHAR wach[_MAX_PATH]; MultiByteToWideChar(CP_ACP, MB_PRECOMPOSED, gcap.szCaptureFile, -1,wach, _MAX_PATH); GUID guid = MEDIASUBTYPE_Avi; hr =gcap.pBuilder->SetOutputFileName(&guid,wach, &gcap.pRender,&gcap.pSink); if (hr != NOERROR) {ErrMsg("Error%x: Cannot set output file", hr); gotoSetupCaptureFail; }
獲得當前的FilterGraph
因為在調用SetOutputFileName中,capturegraph builder 對象建立了一個filter graph,所以你必須把需要的filter加入同一個filter graph中。通過ICaptureGraphBuilder::GetFiltergraph獲得新建立的filtergraph。返回的指針是參數gcap.pFg。
// // The graph builder created a filter graph to do that. Find outwhat it is, // and put the video capture filter in the graph too. //hr =gcap.pBuilder->GetFiltergraph(&gcap.pFg); if (hr != NOERROR) {ErrMsg("Error%x: Cannot get filtergraph", hr); gotoSetupCaptureFail; }
添加音/視頻過濾器到當前的Filter Graph
hr =gcap.pFg->AddFilter(gcap.pVCap, NULL); if (hr != NOERROR) {ErrMsg("Error%x: Cannot add vidcap to filtergraph", hr); gotoSetupPreviewFail; }hr =gcap.pFg->AddFilter(gcap.pACap, NULL); if (hr != NOERROR) {ErrMsg("Error%x: Cannot add audcap to filtergraph", hr); gotoSetupCaptureFail; }
渲染視頻捕捉過濾器的CapturePin和音頻捕捉的Capture Pin
ICaptureGraphBuilder::RenderStream連接源過濾器的pin到渲染過濾器。pin的類別是可選的,capture pin (PIN_CATEGORY_CAPTURE) 或preview pin (PIN_CATEGORY_PREVIEW)。下面的例子演示了連接video capture filter(gcap.pVCap) 的capture pin到渲染gcap.pRender中。
// // Render the video capture and preview pins - we may not havepreview, so // don"t worry if it doesn"t work //hr =gcap.pBuilder->RenderStream(&PIN_CATEGORY_CAPTURE,NULL, gcap.pVCap, NULL, gcap.pRender); // Error checking// // Render the audio capture pin? //if (gcap.fCapAudio) {hr =gcap.pBuilder->RenderStream(&PIN_CATEGORY_CAPTURE,NULL, gcap.pACap, NULL, gcap.pRender); // Error checking
渲染Video CaptureFilter的 Preview Pin
再次調用ICaptureGraphBuilder::RenderStream,從capture filter的previewpin到video renderer。代碼如下:
hr =gcap.pBuilder->RenderStream(&PIN_CATEGORY_PREVIEW,NULL, gcap.pVCap, NULL, NULL);
獲得訪問Video PreviewWindow的接口指針
缺省的,videopreview window是一個獨立的窗口。如果你想改變默認的行為,先調用ICaptureGraphBuilder::FindInterface獲得IVideoWindow接口。第二個參數通過gcap.pVCap指定,描述video capturefilter,第三個參數是想得到的接口(IVideoWindow),最后的是返回的接口。當你得到IVideoWindow接口后,你可以調用IVideoWindow的方法象put_Owner,put_WindowStyle, or SetWindowPosition 去獲得video previewwindow的handle,設置窗口屬性,或把他放到想要的位置。
// This will go through apossible decoder, find the video renderer it"s // connected to, and get the IVideoWindow interface onit hr =gcap.pBuilder->FindInterface(&PIN_CATEGORY_PREVIEW,gcap.pVCap, IID_IVideoWindow, (void**)&gcap.pVW); if (hr != NOERROR) {ErrMsg("Thisgraph cannot preview"); } else {RECTrc; gcap.pVW->put_Owner((long)ghwndApp);// We own the window now gcap.pVW->put_WindowStyle(WS_CHILD);// you are now a child //give the preview window all our space but where the status baris GetClientRect(ghwndApp,&rc); cyBorder= GetSystemMetrics(SM_CYBORDER); cy= statusGetHeight() + cyBorder; rc.bottom-= cy; gcap.pVW->SetWindowPosition(0,0, rc.right, rc.bottom); // be thisbig gcap.pVW->put_Visible(OATRUE); }
現在你已經建立完整的capture filtergraph了,你可以預覽音頻,視頻,或捕捉數據。
控制 Capture FilterGraph
因為通過ICaptureGraphBuilder接口構造的capturefilter graph 只是一個簡單的專門用途的filter graph,所以,控制它就象控制其他類型的filtergraph一樣。你可以使用IMediaControl interface的 Run, Pause,和Stop方法,你也可以使用CBaseFilter::Pause的方法。另外ICaptureGraphBuilder 提供了ControlStream 方法去來控制 capture filter graph的流媒體的開始和結束時間。ControlStream調用IAMStreamControl::StartAt 和IAMStreamControl::StopAt控制filter graph的捕捉和預覽的開始和結束的位置。
注意:不是所有的capture filter都可以,因為不是每一個capturefilter都支持IAMStreamControl。
ICaptureGraphBuilder::ControlStream方法的第一個參數(pCategory)是一個輸出pin類的GUID。這個變量通常是PIN_CATEGORY_CAPTURE或 PIN_CATEGORY_PREVIEW。指定為NULL則控制所有的capture filter。第二個參數在(pFilter)指出那個filter控制。NULL說明為控制所有的filtergraph。如果只是預覽(防止捕捉)的話,可以調用ICaptureGraphBuilder::ControlStream,參數用capturepin類型,MAX_TIME作為開始時間(第三個參數,pstart)。再次調用該方法,參數用previewpin類型,NULL作為開始時間則立即開始預覽。第四參數指出結束的時間(pstop),含義和第三個參數一樣(NULL意味著立刻)。MAX_TIME在DirectShow中定義為最大的參考時間。在這里意味著忽略或取消指定的操作。最后的參數,wStartCookie和wStopCookie分別是開始和結束的cookies(不知道該怎么翻譯,因為我也不理解這個參數的含義)。下面的代碼設置立刻開始預覽,但是忽略捕捉。
// Let the preview sectionrun, but not the capture section // (There might not be a capture section) REFERENCE_TIME start = MAX_TIME, stop = MAX_TIME; // show us a preview first? but don"t capturequite yet... hr =gcap.pBuilder->ControlStream(&PIN_CATEGORY_PREVIEW,NULL, gcap.fWantPreview ? NULL : &start, gcap.fWantPreview ? &stop : NULL, 0, 0); if (SUCCEEDED(hr)) hr=gcap.pBuilder->ControlStream(&PIN_CATEGORY_CAPTURE,NULL, &start, NULL, 0, 0);
同樣的,如果你只想要捕捉而不要預覽,設置捕捉的開始時間為NULL,設置捕捉的結束時間為MAX_TIME。設置預覽的開始時間為MAX_TIME,NULL為結束時間。下面的例子告訴filtergraph開始預覽(第三個參數:開始時間為NULL)。結束時間指定為MAX_TIME意味著忽視停止時間(永遠放下去)。 gcap.pBuilder->ControlStream(&PIN_CATEGORY_PREVIEW,NULL, NULL, MAX_TIME, 0, 0);
調用IMediaControl::Run 運行 graph
// Run the graph IMediaControl *pMC = NULL; HRESULT hr =gcap.pFg->QueryInterface(IID_IMediaControl, (void**)&pMC); if (SUCCEEDED(hr)) {hr= pMC->Run(); if(FAILED(hr)) {//Stop parts that ran pMC->Stop(); } pMC->Release(); } if (FAILED(hr)) {ErrMsg("Error%x: Cannot run preview graph", hr); returnFALSE;
如果graph已經運行,通過調用ICaptureGraphBuilder::ControlStream立刻開始捕捉。例如下面的代碼,控制整個的filtergraph(第二個參數為NULL),立刻開始(第三個參數是NULL),并且永不停止(第四個參數是MAX_TIME)。
// NOW! gcap.pBuilder->ControlStream(&PIN_CATEGORY_CAPTURE,NULL, MAX_TIME, &stop, 0, 0);
停止預覽或捕捉操作,調用IMediaControl::Stop,就同你調用IMediaControl::Run一樣。
// Stop the graph IMediaControl *pMC = NULL; HRESULT hr =gcap.pFg->QueryInterface(IID_IMediaControl, (void**)&pMC); if (SUCCEEDED(hr)) {hr= pMC->Stop(); pMC->Release(); }
獲得捕捉的信息
通過IAMDroppedFrames接口獲得。測試丟失幀的數量(IAMDroppedFrames::GetNumDropped),捕捉的數量(IAMDroppedFrames::GetNumNotDropped)。IAMDroppedFrames::GetAverageFrameSize方法提供了捕捉幀的平均尺寸(單位:byte)。使用這些信息可以知道總的捕捉字節和每秒的幀數(速率)。
保存文件
最初分配的捕捉文件只是臨時的保存數據,所有你可以盡可能快的捕捉。當你想把捕捉的數據保存到硬盤中時,調用ICaptureGraphBuilder::CopyCaptureFile。這個方法從先前得到的捕捉文件輸出數據到你選擇的另一個文件中。這個新的儲存文件的大小是和實際捕捉的數據匹配的,而不是和先前的文件大小匹配。ICaptureGraphBuilder::CopyCaptureFile方法的第一個參數是復制源,第二個是目標文件。第三個參數設為TRUE指出用戶允許用ESC鍵中斷復制操作。最后參數是可選的。允許你提供一個進程指示器。如果想要的化,通過執行IAMCopyCaptureFileProgress 接口。下面示例了如何調用CopyCaptureFile。
hr =pBuilder->CopyCaptureFile(wachSrcFile,wachDstFile,TRUE,NULL);
通過普通的OpenFile Dialog得到新的文件名。用 MultiByteToWideChar函數把文件名轉成寬字符(widestring),使用ICaptureGraphBuilder::CopyCaptureFile把捕捉的數據保存到指定的文件中。
BOOL SaveCaptureFile(HWND hWnd) {HRESULT hr; char achDstFile[_MAX_PATH]; WCHAR wachDstFile[_MAX_PATH]; WCHAR wachSrcFile[_MAX_PATH];if (gcap.pBuilder == NULL) returnFALSE;if (OpenFileDialog(hWnd, achDstFile, _MAX_PATH)){// We have a capture filename MultiByteToWideChar(CP_ACP, MB_PRECOMPOSED, gcap.szCaptureFile, -1,wachSrcFile, _MAX_PATH); MultiByteToWideChar(CP_ACP, MB_PRECOMPOSED, achDstFile, -1,wachDstFile, _MAX_PATH); statusUpdateStatus(ghwndStatus, "Saving capture file - pleasewait...");// We need our own graphbuilder because the main one might not exist ICaptureGraphBuilder *pBuilder; hr = CoCreateInstance((REFCLSID)CLSID_CaptureGraphBuilder, NULL, CLSCTX_INPROC, (REFIID)IID_ICaptureGraphBuilder, (void **)&pBuilder); if (hr == NOERROR) {// Allow the user to press ESC to abort...don"t ask for progress hr = pBuilder->CopyCaptureFile(wachSrcFile,wachDstFile,TRUE,NULL); pBuilder->Release(); } if (hr == S_OK) statusUpdateStatus(ghwndStatus, "Capture file saved"); else if (hr == S_FALSE) statusUpdateStatus(ghwndStatus, "Capture file save aborted"); else statusUpdateStatus(ghwndStatus, "Capture file save ERROR"); return (hr == NOERROR ? TRUE : FALSE);} else {return TRUE; // They canceled orsomething } }
關于捕捉媒體文件和獲得捕捉信息的詳細內容,可以參考AMCap例子的Amcap.cpp 和Status.cpp 。
標簽:
相關推薦:
精彩放送:
- []每日觀察!UCB1策略和公式的理解 解決探索與利用平衡問題
- []天天日報丨組態軟件是什么?組態軟件在工業控制領域的應用
- []每日熱聞!財面兒丨遠洋集團1-2月累計協議銷售額約83.6億元 同比增長1.7%
- []全球最資訊丨消息指Uber正考慮分拆貨運物流部門 或將進行IPO
- []訊息:標普:部分地區投資物業保持彈性 香港置地可平穩度過低迷期
- []德力股份:公司沒有導電玻璃的生產產能
- []世界速看:上海寶山顧村華發四季河濱開啟首次認購 總可售住宅9.8萬平米
- []今日觀點!萬泰生物:公司自2019年起將戊肝疫苗的投標價格統一調整為裸價770元/支
- []全球動態:股民無眠!炒股群炸鍋了:連夜學習“室溫超導”!基礎物理學新突破?
- []世界要聞:2022端午節股市休市幾天,休市三天
- []每日熱聞!中央銀行三大法寶
- []焦點快報!威海到青島自駕車多長時間_威海到青島
- []環球熱點評!余額寶風險是什么,有以下兩點
- []【環球時快訊】2022年端午節股市放假嗎,當然放
- []異地同行轉賬要不要手續費,不要
- []世界熱文:怎么炒股詳細步驟,有以下五步
- []降準對股市影響,有以下三點
- []當前看點!TD早報 | 國泰航空2022年凈虧損擴大近兩成;日本將放寬民宿業準入條件
- []【當前熱聞】怎么炒港股
- []環球今日訊!金融危機對百姓的影響
- []全球快看:農行利率2020年利率
- []焦點關注:2021個人所得稅起征點
- []焦點要聞:修正藥業股票代碼,還未上市沒有股票代碼
- []興業銀行信用卡進度查詢方法
- []買入價和賣出價怎么判斷
- []焦點日報:鼎湖門票_肇慶鼎湖山門票多少錢
- []【獨家】達美樂中國重啟上市?此前已通過港交所聆訊
- []當前信息:平板電腦像素排行榜_7寸平板電腦排行榜情況
- []中國1元等于多少日元 人民幣的意義
- []5g的龍頭股有哪些
- []今日熱訊:大家千萬不要領失業金,主要以下4個原因
- []天天亮點!工商銀行抵押貸款條件及流程
- []環球通訊!北交所打新規則,有以下四點
- []每日看點!力高地產1-2月合約銷售約28.39億元 同比下滑37.19%
- []【全球熱聞】“00后”小伙連續盜竊五起,涉案金額23000元
- []東數西算概念股龍頭一覽表依米康,東數西算概念股一覽
- []【環球報資訊】元旦節股票休市和開市是什么時間,一般休市三天
- []急漲慢跌,意思是迅速上漲緩慢下跌
- []借貸記賬法的理論依據
- []閃酷卡是什么
- []踐行ESG理念,聚焦多元化優勢,華林證券多舉措助力“她力量”綻放
- []大宏立:3月7日公司高管楊中民減持公司股份合計1.99萬股
- []環球快看點丨棲霞物業擬向參股公司提供150萬元借款?期限為24日
- []今日聚焦!中公教育:3月7日公司高管王振東減持公司股份合計1454萬股
- []森麒麟:3月7日公司高管秦龍、林文龍、秦靖博、金勝勇增持公司股份合計129.46萬股
- []視焦點訊!2022年銀行基準利率是多少,各類型基準利率一覽
- []每日消息!未來可能漲100倍的股票是哪個,十大牛股盤點名單
- []余額寶10萬一天收益多少錢,5人民幣左右
- []獲利能力指標
- []建行管理費10元能不能取消,可以取消
- []簡訊:景津裝備:3月7日公司高管楊名杰減持公司股份合計10000股
- []【全球聚看點】新湖中寶注銷此前回購的9040萬股 注冊資本減少至85.09億
- []諾力股份:2月16日至2月27日公司高管張科減持公司股份合計113.99萬股
- []全球關注:遠洋集團前2月協議銷售額約84億元 多個精品項目將全新加推
- []全球快播:十五連板后終被停牌核查 *ST瑞德索賠案訴訟時效僅剩四個月
- []十一高速免費嗎2022年,免費
- []世界新資訊:威海旅游攻略自助游_威海旅游全攻略
- []動態:分期的車可以抵押貸款嗎?
- []全球熱點評!bcx是什么幣
- []證券公司手續費
- []報道:建行轉賬手續費 建行轉賬手續費怎么算
- []全球觀熱點:報告:近半數女性2年內有購房計劃,八成傾向于買新房
- []廈門推出拆遷款房票補償政策
- []北京商務局:鼓勵商業品牌首店首發項目?最高給予500萬元支持
- []天天熱點!萬城控股預計2022年度稅后溢利減少約35%至50%
- []珠海2023年投資項目共198個 年內計劃安排投資202.24億元
- []今日熱文:美格智能:目前6G技術尚處于早期研究階段,距離搭載6G技術的產品落地仍需時日
- []全球熱點評!男女有別嗎?30+有年齡焦慮嗎?她們說……
- []【天天聚看點】什么是折價率
- []天天資訊:注冊制次新股概念股票龍頭一覽表,2023注冊制次新股相關上市公司有哪些
- []今日熱文:貴賓卡是什么卡,代表貴賓身份
- []每日信息:信用卡的好處
- []【全球播資訊】58同城、安居客《2023年女性置業調查報告》:近半數女性2年內有購房計劃
- []財信地產職工代表監事李屹然辭職 殷杰繼任
- []每日簡訊:澳博控股2022年股東應占虧損77.98億港元 同比擴大88.2%
- []軟控股份:涂布機項目主要針對鋰電行業,尚處在研發實驗階段,暫未批量生產
- []【全球熱聞】匯景控股填補公司董事會成員空缺時限申請延長至4月30日
- []天天快消息!芒果超媒2022業績快報:歸母凈利超18億元 期待2023年繼續“破浪”
- []迅捷興:公司產品可廣泛應用于汽車電子、通訊、安防、人工智能等諸多領域
- []全球視訊!自如或在港IPO最早4月遞表 公司方回應“不予置評”
- []世界看熱訊:中百集團:公司中百大廚房現有少量預制菜肴,目前銷售占比較低,不對公司經營業績產生重大影響
- []當前熱文:總投資50億元!億利潔能成功簽約10GW沙戈荒地區高效專用光伏組件項目
- []焦點快看:六折是百分之多少
- []今日熱聞!什么是物理儲能?物理儲能方式包括哪些
- []天天微動態丨期貨交易軟件,有以下十個
- []即時看!余額寶有什么用 余額寶的作用是什么
- []天天快消息!銀行同期貸款利率 銀行的貸款同期利率
- []重磅!全球光伏龍頭A股IPO上市獲受理!
- []小鵬汽車新專利可實現光伏充電
- []天天快資訊丨交易密碼指的是什么密碼 支付密碼
- []焦點日報:越秀服務2022年總收入24.86億元 歸母凈利潤同增15.7%
- []中關村收關注函:要求說明控股股東所持股份凍結對公司控制權影響
- []滾動:長陽科技:公司目前產品尚未涉及固態電池,公司將高度關注相關技術的發展趨勢
- []熱文:上海能源:公司為實現可持續發展,將經營積累主要用于煤炭資源獲取、基本建設投資等
- []【新視野】2023年女性置業調查報告:67.7%女性因職業發展選擇安居城市
- []上海九百:本公司持有的上市公司股份,請詳見公司披露的定期報告及相關公告
- []中國黃金交易時間是幾點
- []產品是企業發展的生命力 波司登創新世界羽絨服市場的發展邏輯
- []【全球報資訊】開板是什么意思股票
- []什么叫劣后資金,指收益不好但風險較大的資金
- B站注冊資本增幅400%至5億 目前由陳睿全資持股
- 光源資本出任獨家財務顧問 沐曦集成電路10億元A輪融資宣告完成
- 巨輪智能2021年上半年營收11.24億元 期內研發費用投入增長19.05%
- 紅棗期貨尾盤拉升大漲近6% 目前紅棗市場總庫存約30萬噸
- 嘉銀金科發布2021年Q2財報 期內凈利潤達1.27億元同比增長208%
- 成都銀行2021上半年凈利33.89億元 期內實現營收同比增長17.27億元
- 汽車之家發布2021年第二季度業績 期內新能源汽車品牌收入增長238%
- 中信銀行上半年實現凈利潤290.31億元 期末不良貸款余額706.82億元
- 光伏概念掀起漲停潮交易價格創新高 全天成交額達1.29億元
- 上半年生物藥大增45% 關鍵財務指標好轉營收賬款持續下降
- 全球速讀:金鏟鏟之戰:騎馬武器陣容如何搭配?
- 每日短訊:養鴿子新手養鴿子怎么養_鴿子怎么養
- 全球熱議:各銀行儲蓄利息表,各銀行存款利率一覽
- buk是什么數字貨幣
- 【世界報資訊】廈門象嶼金控5億元公司債利率詢價區間為3.50%-4.50%
- 焦點速看:金管局: 10年期15億港元政府債券投標申請總額達43.11億港元
- 世界看熱訊:地產債漲跌不一 “H0陽城02”漲100%、“22旭輝01”跌超10%
- 天天快資訊丨3月8日南凌科技漲停分析:東數西算,云計算數據中心,信創概念熱股
- 世界今頭條!香港何文田St. George's Mansions四房大宅1.19億港元沽出
- 每日速訊:"21信地03"擬于3月13日起進行回售并將會進行轉售
- 天天微頭條丨3月8日三暉電氣漲停分析:儀器儀表概念熱股
- 3月8日金信諾漲停分析:6G,衛星互聯網,毫米波通信概念熱股
- 熱議:3月8日新城市漲停分析:智慧停車,新型城鎮化,深圳本地股概念熱股
- 【環球新要聞】it包括哪些服裝品牌?i.t經營的服裝品牌介紹?
- 熱點評!紅糖和紅砂糖有什么不同?紅糖和紅砂糖的區別是什么?
- 每日看點!玻璃護欄玻璃鑲嵌怎么操作?玻璃護欄玻璃鑲嵌方法是什么?
- 今頭條!小鱷龜和巴西龜能一起養嗎?為什么?
- 股票紅色和綠色代表什么
- 現在銀行定期存款利率是多少2022,各行存款利率一覽表
- 焦點滾動:我國三大棉花產地在哪里?我國三大棉花產地資料介紹?
- 每日精選:千媚是哪部電視劇中的人物?講述了什么故事?
- 大學為什么說成是象牙塔?象牙塔指的是什么?
- 快看:隋唐十八好漢都有誰?隋唐十八好漢排行榜一覽?
- 環球微資訊!歐洲旅游趨勢報告:美國客源持續引領復蘇,中國旅客需求增長可期
- 【天天速看料】gdp排名世界2021,中國排名第二
- 【環球熱聞】瀏覽器ie是什么意思?IE全稱是指什么?
- 信息:7號房的禮物劇情介紹?7號房的禮物結局是什么?
- 亞太市場國際差旅需求復蘇超過歐美,預訂量恢復到疫情之前65%的水平
- 中簽是什么意思啊
- 每日消息!買空賣空是什么意思
- 中交房地產集團12.1億公司債將付年息 利率3.49%
- 南京濱江投資公司5億元私募債更新至“已反饋”
- 【快播報】鷺燕醫藥:除個別新設門店因運營時間短未達到申請要求之外,公司絕大多數門店都具有醫保定點資質
- 天天即時:日本擬放寬民宿業準入條件 響應赴日游客恢復
- 當前快訊:上海浦東新區惠南鎮商業房產二拍成交 由北京詠旺物業1.62億元競得
- 天天微資訊!空調開年格局生變:從“雙寡頭”走向“三分天下”
- 常州金壇區潤澳花園大酒店流拍 起拍價約3.04億元
- CCTV健康大講堂專家:從連花清瘟解讀中藥治療甲流的優勢
- 全球動態:信用卡申請進度怎么查詢,有以下三種方法
- 天天看點:銀行貸款利率2022最新表,各行貸款利率一覽
- 環球動態:慶余年全套書有幾冊_慶余年大東山之戰原書第幾章
- 數字貨幣真正龍頭股 數字貨幣龍頭股具體有哪些
- k寶密碼忘了怎么辦,有以下兩種方法
- 建設銀行手機銀行怎么開通,有以下四種方法開通
- 華潤置地子公司潤朝地產掛牌增資 對應持股比例20%
- 女神節來臨,小吉內褲洗烘一體機,帶給您最溫柔的呵護
- 【全球速看料】致同: 亞太區女性高管比例超過30%關鍵水平
- 明陽智能:您問題中所描述的相關數據非公司對外披露之內容,其數據之準確性請您咨詢相關媒體
- 瑞信證券獲準擴大業務范圍 增加證券經紀、證券投資咨詢、證券自營業務三項業務
- 每日播報!企業家看兩會 :代表委員聚焦“白酒出?!?“綠色轉型” 獻策酒業
- 全球要聞:中交地產旗下廈門宏佑地產擬增資3.8億元 對應持股比例49%
- 今日熱文:又有大賣80億!這類產品徹底火了
- 【全球聚看點】南京公積金貸款額度2022,有以下兩種情況
- 環球最資訊丨中國銀行借記卡是什么意思
- 各大銀行存款利率排名,各行存款利率一覽
- 魚兒嘴巴一張一合是在干嘛
- 股票舉牌是什么意思
- 環球新動態:廣州越秀區產融對接項目簽約超1000億元 覆蓋科技、商貿等行業
- 熱點聚焦:“20美置02”回售金額9.84億元 將于3月27日兌付
- 快看點丨2023年2月中國物業服務企業新增合約面積TOP50
- 全球熱訊:“股神”巴菲特時隔半年再出手:大舉加倉西方石油!
- 傳莊士機構香港山頂屋地獲8.8億港元洽購至尾聲
- 焦點資訊:余額寶利息多少 余額寶一天的利息有多少
- 信用卡該怎么辦,有以下三種辦理途徑
- 北京銀行營業時間
- 喜報!鎂鋁裝甲門品牌艾德曼被品味標準起草單位
- 建行的貸款利率是多少2022,有以下四種利率
- 焦點熱文:銀行買房貸款利率2022年一覽表,各行房貸利率一覽
- 環球快消息!香港影視概念股齊升 邵氏兄弟控股一度漲近160%
- 小米隨身wifi怎樣安裝_小米隨身wifi怎么安裝手機app
- 港股貝殼-W跌逾5% 股價暫現三連陰
- 綠通科技:公司會綜合考慮發展戰略和實際經營需要,制定合理的利潤分配方案,具體情況請關注后續公告
- 全球新資訊:暴漲近200%!TVB也來帶貨,老牌藝人現身、直播間送簽名照!又一東方甄選?
- 世界視訊!中國鐵建房地產集團27億公司債將付年息 利率3.25%
- 焦點日報:港旅游界立會議員預期香港未來經高鐵入境旅客量會提升
- 天天觀察:香港置業:港2月二手居屋723宗注冊 按月增逾1成
- 環球微速訊:活期存款利率 各銀行活期存款的利率
- 銀行下午幾點上班 銀行下午什么時候上班
- 各銀行三年定期存款利率2022最新,十大銀行利率一覽
- 快看點丨馬蜂窩大數據:全國多地花季提前,“賞花”熱度大漲133%
- 攜程“她旅行”消費洞察:今年出境游女性訂單超過男性,出境占比達53%
- 全球時訊:2022年中國城市GDP100強排名,全國gdp百強排名一覽表
- 滾動:抖音直播怎么賺錢 抖音直播如何變現
- 環球微動態丨熵基科技:目前電子身份證正處于推行試點階段,國家尚未發布身份證電子化相關技術和應用標準
- 廣州公布2023年供地計劃 住宅用地擬供應901公頃
- 快報:科安達:科安達計軸產品在全國200多條城市軌道交通線路中應用,市場占有率60%以上
- 即時看!武漢推出"相約春天賞櫻"活動 將送出30萬張旅游惠民券
- 全球快資訊:已有城市踩點“交作業”!兩會后樓市會等來“寬松大年”嗎?
- 黑石-湯森路透財團將出售2300萬股倫交所股票 套現17億英鎊
- 環球速訊:福州將迎來第二家山姆會員店 將于5月18日開業
- 環球今日報丨【BT金融分析師】Adobe股票出現暴跌,分析師稱其AI擴張因監管受阻
- 鴻銘股份:具體業績情況請詳見我們即將披露的2022年年度報告和2023年第一季度報告,謝謝您的關注
- 高通是哪個國家的,美國
- 要聞:老板員工都在“報復性出差”,商旅酒店集體漲價、部分城市客房爆滿
- 世界快資訊丨科創板的上市時間是多久
- 2008年股市大跌,原因有以下三點
- 快播:現在銀行存款利率是多少2022年,各銀行存款利率一覽
- 股票β系數計算公式
- 品牌的力量 “2023中國儲能行業十佳品牌”公益評選活動 正式開啟
- 怎么才能提高自己的社交能力?提高自己的社交能力的方法?