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

            cc

              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              38 隨筆 :: 14 文章 :: 21 評論 :: 0 Trackbacks
            最近在嘗試為軟件增加截取屏幕的功能,為此學(xué)習(xí)了System.Drawing命名空間的Graphics、Image、Bitmap等GDI+類,這些類都很方便使用。但是它們大多都是對原有GDI API的封裝,也增加了一些新的東西;不過封裝得并不徹底,有些功能還是需要調(diào)用GDI API才能實(shí)現(xiàn)。我武斷的認(rèn)為Image、Bitmap、Metafile跟HBITMAP對應(yīng),Graphics跟HDC對應(yīng)。

                在GDI+中,我們可以很方便的用Graphics.FromImage方法來操作Image中的內(nèi)容,并將其保存回圖片文件。那么,我們怎么才能保存Graphics到圖片文件呢?創(chuàng)建一個Bitmap對象,復(fù)制Graphics g1的內(nèi)容到Bitmap的Graphics g2,然后保存Bitmap對象到文件。復(fù)制過程我們必須通過PINVOKE調(diào)用BitBlt函數(shù)來實(shí)現(xiàn)。下面是該函數(shù)的聲明:

            [DllImport("gdi32.dll", CharSet=CharSet.Auto, SetLastError=true, ExactSpelling=true)]
            public static extern int BitBlt(HandleRef hDC, int x, int y, int nWidth, int nHeight, HandleRef hSrcDC, int xSrc, int ySrc, int dwRop);
            參數(shù)中的各種DC可以用Graphics.GetHdc得到;最后一個參數(shù)光柵操作碼很多,截取屏幕用的SRCCOPY值是0xcc0020,完整的光柵操作碼可以查看MSDN的“Ternary Raster Operations”部分。

            示例代碼如下:

            //這里假設(shè)要保存一個窗體的內(nèi)容

            int width=800;     //獲取寬度

            int height=600;     //獲取高度

            const int SRCCOPY=0xcc0020;     //復(fù)制圖塊的光柵操作碼

            Bitmap bmSave=new Bitmap(width,height);     //用于保存圖片的位圖對象

            Graphics gSave=Graphics.FromImage(bmSave);     //創(chuàng)建該位圖的Graphics對象

            HandleRef hDcSave=new HandleRef(null,gSave.GetHdc());     //得到句柄

            Graphics gSrc=formMain.CreateGraphics();     //創(chuàng)建窗體的Graphics對象

            HandleRef hDcSrc=new HandleRef(null,gSrc.GetHdc());

            BitBlt(hDcSave,0,0,width,height,hDcSrc,0,0,SRCCOPY);

            gSrc.ReleaseHdc();

            gSave.ReleaseHdc();

            bmSave.Save(@"C:\test.bmp");

            gSrc.Dispose();

            gSave.Dispose();

            bmSave.Dispose();

             

             關(guān)于Graphics.CopyFromScreen方法

                 該方法在內(nèi)部其實(shí)也使用BitBlt來進(jìn)行圖塊復(fù)制,但是它只是固定的復(fù)制屏幕的內(nèi)容,我們不能指定復(fù)制的源。

            如果您需要截取屏幕的內(nèi)容,可以使用以下代碼:

            int screenWidth=System.Windows.Forms.SystemInformation.VirtualScreen.Width;     //屏幕寬度

            int screenHeight=System.Windows.Forms.SystemInformation.VirtualScreen.Height;     //屏幕高度

            Bitmap bmSave=new Bitmap(screenWidth,screenHeight);

            Graphics g=Graphics.FromImage(bmSave);

            g.CopyFromScreen(0,0,0,0,new Size(screenWidth,screenHeight),CopyPixelOperation.SourceCopy);

            bmSave.Save(@"C:\test.bmp");

            g.Dispose();

            bmSave.Dispose();

             

            如果需要復(fù)制頂層窗體的可見部分,也可以使用Graphics.CopyFromScreen,但是需要用PointToScreen方法先得到屏幕坐標(biāo)。

            如果需要復(fù)制任意的窗體或者控件,先用Control.Handle得到控件句柄,然后再用GetDC()函數(shù)得到HDC,再用BitBlt進(jìn)行圖塊復(fù)制。

            posted on 2009-11-30 17:44 醒目西西 閱讀(2214) 評論(0)  編輯 收藏 引用
            国产精品久久久久久一区二区三区 | 久久婷婷五月综合色奶水99啪| 久久涩综合| 中文字幕久久精品无码| 国产精品一区二区久久| 思思久久好好热精品国产| 久久久久亚洲AV无码专区体验| 99久久婷婷国产综合精品草原| 一级做a爰片久久毛片毛片| 久久无码人妻一区二区三区午夜| 激情综合色综合久久综合| 久久亚洲中文字幕精品有坂深雪| 久久成人18免费网站| 精品久久一区二区三区| 亚洲AV无码1区2区久久| 久久综合五月丁香久久激情| 国产精品久久久久久影院| 99蜜桃臀久久久欧美精品网站| 亚洲欧美精品伊人久久| 国产亚洲综合久久系列| 久久香蕉超碰97国产精品| 国产精品久久久久久久久软件| 青青国产成人久久91网| 精品蜜臀久久久久99网站| 久久强奷乱码老熟女网站| 亚洲国产视频久久| 伊人久久大香线蕉成人| 久久亚洲国产最新网站| 无码8090精品久久一区| 2021国产精品久久精品| 亚洲а∨天堂久久精品| 99久久香蕉国产线看观香| 久久人人青草97香蕉| 一本色道久久88综合日韩精品 | 国产精品久久国产精品99盘 | 综合久久一区二区三区 | 久久久久亚洲AV无码去区首| 久久99精品国产麻豆婷婷| 精品无码人妻久久久久久| 久久久久亚洲精品无码网址| 香蕉久久久久久狠狠色|