• <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 千張 閱讀(7984) 評論(2)  編輯 收藏 引用 所屬分類: 圖形學

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


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

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

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

                
            //初始化視頻設備
                PalCapture.Init( 0false768576330true);
                
                
            //開啟紋理映射和設置紋理參數(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 );

                
            /********************觀察視點設置*******************/            
                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)一設置成左下角
                {
                    cvFlip(pFrmImage, pTempImg, 
            0);   //翻轉圖像
                    pTempImg->origin = IPL_ORIGIN_BL; //將pTempImg圖像的原點設置成左下角
                }

                
            //更新紋理
                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進行操作。
            關于顯示視頻 (AVI視頻) ,NEHE的OpenGL課程的第35課中有詳細介紹,我也是參考那個的~~只不多OpenCV中有翻轉函數(shù)cvFlip函數(shù),我就不用自己寫了~~

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

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

            Feedback

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

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

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

            2012-09-06 18:46 by abc
            久久精品国产第一区二区三区| 天天综合久久一二三区| 久久精品国产亚洲77777| 97久久超碰国产精品2021| 激情五月综合综合久久69| 久久婷婷五月综合成人D啪| 精品免费tv久久久久久久| 国产一区二区精品久久凹凸| 久久久久免费精品国产| 一级做a爰片久久毛片人呢| 久久精品一区二区三区AV| 国产99久久精品一区二区| 波多野结衣久久精品| 久久99国产精品二区不卡| 国产A级毛片久久久精品毛片| 99久久亚洲综合精品网站| 男女久久久国产一区二区三区| 激情五月综合综合久久69| 精品国产VA久久久久久久冰 | 国内精品久久久久影院薰衣草 | 亚洲色欲久久久综合网东京热| 久久精品一区二区三区不卡| 性做久久久久久久久浪潮| 国产精品久久久久久| 久久精品国产亚洲av影院| 亚洲AV乱码久久精品蜜桃| 波多野结衣AV无码久久一区| 亚洲乱码日产精品a级毛片久久| 超级碰久久免费公开视频| 国产精品久久网| 国产精品久久精品| 久久99精品久久久久婷婷| 久久无码人妻一区二区三区午夜| 亚洲中文字幕久久精品无码APP | 狠狠色丁香久久婷婷综合| 国产精品成人久久久| 国产精品久久久久久久久久影院| 日韩精品无码久久一区二区三| 日韩美女18网站久久精品 | 伊人久久大香线蕉成人| 久久亚洲国产成人影院网站|