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

            Jiang's C++ Space

            創作,也是一種學習的過程。

               :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::

            【20060307發表于blog.csdn.net,20090403重編輯】

            1、GDI名字的意義
            GDI Graphic Device Interface,我說不清和GUI有什么區別。可能一種針對設備,一種針對用戶而言吧,反正以后都說GDI,也就是Windows的圖形編程。

            2、設備描述上下文HDC
            Handle Device Context
            這個是關鍵的關鍵,可以理解成畫圖的環境,何謂環境?畫板,紙,筆,尺寸,字體,顏色,區域等。反正包括你能想到的和未能想到的了。要畫出不同的圖形,很大程度上是對HDC的修改。

            3、HDC的創建方式
            WM_PAINT消息來的時候,用:

            hdc = BeginPaint(hwnd, &ps);
            //...
            EndPaint(hwnd, &ps);

            結束后ps區域自動變有效。還有:

            hdc = GetDC(hwnd);
            //...
            ReleaseDC(hwnd, hdc);

            這一對需要調用ValidateRect()函數來使得區域有效。

            還有別的辦法,但不常用,這里略過。不過有一個還是值得一說,那就是取得Window HDC的辦法,用它可以在Windows非客戶區畫圖:

            hdcWindow = GetWindowDC(hwnd);
            //...
            ReleaseDC(hwnd, hdcWindow);


            4、獲取HDC信息
            GetDeviceCaps()
            其中比較重要的指標是:
            HORZRES - horizontal resolution
            VERTRES - vertical resolution
            BITSPIXEL - 色深

            5、保存HDC與還原HDC

            SaveDC(hdc);
            RestoreDC(hdc, 
            -1);


            6、畫圖畫圖!

            //[偽碼]

            // ----- 點 -----
            //畫點
            SetPixel(hdc, x, y, crColor);
            //取點顏色
            crColor = GetPixel(hdc, x, y);

            // ----- 直線 -----
            //最后一參數為NULL表示不返回最后點
            MoveToEx(hdc, x, y, lpPrevPoint);
            //畫線
            LineTo(hdc, x, y);
            //畫多線,不移動當前點
            Polyline(hdc, lpPoint, cPointNum);
            //畫多線,移動當前點
            PolylineTo(hdc, lpPoint, cPointNum);
            //畫多組多線
            PolyPolyline(hdc, lppt, lpNum, cCount);

            //----- 曲線 -----
            //畫橢圓線
            Arc();
            //畫比澤爾曲線,不移動但前點
            PolyBezier();
            //畫比澤爾曲線,移動當前點
            PolyBezierTo();

            //----- 區域 -----
            //畫矩形
            Rectangle();
            //畫橢圓
            Ellipse();
            //畫帶圓角的矩形
            RoundRect();
            //畫扇
            Pie();
            //畫弓
            Chord();


            7、畫筆HPEN(改變線條)
            方法1:
            HPEN hPen = GetStockObject(ARGUMENTS);
            ARGUMENTS為:BLACK_PEN 黑筆WHITE_PEN 白筆

            HPEN hPen = SelectObject(hdc, GetStockObject(WHITE_PEN));
            DelectObject(hPen);

            方法2:
            HPEN hPen = CreatePen(iPenStyle, iWidth, crColor);
            iPenStyle為:PS_SOLID實線PS_DASH虛線PS_DOT點線PS_DASHDOT虛點線PS_DASHDOTDOT虛雙點線PS_NULL空線PS_INSIDEFRAME??

            DeleteObject(SelectObject(hdc, GetStockObject(BLACK_PEN)));

            獲取畫筆信息:

            GetObject(hPen, sizeof(LOGPEN), (LPVOID)&logpen);

            選出HDC中的畫筆:

            hPen = GetCurrentObject(hdc, OBJ_PEN);


            8、背景模式
            改變背景模式,也就是制定虛線間間隙的填充問題了:

            SetBkColor(hdc, crColor);
            SetBkMode(hdc, TRANSPARENT);
            SetBkMode(hdc, OPAQUE);

            有Set嘛,相應地有Get了,這里略過。

            9、疊加模式

            SetROP2(hdc, iDrawMode);
            iDrawMode 
            = GetROP2(hdc);


            10、畫刷HBRUSH(改變填充)
            畫刷能指明區域填充模式。
            方法1:

            HBRUSH hBrush = GetStockObject(GRAY_BRUSH);
            SelectObject(hdc, hBrush);

            方法2:

            HBRUSH hBrush = CreateSolidBrush(crColor);
            HBRUSH hBrush 
            = CreateHatchBrush(iHatchStyle, crColor);


            11、多邊形填充模式及畫多邊形

            SetPolyFillMode(hdc, iMode); //iMode:ALTERNAME WINDING
            Polygon();

            12、區域HRGN(繪畫范圍)

            HRGN hRgn = CreateRectRgn(x1, y1, x2, y2);
            HRGN hRgn 
            = CreateRectRgnIndirect(&rect);
            HRGN hRgn 
            = CreateEllipticRgn(x1, y1, x2, y2);
            HRGN hRgn 
            = CreateEllipticRgnIndirect(&rect);

            區域合并

            CombineRgn(hDestRgn, hSrcRgn1, hSrcRgn2, iCombine); //iCombine: RGN_AND, RGN_OR, RGN_XOR, RGN_DIFF, RGN_COPY

            注意:hDestRgn, hSrcRgn1, hSrcRgn2都必須有效。

            FillRgn(); //填充區域。
            FrameRgn(); //給區域畫邊。
            InvertRgn(); //反轉區域。
            HRGN hRgnPrev = SelectObject(hdc, hRgn); //將區域放置入HDC。

            使區域無效/有效:

            InvalidateRgn(hRgn);
            ValidateRgn(hRgn);
            posted on 2009-04-03 19:02 Jiang Guogang 閱讀(1628) 評論(0)  編輯 收藏 引用 所屬分類: Windows Programming
            亚洲欧美久久久久9999| 久久高清一级毛片| 精品无码久久久久国产| 久久精品草草草| 国产99久久久国产精品小说| 亚洲av日韩精品久久久久久a| 精品国产乱码久久久久久1区2区| 亚洲天堂久久精品| 久久久久亚洲AV片无码下载蜜桃| 久久免费线看线看| 囯产精品久久久久久久久蜜桃| 久久精品国产半推半就| 久久国产精品无| 久久精品无码av| 国产精品视频久久| 久久综合狠狠综合久久综合88| 久久免费视频6| 激情久久久久久久久久| 久久99毛片免费观看不卡 | 久久香蕉超碰97国产精品 | 亚洲欧美成人久久综合中文网 | 久久久久亚洲av无码专区| 欧美激情精品久久久久久久九九九 | 久久久国产精品网站| 久久综合给久久狠狠97色| 精品久久久中文字幕人妻| 亚洲国产小视频精品久久久三级| 国产成人精品久久综合| 99久久精品免费看国产免费| 国产精品久久久久久久久免费| 久久久一本精品99久久精品88| 久久久噜噜噜久久中文字幕色伊伊| 久久99这里只有精品国产| 一本色综合久久| 久久国产色av免费看| 亚洲国产精品无码久久久不卡 | 午夜欧美精品久久久久久久| 东方aⅴ免费观看久久av| 久久天天躁狠狠躁夜夜躁2O2O| 色婷婷综合久久久久中文一区二区| 日韩AV无码久久一区二区 |