GDI是Graphics Device Interface的缩写,含义是图形设备接口,它的主要任务是负责系统与绘图程序之间的信息交换,处理所有Windows程序的图形输出。
在Windows *** 作系统下,绝大多数具备图形界面的应用程序都离不开GDI,我们利用GDI所提供的众多函数就可以方便的在屏幕、打印机及其它输出设备上输出图形,文本等 *** 作。GDI的出现使程序员无需要关心硬件设备及设备驱动,就可以将应用程序的输出转化为硬件设备上的输出,实现了程序开发者与硬件设备的隔离,大大方便了开发工作。
GDI+是Windows XP中的一个子系统,它主要负责在显示屏幕和打印设备输出有关信息,它是一组通过C++类实现的应用程序编程接口。顾名思义,GDI+是以前版本GDI的继承者,出于兼容性考虑,Windows XP仍然支持以前版本的GDI,但是在开发新应用程序的时候,开发人员为了满足图形输出需要应该使用GDI+,因为GDI+对以前的Windows版本中GDI进行了优化,并添加了许多新的功能。
作为图形设备接口的GDI+使得应用程序开发人员在输出屏幕和打印机信息的时候无需考虑具体显示设备的细节,他们只需调用GDI+库输出的类的一些方法即可完成图形 *** 作,真正的绘图工作由这些方法交给特定的设备驱动程序来完成,GDI+使得图形硬件和应用程序相互隔离.从而使开发人员编写设备无关的应用程序变得非常容易。
//GDI Plus #includewin32项目会报错,因为GdiPlus依赖MFC//gdiplus是基于MFC的..需要在MFC工程中使用,或者包含一下MFC的头文件 #pragma comment(lib, "gdiplus.lib") using namespace Gdiplus;
//解决#error: Building MFC application with /MD[d] (CRT dll version) requires MFC shared dll version. //也可以使用mt运行库 #define _AFXDLL //mfc头文件 #include #include初始化Gdiplus
//初始化GDI Plus应用环境 Gdiplus::GdiplusStartupInput gdiplusStartupInput; ULONG_PTR gdiplusToken; GdiplusStartup(&gdiplusToken, &gdiplusStartupInput, NULL);关闭Gdiplus
//释放GDI Plus的应用环境 GdiplusShutdown(gdiplusToken);demo
//解决#error: Building MFC application with /MD[d] (CRT dll version) requires MFC shared dll version. //也可以使用mt运行库 #define _AFXDLL //mfc头文件 #include #include #include "framework.h" #include "GdiPlus.h" //GDI Plus #include//gdiplus是基于MFC的..需要在MFC工程中使用,或者包含一下MFC的头文件 #pragma comment(lib, "gdiplus.lib") using namespace Gdiplus; #define MAX_LOADSTRING 100 // 全局变量: HINSTANCE hInst; // 当前实例 WCHAR szTitle[MAX_LOADSTRING]; // 标题栏文本 WCHAR szWindowClass[MAX_LOADSTRING]; // 主窗口类名 // 此代码模块中包含的函数的前向声明: ATOM MyRegisterClass(HINSTANCE hInstance); BOOL InitInstance(HINSTANCE, int); LRESULT CALLBACK WndProc(HWND, UINT, WPARAM, LPARAM); int APIENTRY wWinMain(_In_ HINSTANCE hInstance, _In_opt_ HINSTANCE hPrevInstance, _In_ LPWSTR lpCmdLine, _In_ int nCmdShow) { UNREFERENCED_PARAMETER(hPrevInstance); UNREFERENCED_PARAMETER(lpCmdLine); //初始化GDI Plus应用环境 Gdiplus::GdiplusStartupInput gdiplusStartupInput; ULONG_PTR gdiplusToken; GdiplusStartup(&gdiplusToken, &gdiplusStartupInput, NULL); // 初始化全局字符串 LoadStringW(hInstance, IDS_APP_TITLE, szTitle, MAX_LOADSTRING); LoadStringW(hInstance, IDC_GDIPLUS, szWindowClass, MAX_LOADSTRING); MyRegisterClass(hInstance); // 执行应用程序初始化: if (!InitInstance (hInstance, nCmdShow)) { return FALSE; } HACCEL hAccelTable = LoadAccelerators(hInstance, MAKEINTRESOURCE(IDC_GDIPLUS)); MSG msg; // 主消息循环: while (GetMessage(&msg, nullptr, 0, 0)) { if (!TranslateAccelerator(msg.hwnd, hAccelTable, &msg)) { TranslateMessage(&msg); DispatchMessage(&msg); } } //释放GDI Plus的应用环境 GdiplusShutdown(gdiplusToken); return (int) msg.wParam; } // // 函数: MyRegisterClass() // // 目标: 注册窗口类。 // ATOM MyRegisterClass(HINSTANCE hInstance) { WNDCLASSEXW wcex; wcex.cbSize = sizeof(WNDCLASSEX); wcex.style = CS_HREDRAW | CS_VREDRAW; wcex.lpfnWndProc = WndProc; wcex.cbClsExtra = 0; wcex.cbWndExtra = 0; wcex.hInstance = hInstance; wcex.hIcon = LoadIcon(hInstance, MAKEINTRESOURCE(IDI_GDIPLUS)); wcex.hCursor = LoadCursor(nullptr, IDC_ARROW); wcex.hbrBackground = (HBRUSH)(COLOR_WINDOW+1); wcex.lpszMenuName = MAKEINTRESOURCEW(IDC_GDIPLUS); wcex.lpszClassName = szWindowClass; wcex.hIconSm = LoadIcon(wcex.hInstance, MAKEINTRESOURCE(IDI_SMALL)); return RegisterClassExW(&wcex); } // // 函数: InitInstance(HINSTANCE, int) // // 目标: 保存实例句柄并创建主窗口 // // 注释: // // 在此函数中,我们在全局变量中保存实例句柄并 // 创建和显示主程序窗口。 // BOOL InitInstance(HINSTANCE hInstance, int nCmdShow) { hInst = hInstance; // 将实例句柄存储在全局变量中 HWND hWnd = CreateWindowW(szWindowClass, szTitle, WS_OVERLAPPEDWINDOW, CW_USEDEFAULT, 0, CW_USEDEFAULT, 0, nullptr, nullptr, hInstance, nullptr); if (!hWnd) { return FALSE; } ShowWindow(hWnd, nCmdShow); UpdateWindow(hWnd); return TRUE; } void OnPaint(HWND hwnd, HDC hdc) { //加载背景图片,并根据背景图片的大小调整窗口大小 Gdiplus::Image bkImage(_TEXT("H:/植物大战僵尸素材/interface/background1.jpg")); //加载图片的类,jpg,png这样的压缩图片 int nWidth = bkImage.GetWidth(); int nHeight = bkImage.GetHeight(); ::SetWindowPos(hwnd, HWND_TOP, 0, 0, nWidth, nHeight, SWP_NOMOVE | SWP_SHOWWINDOW); Gdiplus::Graphics graphics(hdc); graphics.DrawImage(&bkImage, 0, 0, nWidth, nHeight); //画笔绘制 Gdiplus::Pen pen(0xffff0000, 1.0f); //ARGB格式 graphics.DrawLine(&pen, 10, 10, 20, 20); graphics.DrawEllipse(&pen, 30, 30, 100, 80); graphics.DrawRectangle(&pen, 300, 300, 40, 50); //画刷填充 Gdiplus::SolidBrush brush(Gdiplus::Color(255, 0, 0, 255)); graphics.FillRectangle(&brush, 400, 100, 40, 80); } LRESULT CALLBACK WndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam) { switch (message) { case WM_PAINT: { PAINTSTRUCT ps; HDC hdc = BeginPaint(hWnd, &ps); OnPaint(hWnd, hdc); EndPaint(hWnd, &ps); } break; case WM_DESTROY: PostQuitMessage(0); break; default: return DefWindowProc(hWnd, message, wParam, lParam); } return 0; }
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)