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

            搜索

            •  

            積分與排名

            • 積分 - 177261
            • 排名 - 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 閱讀(3976) 評論(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精品国产99久久6| 国产精品99久久久久久宅男小说| 久久99久久99小草精品免视看| 一本久久a久久精品综合夜夜| 久久亚洲视频| 天天综合久久久网| 亚洲中文字幕久久精品无码APP| 久久精品国产只有精品2020| 久久毛片一区二区| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 精品一二三区久久aaa片| 91精品国产高清久久久久久io| 久久免费99精品国产自在现线| 日韩AV无码久久一区二区| 欧美精品福利视频一区二区三区久久久精品| 国产毛片欧美毛片久久久| 精品久久人人妻人人做精品 | 91精品国产91久久久久福利| 欧美成人免费观看久久| 久久嫩草影院免费看夜色| 久久婷婷久久一区二区三区 | 精品久久久久久无码人妻蜜桃| 久久国产精品99精品国产| 精品国产青草久久久久福利| 亚洲午夜精品久久久久久app| 国产精品日韩深夜福利久久| 99久久免费只有精品国产| 老司机国内精品久久久久| 久久线看观看精品香蕉国产| 久久不见久久见免费视频7| 久久精品人成免费| 国产精品久久久久9999| 久久99国产精品99久久| 99久久亚洲综合精品网站| 2021国产成人精品久久| 狠狠人妻久久久久久综合| 精品久久久久久99人妻| 模特私拍国产精品久久| 久久婷婷五月综合色奶水99啪 | 无码精品久久久久久人妻中字| 亚洲AV无码1区2区久久|