• <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>

            Welcome to ErranLi's Blog!

              C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
              106 Posts :: 1 Stories :: 97 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(12)

            搜索

            •  

            積分與排名

            • 積分 - 175054
            • 排名 - 151

            最新評論

            閱讀排行榜



            在WinCE中, 由于WinCE的精簡,有很多win32下的標準API不支持,所以有很多在vc上能夠輕易實現的功能, 在evc中有點難度,必須變通一下,就拿截取屏幕來說,一個常用的函數GetDIBits在wince就Unsupported.當時為了實現這個功能,頗費了了一番心血,當然其主要還是因為對api不是很熟悉。

            最初使用的截屏方法說來還真有些丟人,一個一個點的取得顏色值,再保存到bmp文件中去,這樣程序運行的速度超慢,保存一個800X600的bmp差不多要一兩分鐘(研華8251板),覺得有些不對頭,決定想辦法改進一下,就使勁地看了一下Charles Petzold先生的《Programming Windows》(這本書很經典,值得好好研究一下),終于把時間縮短到幾秒鐘了,下面這個函數在evc和vc下都test pass(不用更改),有不足之處歡迎指正,函數:

            // this function create a bmp file to save the current screen;
            // supported eVC++ 4.0 (wince 4.0) and vc++ 6.0 , test pass;

            void CSnapDlg::OnScreenSave(const char *filename)

                HDC  hScrDC, hMemDC;        
                int  width, height; 
             
             //the pointer will save all pixel point's color value
             BYTE  *lpBitmapBits = NULL;
                   
             //creates a device context for the screen device
                hScrDC = CreateDC(_T("DISPLAY"), NULL, NULL, NULL);

              //get the screen point size
                width = GetDeviceCaps(hScrDC, HORZRES);
                height = GetDeviceCaps(hScrDC, VERTRES);

                //creates a memory device context (DC) compatible with the screen device(hScrDC) 
                hMemDC = CreateCompatibleDC(hScrDC);

             //initialise the struct BITMAPINFO for the bimap infomation,
             //in order to use the function CreateDIBSection
             //
            on wince os, each pixel stored by 24 bits(biBitCount=24) 
             //and no compressing(biCompression=0)

                BITMAPINFO RGB24BitsBITMAPINFO;
                ZeroMemory(&RGB24BitsBITMAPINFO, sizeof(BITMAPINFO));
                RGB24BitsBITMAPINFO.bmiHeader.biSize = sizeof(BITMAPINFOHEADER);
                RGB24BitsBITMAPINFO.bmiHeader.biWidth = width;
                RGB24BitsBITMAPINFO.bmiHeader.biHeight = height;
                RGB24BitsBITMAPINFO.bmiHeader.biPlanes = 1;
                RGB24BitsBITMAPINFO.bmiHeader.biBitCount = 24;
              
             
            //use the function CreateDIBSection and SelectObject 
             //in order to get the bimap pointer : lpBitmapBits

                HBITMAP directBmp = CreateDIBSection(hMemDC, (BITMAPINFO*)&RGB24BitsBITMAPINFO,
                   DIB_RGB_COLORS, (void **)&lpBitmapBits, NULL, 0);
             HGDIOBJ previousObject = SelectObject(hMemDC, directBmp);

             // copy the screen dc to the memory dc
             BitBlt(hMemDC, 0, 0, width, height, hScrDC, 0, 0, SRCCOPY);
             
             //if you only want to get the every pixel color value,
             //you can begin here and the following part of this function will be unuseful;
             //the following part is in order to write file;

             //bimap file header in order to write bmp file
             BITMAPFILEHEADER bmBITMAPFILEHEADER;
             ZeroMemory(&bmBITMAPFILEHEADER, sizeof(BITMAPFILEHEADER));
             bmBITMAPFILEHEADER.bfType = 0x4d42;  //bmp 
                bmBITMAPFILEHEADER.bfOffBits = sizeof(BITMAPFILEHEADER) + sizeof(BITMAPINFOHEADER);
                bmBITMAPFILEHEADER.bfSize = bmBITMAPFILEHEADER.bfOffBits + ((width*height)*3); ///3=(24 / 8)
             
             //write into file
             FILE *mStream = NULL;
             if((mStream = fopenfilename, "wb")))
             {  
              //write bitmap file header
              fwrite(&bmBITMAPFILEHEADER, sizeof(BITMAPFILEHEADER), 1, mStream);
              //write bitmap info
              fwrite(&(RGB24BitsBITMAPINFO.bmiHeader), sizeof(BITMAPINFOHEADER), 1, mStream);
              //write bitmap pixels data
              fwrite(lpBitmapBits, 3*width*height, 1, mStream);
             
             //close file
              fclose(mStream);
             }
             
             //delete
             DeleteObject(hMemDC);
             DeleteObject(hScrDC);
             DeleteObject(directBmp);
             DeleteObject(previousObject);
            }

            還是用英語作了注釋,雖然英語學的很糟糕,還是覺得這個習慣比較好~~ ..


            posted on 2006-05-14 01:34 erran 閱讀(3951) 評論(4)  編輯 收藏 引用 所屬分類: WinCE

            Feedback

            # re: EVC實現WIN CE下截屏并且保存到文件[By Erran] 2007-06-13 00:12 S.S.Pang
            萬分感謝!!正需要這個.呵呵.  回復  更多評論
              

            # re: EVC實現WIN CE下截屏并且保存到文件[By Erran] [未登錄] 2007-12-26 13:08 Terry
            if((mStream = fopenfilename, "wb")))

            應該是...

            if((mStream = fopen(filename, "wb")))
              回復  更多評論
              

            # re: EVC實現WIN CE下截屏并且保存到文件[By Erran] [未登錄] 2008-11-07 17:06 Feng
            十分感謝  回復  更多評論
              

            # re: EVC實現WIN CE下截屏并且保存到文件[By Erran] 2010-03-06 09:34 xiaoI000
            如果只是需要一個截屏的工具,就不需要自己寫代碼了,網上有這種工具
            我用了下下面這個,還很好用,可以直接在PC上遠程截取Windows CE上的屏幕.
            http://www.wceui.cn/blog/article/wceui_capturescreen.html
              回復  更多評論
              

            99久久精品国产麻豆| 91久久香蕉国产熟女线看| 人妻无码αv中文字幕久久琪琪布 人妻无码精品久久亚瑟影视 | 久久精品国产影库免费看 | 精品久久人人做人人爽综合| 日日狠狠久久偷偷色综合0| 亚洲国产精品成人久久| 久久精品国产福利国产琪琪| 久久亚洲春色中文字幕久久久 | 久久久久波多野结衣高潮| 精品精品国产自在久久高清| 久久久久久极精品久久久| 2020久久精品国产免费| 99精品国产免费久久久久久下载| 欧美一区二区三区久久综合 | 久久精品亚洲福利| 97热久久免费频精品99| 亚洲色婷婷综合久久| 久久久久香蕉视频| 久久er热视频在这里精品| 午夜人妻久久久久久久久| 一本大道久久香蕉成人网| 国产精品久久久久乳精品爆| 国产Av激情久久无码天堂| 亚洲精品乱码久久久久久蜜桃不卡 | 久久亚洲视频| 国产精品一区二区久久精品无码 | 内射无码专区久久亚洲| 亚洲国产精品久久久久久| 精品人妻久久久久久888| 精品久久久无码人妻中文字幕 | 久久伊人亚洲AV无码网站| 国産精品久久久久久久| 色综合合久久天天综合绕视看| 91精品国产91久久综合| 97久久精品无码一区二区天美| 一本大道久久香蕉成人网| 亚洲人成网亚洲欧洲无码久久| 亚洲伊人久久成综合人影院| 99久久国产宗和精品1上映| 亚洲欧美伊人久久综合一区二区 |