發(fā)布時(shí)間:2021-04-25
欄目:其他
利用PlatformBuilder定制WindowsCE系統(tǒng)并開(kāi)發(fā)USB攝像頭驅(qū)動(dòng)和數(shù)據(jù)發(fā)送端的開(kāi)發(fā)新格局,本文詳細(xì)介紹USB攝像頭驅(qū)動(dòng)的設(shè)計(jì)和發(fā)送端的程序設(shè)計(jì)明顯。系統(tǒng)的軟件結(jié)構(gòu)圖如圖3所示。
WindowsCE流接口驅(qū)動(dòng)程序是具有定制接口的驅(qū)動(dòng)程序顯示,表現(xiàn)為在用戶一級(jí)的動(dòng)態(tài)鏈接庫(kù)DLL創新為先,是一般類(lèi)型的設(shè)備驅(qū)動(dòng)程序。流接口驅(qū)動(dòng)程序中用來(lái)實(shí)現(xiàn)一組固定的函數(shù)稱(chēng)為流接口函數(shù)科普活動,這些流接口函數(shù)使得應(yīng)用程序可以通過(guò)文件系統(tǒng)訪問(wèn)這些驅(qū)動(dòng)程序創新延展。流接口驅(qū)動(dòng)程序幾乎支持任何類(lèi)型的可以連接到基于WindowsCE.net的平臺(tái)外部設(shè)備,其中包括USB設(shè)備。
流接口驅(qū)動(dòng)程序的主要任務(wù)是把外設(shè)的使用傳遞給應(yīng)用程序基本情況,這是通過(guò)把設(shè)備表示為文件系統(tǒng)的一個(gè)特殊文件實(shí)現(xiàn)現場。應(yīng)用程序通過(guò)文件系統(tǒng)的API函數(shù)調(diào)用流接口函數(shù),然后流接口驅(qū)動(dòng)程序調(diào)用本機(jī)驅(qū)動(dòng)或者通過(guò)設(shè)備管理器與系統(tǒng)內(nèi)核或外圍打交道力量。
2.1 攝像頭驅(qū)動(dòng)程序的流接口函數(shù)的實(shí)現(xiàn)
開(kāi)發(fā)攝像頭驅(qū)動(dòng)程序涉及到一組標(biāo)準(zhǔn)的流接口驅(qū)動(dòng)程序的函數(shù)我有所應,如CAM_Init()、CAM_Deinit()提升行動、CAM_Open()、CAM_Read()等關註,這些函數(shù)是接口驅(qū)動(dòng)程序的DLL接口研究進展,其中CAM_Init()、CAM_Open()機遇與挑戰、CAM_Read()和CAM_IOControl()最為重要廣泛關註。下面對(duì)這些重要函數(shù)進(jìn)行詳細(xì)介紹。
〖杉夹g。?)CAM_Init()
CAM_Init()函數(shù)是通過(guò)設(shè)備管理器提供的ActiveDeviceEx()函數(shù)調(diào)用就能壓製。在設(shè)備初始化時(shí)通過(guò)ActiveDeviceEx()將設(shè)備句柄信息寫(xiě)入DriversActive下面,當(dāng)應(yīng)用程序初始化時(shí)適應能力,注冊(cè)表的地址將以Context參數(shù)形式傳給CAM_Init()網(wǎng)站狀態(tài)監(jiān)控助手更優美,利用RegOpenKeyEx()、RegQueryValueEx()等函數(shù)執(zhí)行打開(kāi)和讀寫(xiě)注冊(cè)表操作防控,等執(zhí)行成功后返回USB設(shè)備的句柄信息等成效與經驗。驅(qū)動(dòng)程序的部分源代碼:
(2)CAM_Open()
在對(duì)設(shè)備進(jìn)行讀操作之前堅實基礎,首先要先通過(guò)執(zhí)行CeratFile()來(lái)調(diào)用CAM_Open()打開(kāi)設(shè)備稍有不慎,CAM_Open()所需的第一個(gè)參數(shù)是應(yīng)用程序初始化時(shí)由CAM_Init()返回的設(shè)備句柄等信息,然后將設(shè)備關(guān)閉的事件設(shè)為無(wú)信號(hào)狀態(tài)等地。
下面是部分源碼:
程序中涉及的EnterCriticalSection()和LeaveCriticalSection()兩個(gè)函數(shù)的作用是保證在臨界區(qū)內(nèi)所有被訪問(wèn)的資源不被其他線程訪問(wèn)最為顯著,直到當(dāng)前線程執(zhí)行完臨界區(qū)代碼。EnterCriticalSection()和LeaveCriticalSection()分別表示為進(jìn)入臨界區(qū)和退出臨界區(qū)規定。
…h境。?)CAM_IOControl()
程序設(shè)計(jì)中通過(guò)CreatFile()函數(shù)調(diào)CAM_Open()打開(kāi)攝像頭設(shè)備,通過(guò)ReadFile()將返回值傳給CAM_IOControl()流接口函數(shù)高質量,而CAM_IOControl()則調(diào)用OV51xReadOneFrame()對(duì)USB設(shè)備數(shù)據(jù)進(jìn)行讀取優勢與挑戰。下面是部分源碼:
對(duì)于USB總線上的數(shù)據(jù)傳輸,一共有四種傳輸類(lèi)型解決方案,分別是控制傳輸趨勢、中斷傳輸、批量傳輸和實(shí)時(shí)傳輸,這四種傳輸類(lèi)型分別應(yīng)用到不同的USB設(shè)備一站式服務。其中實(shí)時(shí)傳輸適用于以固定速率或特定時(shí)間內(nèi)傳輸廣度和深度,可以容忍偶爾錯(cuò)誤的流數(shù)據(jù)情況,對(duì)于USB攝像頭這種實(shí)時(shí)性要求比較高的設(shè)備一般選用實(shí)時(shí)傳輸引領作用,所以在CAM_Read()中就需要用到實(shí)時(shí)傳輸函數(shù)IssueIsochTransfer()來(lái)讀取攝像頭采集的數(shù)據(jù)加強宣傳。如果IssueIsochTransfer()執(zhí)行后返回一個(gè)標(biāo)示句柄,則代表執(zhí)行成功用的舒心,如果無(wú)返回值技術發展,則表示執(zhí)行失敗。
下面是部分源碼:
程序中涉及的EnterCriticalSection()和LeaveCriticalSection()兩個(gè)函數(shù)的作用是保證在臨界區(qū)內(nèi)所有被訪問(wèn)的資源不被其他線程訪問(wèn)前來體驗,直到當(dāng)前線程執(zhí)行完臨界區(qū)代碼自主研發。EnterCriticalSection()和LeaveCriticalSection()分別表示為進(jìn)入臨界區(qū)和退出臨界區(qū)。
「訌V闊。?)CAM_IOControl()
程序設(shè)計(jì)中通過(guò)CreatFile()函數(shù)調(diào)CAM_Open()打開(kāi)攝像頭設(shè)備損耗,通過(guò)ReadFile()將返回值傳給CAM_IOControl()流接口函數(shù),而CAM_IOControl()則調(diào)用OV51xReadOneFrame()對(duì)USB設(shè)備數(shù)據(jù)進(jìn)行讀取非常完善。下面是部分源碼:
實(shí)時(shí)監(jiān)控網(wǎng)站對(duì)于USB總線上的數(shù)據(jù)傳輸性能穩定,一共有四種傳輸類(lèi)型,分別是控制傳輸作用、中斷傳輸情況正常、批量傳輸和實(shí)時(shí)傳輸,這四種傳輸類(lèi)型分別應(yīng)用到不同的USB設(shè)備技術特點。其中實(shí)時(shí)傳輸適用于以固定速率或特定時(shí)間內(nèi)傳輸醒悟,可以容忍偶爾錯(cuò)誤的流數(shù)據(jù)情況,對(duì)于USB攝像頭這種實(shí)時(shí)性要求比較高的設(shè)備一般選用實(shí)時(shí)傳輸高質量,所以在CAM_Read()中就需要用到實(shí)時(shí)傳輸函數(shù)IssueIsochTransfer()來(lái)讀取攝像頭采集的數(shù)據(jù)也逐步提升。如果IssueIsochTransfer()執(zhí)行后返回一個(gè)標(biāo)示句柄,則代表執(zhí)行成功註入了新的力量,如果無(wú)返回值重要的作用,則表示執(zhí)行失敗。
在每次得到一包數(shù)據(jù)時(shí)去創新,查找?guī)_(kāi)始標(biāo)記足夠的實力,如果查找到,則復(fù)制剩余的所有數(shù)據(jù)到應(yīng)用程序的緩沖中結構。在程序的Ov51xReadOneFrame()函數(shù)中更適合,pDataBuff申請(qǐng)了9610B空間,dwFrameLen為10次傳輸每次的長(zhǎng)度溝通協調,這里都設(shè)置為961要素配置改革。圖4為Ov51ReadFrame()軟件流程圖體系。
2.2 通信發(fā)送端的設(shè)計(jì)實(shí)現(xiàn)
通信發(fā)送端主要完成RTP/RTCP協(xié)議封裝和解封裝、網(wǎng)絡(luò)發(fā)送與數(shù)據(jù)獲取帶動產業發展。本文所實(shí)現(xiàn)的是基于RTP/UDP/IP協(xié)議棧的MPEG-4實(shí)時(shí)流媒體傳輸責任製,是移動(dòng)視頻監(jiān)控系統(tǒng)中網(wǎng)絡(luò)傳輸部分的子模塊。采用JRTPLIB庫(kù)函數(shù)來(lái)實(shí)現(xiàn)RTP的實(shí)時(shí)傳輸倍增效應。傳輸部分的系統(tǒng)架構(gòu)如圖5所示有序推進。
該發(fā)送端的主要功能是將音視頻流封裝到RTP包內(nèi)通過(guò)3G網(wǎng)絡(luò)傳送給接收端,同時(shí)發(fā)送和接收RTCP包進(jìn)行反饋控制需求,以期達(dá)到最佳效果堅定不移。基于WindowsCE平臺(tái)通過(guò)調(diào)用JRTPLIB函數(shù)庫(kù)來(lái)編程實(shí)現(xiàn)實(shí)時(shí)流媒體傳輸更讓我明白了。
由于RTP協(xié)議并不作為獨(dú)立的網(wǎng)絡(luò)層來(lái)實(shí)現(xiàn)迎難而上,它采用應(yīng)用層組幀的理念,作為應(yīng)用程序代碼的一部分免費(fèi)網(wǎng)站監(jiān)控充分,本文針對(duì)一個(gè)具體媒體的應(yīng)用通過(guò)應(yīng)用程序?qū)崿F(xiàn)RTP封裝分組進一步完善,然后將RTP分組交給UDP接口集聚,采用JTHREAD作為線程庫(kù)競爭力,完成多線程的操作。利用RTP來(lái)做視頻傳輸分2個(gè)session來(lái)完成:一個(gè)負(fù)責(zé)聲音傳送狀況;另一個(gè)負(fù)責(zé)視頻傳送機製性梗阻。
發(fā)送端的部分主程序如下:
3 結(jié)語(yǔ)
本文在現(xiàn)有的汽車(chē)防盜報(bào)警系統(tǒng)的基礎(chǔ)上,通過(guò)接口的擴(kuò)展全過程,實(shí)現(xiàn)了基于3G網(wǎng)絡(luò)的視頻監(jiān)控功能集成應用,并詳細(xì)闡述了攝像頭的流接口函數(shù)和通信發(fā)送端的設(shè)計(jì)。此外不負眾望,通過(guò)該系統(tǒng)的通用接口的擴(kuò)展高效流通,該系統(tǒng)還可與具體行業(yè)或家庭應(yīng)用相結(jié)合,實(shí)現(xiàn)手機(jī)對(duì)于小范圍環(huán)境的可視化監(jiān)控精準調控。該系統(tǒng)的設(shè)計(jì)實(shí)現(xiàn)不但對(duì)于汽車(chē)防盜產(chǎn)品的發(fā)展有著重要的意義功能,同時(shí)對(duì)于基于3G網(wǎng)絡(luò)的可視化監(jiān)控的發(fā)展提供了良好的應(yīng)用前景。
iPhone6搶購(gòu)神器降世 實(shí)時(shí)監(jiān)控蘋(píng)果官網(wǎng)供貨情況
在面對(duì)iPhone6/iPhone6 Plus這兩款神器的時(shí)候解決,就連土豪也使不上什么勁預期,有錢(qián)都花不出去,因?yàn)閾屬?gòu)iPhone6的難度已經(jīng)不亞于在中國(guó)搶購(gòu)春運(yùn)火車(chē)票了幅度。不過(guò)結構,iPhone6搶購(gòu)神器也問(wèn)世了!據(jù)說(shuō)跟春運(yùn)搶票軟件有的一拼貢獻。
文章地址:http://www.61py.com/article/other/jyWindowsCEczxtdrjjgbglbf.html

- 1通王CMS 2.0簡(jiǎn)介
- 2黑帽網(wǎng)站排名檢測(cè)
- 3MySQL中經(jīng)典的too many connection怎么破
- 4網(wǎng)易郵箱洪陸駕:反垃圾郵件需集合全球力量
- 5站群友鏈換鏈神器
- 6云勢(shì)軟件VirgoEDC助力安徽萬(wàn)邦、迪時(shí)咨詢等公司臨床試驗(yàn)數(shù)據(jù)采集智能化
- 7Authorize 屬性通過(guò)聲明的方式保護(hù)控制器或其部分方法
- 8域名是稀有資源優勢,好的域名善謀新篇,在一定時(shí)期內(nèi)會(huì)越來(lái)越升值
- 9解析常見(jiàn)的PHP緩存技術(shù)有哪些
- 10對(duì)ASP.NET程序員非常有用工具