优秀的手机游戏下载!
首页 CreateCompatibleDC()和GetDC()区别在哪里

CreateCompatibleDC()和GetDC()区别在哪里

发布时间:2024-01-11 00:20:34 编辑:手游哥 浏览:693

getdc()该函数检索一指定窗口的客户区域或整个屏幕的显示设备上下文环境的句柄,以后可以在gdi函数中使用该句柄来在设备上下文环境中绘图。

createcompatibledc(pdc)该函数创建一个与指定设备兼容的内存设备上下文环境(dc)。通过getdc()获取的hdc直接与相关设备沟通,而本函数创建的dc,则是与内存中的一个表面相关联。

以上来自百度百科

一般用来做双缓冲,防止屏幕刷新闪烁

如何在Windows窗口中插入图片

在图形处理的时候,为了避免画面闪烁,有时是为了图形叠加,常常需要在内存中开辟一个缓冲区,也就是定义一个临时DC,将所有内容先绘制到这个临时的DC中,绘制完毕后,将临时DC中的数据转移到真正的DC中。为了保证内存中的临时DC与真实的DC一致,就需要

CreateCompatibleDC

函数。

如果没有上面提到的两种需求,那么可以将信息直接输出到真实DC中,也就不需要那个函数了。

如何在MFC中插入位图?

然后显示图片需要写在WM_PAINT消息里:

首选使用函数LoadImage载入位图或图标。 

hb_icon = (HBITMAP)::LoadImage(hInst, _TEXT(“icon.bmp”), IMAGE_BITMAP, 36, 36, LR_CREATEDIBSECTION | LR_DEFAULTSIZE | LR_LOADFROMFILE)

    HDC hMemDC = CreateCompatibleDC(hdc)//创建内存DC

    ::SelectObject(hMemDC, hb_icon)//把位图选进内存DC

    BitBlt(hdc, 0, 0, 35, 35, hMemDC, 0, 0, SRCCOPY)//内存DC映射到屏幕DC

列子

LRESULT CALLBACK WndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)

{

    switch (message)

    {

    case WM_COMMAND:

        {

            HWND wmId = (HWND)LOWORD(lParam)

            switch(LOWORD(wParam)){

            case IDM_ABOUT:

                DialogBox(hInst, MAKEINTRESOURCE(IDD_ABOUTBOX), hWnd, About)

                break

            case IDM_EXIT:

                DestroyWindow(hWnd)

CreateCompatibleDC()和GetDC()区别在哪里

                break

            default:

                return DefWindowProc(hWnd, message, wParam, lParam)

            }

break

        }

    case WM_PAINT:

        {

            PAINTSTRUCT ps

            HDC hdc = BeginPaint(hWnd, &ampps)

        su_icon = (HBITMAP)::LoadImage(hInst, _TEXT(“icon.bmp”), IMAGE_BITMAP, 36, 36, LR_CREATEDIBSECTION | LR_DEFAULTSIZE | LR_LOADFROMFILE)

            //绘制图标

            HDC hMemDC = CreateCompatibleDC(hdc)//创建内存DC

            ::SelectObject(hMemDC, su_icon)//把位图选进内存DC

            BitBlt(hdc, 10, 75, 35, 35, hMemDC, 0, 0, SRCCOPY)//内存DC映射到屏幕DC

            EndPaint(hWnd, &ampps)

            break

        }

    case WM_DESTROY:

        PostQuitMessage(0)

        break

    default:

        return DefWindowProc(hWnd, message, wParam, lParam)

    }

    return 0

}

MFC中有一个位图类CBitmap,你可在资源中导入图片,必须是.bmp格式,然后定义类,最后Bitblt这个函数可以把位图下载到单文档或者其它工程中直接显示图片。\x0d\x0a下面是一份资料,你自己看看吧。\x0d\x0a在Windows中可以将预先准备好的图像复制到显示区域中,这种内存拷贝执行起来是非常快的。在Windows中提供了两种使用图形拷贝的方法:通过设备相关位图(DDB)和设备无关位图(DIB)。\x0d\x0a\x0d\x0aDDB可以用MFC中的CBitmap来表示,而DDB一般是存储在资源文件中,在加载时只需要通过资源ID号就可以将图形装入。BOOL CBitmap::LoadBitmap( UINT nIDResource )可以装入指定DDB,但是在绘制时必须借助另一个和当前绘图DC兼容的内存DC来进行。通过CDC::BitBlt( int x, int y, int nWidth, int nHeight, CDC* pSrcDC, int xSrc, int ySrc, DWORD dwRop )绘制图形,同时指定光栅操作的类型。BitBlt可以将源DC中位图复制到目的DC中,其中前四个参数为目的区域的坐标,接下来是源DC指针,然后是源DC中的起始坐标,由于BitBlt为等比例复制,所以不需要再次指定长宽,(StretchBlt可以进行缩放)最后一个参数为光栅操作的类型,可取以下值: \x0d\x0a\x0d\x0aBLACKNESS 输出区域为黑色 Turns all output black.\x0d\x0a\x0d\x0aDSTINVERT 反色输出区域 Inverts the destination bitmap.\x0d\x0a\x0d\x0aMERGECOPY 在源和目的间使用AND操作 Combines the pattern and the source bitmap using the Boolean AND operator.\x0d\x0a\x0d\x0aMERGEPAINT 在反色后的目的和源间使用OR操作 Combines the inverted source bitmap with the destination bitmap using the Boolean OR operator.\x0d\x0a\x0d\x0aNOTSRCCOPY 将反色后的源拷贝到目的区 Copies the inverted source bitmap to the destination.\x0d\x0a\x0d\x0aPATINVERT 源和目的间进行XOR操作 Combines the destination bitmap with the pattern using the Boolean XOR operator.\x0d\x0a\x0d\x0aSRCAND 源和目的间进行AND操作 Combines pixels of the destination and source bitmaps using the Boolean AND operator.\x0d\x0a\x0d\x0aSRCCOPY 复制源到目的区 Copies the source bitmap to the destination bitmap.\x0d\x0a\x0d\x0aSRCINVERT 源和目的间进行XOR操作 Combines pixels of the destination and source bitmaps using the Boolean XOR operator.\x0d\x0a\x0d\x0aSRCPAINT 源和目的间进行OR操作 Combines pixels of the destination and source bitmaps using the Boolean OR operator.\x0d\x0a\x0d\x0aWHITENESS 输出区域为白色 Turns all output white. \x0d\x0a下面用代码演示这种方法:\x0d\x0aCYourView::OnDraw(CDC* pDC)\x0d\x0a{\x0d\x0a CDC memDC//定义一个兼容DC\x0d\x0a memDC.CreateCompatibleDC(pDC)//创建DC\x0d\x0a CBitmap bmpDraw\x0d\x0a bmpDraw.LoadBitmap(ID_BMP)//装入DDB\x0d\x0a CBitmap* pbmpOld=memDC.SelectObject(&ampbmpDraw)//保存原有DDB,并选入新DDB入DC\x0d\x0a pDC-&gtBitBlt(0,0,20,20,&ampmemDC,0,0,SRCCOPY)//将源DC中(0,0,20,20)复制到目的DC(0,0,20,20)\x0d\x0a pDC-&gtBitBlt(20,20,40,40,&ampmemDC,0,0,SRCAND)//将源DC中(0,0,20,20)和目的DC(20,20,40,40)中区域进行AND操作\x0d\x0a memDC.SelectObject(pbmpOld)//选入原DDB\x0d\x0a}\x0d\x0a\x0d\x0a(图标并不是一个GDI对象,所以不需要选入DC)在MFC中没有一个专门的图标类,因为图标的操作比较简单,使用HICON CWinApp::LoadIcon( UINT nIDResource )或是HICON CWinApp::LoadStandardIcon( LPCTSTR lpszIconName ) 装入后就可以利用BOOL CDC::DrawIcon( int x, int y, HICON hIcon )绘制。由于在图标中可以指定透明区域,所以在某些需要使用非规则图形而且面积不大的时候使用图标会比较简单。下面给出简单的代码: \x0d\x0a\x0d\x0aOnDraw(CDC* pDC)\x0d\x0a{\x0d\x0a HICON hIcon1=AfxGetApp()-&gtLoadIcon(IDI_I1)\x0d\x0a HICON hIcon2=AfxGetApp()-&gtLoadIcon(IDI_I2)\x0d\x0a pDC-&gtDrawIcon(0,0,hIcon1)\x0d\x0a pDC-&gtDrawIcon(0,40,hIcon2)\x0d\x0a DestroyIcon(hIcon1)\x0d\x0a DestroyIcon(hIcon2)\x0d\x0a}\x0d\x0a\x0d\x0a同样在MFC也没有提供一个DIB的类,所以在使用DIB位图时我们需要自己读取位图文件中的头信息,并读入数据,并利用API函数StretchDIBits绘制。位图文件以BITMAPFILEHEADER结构开始,然后是BITMAPINFOHEADER结构和调色版信息和数据,其实位图格式是图形格式中最简单的一种,而且也是Windows可以理解的一种。我不详细讲解DIB位图的结构,提供一个CDib类供大家使用,这个类包含了基本的功能如:Load,Save,Draw。DownLoad

以上就是关于CreateCompatibleDC()和GetDC()区别在哪里全部的内容,如果了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

更多相关资讯

getdc()该函数检索一指定窗口的客户区域或整个屏幕的显示设备上下文环境的句柄,以后可以在gdi函数中使用该句柄来在设备上下文环境中绘图。 createcom…
查看详情
getdc()该函数检索一指定窗口的客户区域或整个屏幕的显示设备上下文环境的句柄,以后可以在gdi函数中使用该句柄来在设备上下文环境中绘图。 createcom…
查看详情
getdc()该函数检索一指定窗口的客户区域或整个屏幕的显示设备上下文环境的句柄,以后可以在gdi函数中使用该句柄来在设备上下文环境中绘图。 createcom…
查看详情
相关资讯
猜你喜欢