最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當(dāng)前位置: 首頁 - 科技 - 知識(shí)百科 - 正文

WPF中在攝像頭視頻上疊加控件的解決方案

來源:懂視網(wǎng) 責(zé)編:小OO 時(shí)間:2020-11-27 22:35:50
文檔

WPF中在攝像頭視頻上疊加控件的解決方案

說道WPF想必有很多朋友跟小編一樣不知道wpf是什么,今天小編就給大家簡(jiǎn)單普及下基本概念。WPF(Windows Presentation Foundation)是微軟推出的基于Windows 的用戶界面框架,屬于.NET Framework 3.0的一部分。它提供了統(tǒng)一的編程模型、語言和框架,真正做到了分離界面設(shè)計(jì)人員與開發(fā)人員的工作;同時(shí)它提供了全新的多媒體交互用戶圖形界面。一、視頻呈現(xiàn);前段時(shí)間,在一個(gè)wpf的項(xiàng)目中需要實(shí)時(shí)顯示ip攝像頭,對(duì)此的解決方案想必大家都應(yīng)該知道很多。在winform中,可以將一個(gè)控件(一般用panel或者pictruebox)的句柄丟給攝像頭的sdk以實(shí)現(xiàn)該功能,而在wpf中我們同樣可以使用該方案快速實(shí)現(xiàn)。
推薦度:
導(dǎo)讀說道WPF想必有很多朋友跟小編一樣不知道wpf是什么,今天小編就給大家簡(jiǎn)單普及下基本概念。WPF(Windows Presentation Foundation)是微軟推出的基于Windows 的用戶界面框架,屬于.NET Framework 3.0的一部分。它提供了統(tǒng)一的編程模型、語言和框架,真正做到了分離界面設(shè)計(jì)人員與開發(fā)人員的工作;同時(shí)它提供了全新的多媒體交互用戶圖形界面。一、視頻呈現(xiàn);前段時(shí)間,在一個(gè)wpf的項(xiàng)目中需要實(shí)時(shí)顯示ip攝像頭,對(duì)此的解決方案想必大家都應(yīng)該知道很多。在winform中,可以將一個(gè)控件(一般用panel或者pictruebox)的句柄丟給攝像頭的sdk以實(shí)現(xiàn)該功能,而在wpf中我們同樣可以使用該方案快速實(shí)現(xiàn)。

說道WPF想必有很多朋友跟小編一樣不知道wpf是什么,今天小編就給大家簡(jiǎn)單普及下基本概念。

WPF(Windows Presentation Foundation)是微軟推出的基于Windows 的用戶界面框架,屬于.NET Framework 3.0的一部分。它提供了統(tǒng)一的編程模型、語言和框架,真正做到了分離界面設(shè)計(jì)人員與開發(fā)人員的工作;同時(shí)它提供了全新的多媒體交互用戶圖形界面。

一、視頻呈現(xiàn)

  前段時(shí)間,在一個(gè)wpf的項(xiàng)目中需要實(shí)時(shí)顯示ip攝像頭,對(duì)此的解決方案想必大家都應(yīng)該知道很多。在winform中,我們可以將一個(gè)控件(一般用panel或者pictruebox)的句柄丟給攝像頭的sdk以實(shí)現(xiàn)該功能,而在wpf中我們同樣可以使用該方案快速實(shí)現(xiàn)。

  我們以??灯脚_(tái)為例,??档膕dk就需要我們傳遞一個(gè)控件的句柄,winform中可以直接使用控件的handle屬性來獲取句柄,而在wpf中我們則有兩種方法:

  1、將WindowsFormsHost作為容器在內(nèi)部嵌套一個(gè)winform控件,比如panel,這樣的話就和winform中一樣了;

  2、直接使用    ((HwndSource)PresentationSource.FromVisual(你的wpf元素)).Handle;  獲取句柄;

二、疊加控件

  簡(jiǎn)單的視頻展示使用一中的方案就可以解決,但我接手的項(xiàng)目是一個(gè)將攝像頭視頻用以AR處理的程序,界面上需要展示很多圖標(biāo)和信息欄,最重要的是整個(gè)主程序的大背景就是實(shí)時(shí)的攝像頭畫面,除此之外還有各種子窗口,子窗口中也要用到視頻,這樣就必然涉及到在視頻畫面上疊加控件的難題?! ?/p>

  1、使用Microsoft.DwayneNeed

  之所以說是難題,是微軟也在試圖解決卻也沒有給出真正完美的解決方案。這個(gè)難題就是著名的空域問題(airspace issues)。這里有一份園友的隨筆鏈接,主要介紹的是微軟目前的解決方案://www.gxlcms.com/article/110896.htm,這套方案在我實(shí)際使用中雖然可以正常的在視頻上疊加控件,但在上方拖動(dòng)控件則非??D,通常的情況就是鼠標(biāo)已經(jīng)移動(dòng)到了右側(cè),被拖控件還在左側(cè)依依不舍,即便是release版本也無濟(jì)于事,這套方案最終流產(chǎn)。 

  2、將視頻流轉(zhuǎn)碼,使用d3d渲染為ImageSource

  此方案比較麻煩,需要自己控制轉(zhuǎn)碼過程,這里有一篇關(guān)于此方案的文章鏈接://www.gxlcms.com/article/110898.htm,我這里準(zhǔn)備了一份demo(非本人編寫):https://pan.baidu.com/s/1i59OZC5,以下是demo運(yùn)行的截圖:

  大致的原理就是利用sdk的回調(diào)機(jī)制逐幀獲取碼流,再使用direct進(jìn)行渲染;

  此方案除了代碼量相對(duì)多點(diǎn)之外還存在和1中同樣的問題,控件拖動(dòng)時(shí)依然卡頓,各位園友不知有何好的解決辦法呢。

  3、最終的解決方案

  在1和2都達(dá)不到理想中的要求時(shí),我突然意識(shí)到一個(gè)問題,為什么會(huì)出現(xiàn)空域問題?那是因?yàn)閣inform和wpf的渲染方式不同,如果將他們統(tǒng)一,問題是不是解決了?只能說解決了一半,如果需要疊加的控件是規(guī)規(guī)矩矩的矩形,換句話說,不需要透明通道的那些控件,則完全可以使用這套方案,但是像那些有圓角的控件還需要另外想辦法,我們先說前者吧,簡(jiǎn)單的代碼如下:

<wfi:WindowsFormsHost>
 <wf:Panel/>
</wfi:WindowsFormsHost>
<wfi:WindowsFormsHost Width="114" Height="152">
  <ElementHost>
    <Border Width="114" Height="152"/>
  </ElementHost>
</wfi:WindowsFormsHost>

  其實(shí)就是在 WindowsFormsHost再套一個(gè)ElementHost,現(xiàn)在無論是視頻的panel還是在其上方的border控件由于都被WindowsFormsHost所包含,所以border在渲染時(shí)不會(huì)被覆蓋到底層了。

  下面再談?wù)勎覀€(gè)人認(rèn)為最難的不規(guī)則控件的疊加方式,如果你能在wpf應(yīng)用中通過代碼讓W(xué)indowsFormsHost背景透明,那么你不需要再繼續(xù)往下看了,請(qǐng)你聯(lián)系我,我認(rèn)為這才是最好的解決方案,而接下來我要說的方案可能會(huì)讓你們不屑,甚至嘲笑。

  我的辦法很簡(jiǎn)單,就是使用兩個(gè)窗口,底部窗口單獨(dú)顯示視頻,并設(shè)置為主窗口,頂部窗口設(shè)置AllowsTransparency="True",ShowInTaskbar="False",在顯示頂部窗口時(shí)使用showdialog而不是show,這樣能夠保證用戶永遠(yuǎn)在頂部窗口上操作,到不了視頻窗口。針對(duì)子窗口的情況,雖然可以用popup來模擬上述過程,但popup也有很多問題,他默認(rèn)是置頂?shù)?,有時(shí)會(huì)給用戶帶來困惑,比如兩個(gè)子窗口重疊時(shí),明明帶視頻的那個(gè)窗口在底部,但由于其中的視頻部分使用的是popup來展示的,它居然會(huì)顯示在頂層窗口之上,完美實(shí)現(xiàn)了窗口洗牌的特效,除此之外你還需要通過特殊的偏移量才能控制popup的位置,鑒于此,我建議你單獨(dú)定制一個(gè)專門用來彈出信息的窗體,再將包含視頻的控件作為子元素傳入其中。

  最終的解決方案是結(jié)合這三種,由于主界面是個(gè)實(shí)時(shí)視頻大背景,所以任何拖動(dòng)的操作都不該延遲,所以主界面用了3號(hào)解決方案,而一些子界面不涉及到在上方拖動(dòng)的操作,則可以用1號(hào)方案,至于2號(hào)方案則可以用來兼容各大視頻平臺(tái),例如有些視頻平臺(tái)不支持句柄的傳入,則可以使用該方案。

以上所述是小編給大家介紹的WPF中在攝像頭視頻上疊加控件的解決方案,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

WPF中在攝像頭視頻上疊加控件的解決方案

說道WPF想必有很多朋友跟小編一樣不知道wpf是什么,今天小編就給大家簡(jiǎn)單普及下基本概念。WPF(Windows Presentation Foundation)是微軟推出的基于Windows 的用戶界面框架,屬于.NET Framework 3.0的一部分。它提供了統(tǒng)一的編程模型、語言和框架,真正做到了分離界面設(shè)計(jì)人員與開發(fā)人員的工作;同時(shí)它提供了全新的多媒體交互用戶圖形界面。一、視頻呈現(xiàn);前段時(shí)間,在一個(gè)wpf的項(xiàng)目中需要實(shí)時(shí)顯示ip攝像頭,對(duì)此的解決方案想必大家都應(yīng)該知道很多。在winform中,可以將一個(gè)控件(一般用panel或者pictruebox)的句柄丟給攝像頭的sdk以實(shí)現(xiàn)該功能,而在wpf中我們同樣可以使用該方案快速實(shí)現(xiàn)。
推薦度:
標(biāo)簽: 視頻 攝像頭 攝像
  • 熱門焦點(diǎn)

最新推薦

猜你喜歡

熱門推薦

專題
Top