• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            千張筆記

            Email:rain_qian830@163.com
            posts - 28, comments - 42, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            【原】OpenGL顯示視頻(7月27日工作小記)

            Posted on 2009-07-27 20:49 千張 閱讀(7999) 評論(2)  編輯 收藏 引用 所屬分類: 圖形學

            這周是實習的第三周了,堅持了兩周,慢慢也就習慣上班了,好了,說正事吧,O(∩_∩)O~
            今天小秦老師交給我的任務(wù)是用OpenGL顯示攝像頭中拍攝的畫面,要全屏顯示的。上周他已經(jīng)把程序框架給了我,所以一些初始化的工作我就不用做了,直接加?xùn)|西就行了。
            從圖像采集卡中讀取圖像采用的是小秦老師給我的dll,他們自己編寫的類,可以參考OpenCV'中的ARFrameGrabber類。


            獲取當前幀后,顯示圖像就很容易了,可以用紋理映射,將當前幀映射到一個矩形上,該矩形大小為視口大小。

            下面為初始化函數(shù):
            bool OpenGLDraw::Initialize()
            {
                
            //opengl Initialize

                
            //獲得屏幕分辨率
                int nFullWidth=GetSystemMetrics(SM_CXSCREEN); 
                
            int nFullHeight=GetSystemMetrics(SM_CYSCREEN); 

                
            //初始化視頻設(shè)備
                PalCapture.Init( 0false768576330true);
                
                
            //開啟紋理映射和設(shè)置紋理參數(shù)
                glEnable(GL_TEXTURE_2D);                                    
                glTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MAG_FILTER,GL_LINEAR);       
            //線性濾波
                glTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MIN_FILTER,GL_LINEAR);       //線性濾波
                
                
                
            //生成空紋理
                glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, 7685760, GL_RGB, GL_UNSIGNED_BYTE,NULL );

                
            /********************觀察視點設(shè)置*******************/            
                glViewport(
            00, nFullWidth, nFullHeight);
                glMatrixMode(GL_PROJECTION);    
                glLoadIdentity();
                gluOrtho2D(
            -11-11);
                glMatrixMode(GL_MODELVIEW);
                glLoadIdentity();

                
            return true;
            }

            下面為繪制函數(shù):
            void OpenGLDraw::Draw()
            {
                glClear(GL_COLOR_BUFFER_BIT 
            | GL_DEPTH_BUFFER_BIT);
                glClearColor(
            0.0f0.0f0.0f0.0f);
                glLoadIdentity();
                
                pFrmImage 
            = PalCapture.GetImage();
                IplImage 
            *pTempImg = cvCloneImage( pFrmImage);
                
            if (pFrmImage->origin == IPL_ORIGIN_TL)       //將圖像原點統(tǒng)一設(shè)置成左下角
                {
                    cvFlip(pFrmImage, pTempImg, 
            0);   //翻轉(zhuǎn)圖像
                    pTempImg->origin = IPL_ORIGIN_BL; //將pTempImg圖像的原點設(shè)置成左下角
                }

                
            //更新紋理
                glTexSubImage2D(GL_TEXTURE_2D, 000768576, GL_RGB, GL_UNSIGNED_BYTE, pTempImg->imageData);
                    
                glBegin(GL_QUADS);
                  glTexCoord2f(
            0.0f0.0f); glVertex2f(-1.0f,-1.0f);
                  glTexCoord2f(
            1.0f0.0f); glVertex2f(1.0f,-1.0f);
                  glTexCoord2f(
            1.0f1.0f); glVertex2f(1.0f,1.0f);
                  glTexCoord2f(
            0.0f1.0f); glVertex2f(-1.0f,1.0f);
                glEnd();
                glFlush();
                cvReleaseImage(
            &pTempImg);
            }



            其中PalCapture是視頻采集卡類的對象,獲取一幀圖像即pFrmImage,pFrmImage是IplImage類型的圖像,此處直接對pFrmImage的imageData進行操作。
            關(guān)于顯示視頻 (AVI視頻) ,NEHE的OpenGL課程的第35課中有詳細介紹,我也是參考那個的~~只不多OpenCV中有翻轉(zhuǎn)函數(shù)cvFlip函數(shù),我就不用自己寫了~~

            NEHE的課程還提到:使用glTexSubImage2D()另一個重要原因.不僅因為在許多OpenGL實現(xiàn)中它很快,還因為目標區(qū)不必是2的冪.這對視頻重放很方便,因為一幀的維通常不是2的冪(而是像320*200之類的).這樣給了你很大機動性,你可以按視頻流原本的樣子播放,而不是扭曲或剪切每一幀來適應(yīng)紋理的維。
            所以這里我沒有把圖像轉(zhuǎn)換成紋理要求的大小(大小為2的非負n次冪),不知道這樣做對不對,不過畫面顯示效果看起來還不錯。

            這么幾行代碼,我還弄了一天,貌似紅寶書上有的,還是基礎(chǔ)不牢噢。明天有網(wǎng)絡(luò)傳輸數(shù)據(jù)方面的任務(wù),關(guān)于網(wǎng)絡(luò),我可是一點都不懂,慢慢看吧

            Feedback

            # re: 【原】OpenGL顯示視頻(7月27日工作小記)  回復(fù)  更多評論   

            2009-07-28 15:14 by 凡客誠品
            奧斯卡大家阿斯頓!

            # re: 【原】OpenGL顯示視頻(7月27日工作小記)  回復(fù)  更多評論   

            2012-09-06 18:46 by abc
            精品综合久久久久久98| 亚洲精品无码久久久久sm| 久久99亚洲网美利坚合众国| 久久久久久久人妻无码中文字幕爆 | 欧美牲交A欧牲交aⅴ久久| 9久久9久久精品| 欧美精品福利视频一区二区三区久久久精品 | 国产精品美女久久福利网站| 久久久免费精品re6| 久久天天躁狠狠躁夜夜2020 | 香蕉久久夜色精品升级完成| 国产精品日韩深夜福利久久| 亚洲国产另类久久久精品| 国产成人99久久亚洲综合精品| 久久婷婷五月综合色奶水99啪| 久久99热精品| 日韩精品久久久肉伦网站| 欧美久久久久久午夜精品| 日日躁夜夜躁狠狠久久AV| 久久无码国产| 精品国产热久久久福利| 久久国产精品成人影院| 久久久网中文字幕| 国产精品亚洲综合专区片高清久久久| 精品久久久久久中文字幕大豆网| 久久久亚洲精品蜜桃臀| 精品久久久久久99人妻| 久久美女网站免费| 国产精品久久久天天影视| 久久久久人妻精品一区| 久久精品国产亚洲av麻豆蜜芽 | 久久精品国产一区二区| 色综合久久综精品| 久久91亚洲人成电影网站| 97久久精品无码一区二区| 人妻少妇久久中文字幕一区二区| 综合网日日天干夜夜久久| 天天爽天天狠久久久综合麻豆| 亚洲AV日韩AV天堂久久| 久久精品中文闷骚内射| 久久福利青草精品资源站免费|