C/C++ 图形化界面编程入门:EasyX 完全指南
引言在C/C编程学习中我们通常接触的是控制台程序——黑底白字的命令行界面。虽然控制台程序功能强大但界面单调、用户体验较差。那么能否用C/C编写带有图形界面的程序呢答案是肯定的我们可以使用图形库来实现图形化界面。对于Windows平台EasyX是一个非常适合初学者的图形库。它封装了Windows底层绘图API提供了简单易用的接口。今天我将通过一个完整的项目案例全面讲解EasyX图形库的使用方法。第一部分EasyX 简介与环境配置一、什么是EasyXEasyX是一个轻量级的C图形库专门为Windows平台设计常用于教学演示小型游戏开发图形化小程序特点语法简单易于上手封装了Windows GDI无需深入理解底层支持图片、音乐、鼠标键盘交互二、环境配置步骤操作说明1搜索EasyX官网访问 easyx.cn2下载安装包选择对应VS版本3运行安装程序自动配置头文件和库文件注意事项EasyX仅支持Windows平台需要Visual Studio开发环境安装后会自动添加#include easyx.h路径#include easyx.h // 新版推荐 // #include graphics.h // 旧版部分函数名称不同 #pragma comment(lib, winmm.lib) // 多媒体库用于播放音乐第二部分窗口创建与基本绘图一、创建窗口#include easyx.h #include stdio.h int main() { // 创建窗口宽度680高度906样式标志位 initgraph(680, 906); // 程序运行期间保持窗口 while (1); // 或使用 getchar() / system(pause) // 关闭图形窗口 closegraph(); return 0; }initgraph 参数说明参数类型说明第1个int窗口宽度像素第2个int窗口高度像素第3个int样式标志位200表示无边框等通常可省略二、坐标系与坐标EasyX的坐标系原点在窗口左上角示例点(100, 50)距离左边100像素距离顶部50像素三、颜色系统EasyX中的颜色使用32位整数表示格式为ARGB或RGB。预定义颜色常量常量说明RGB值RED红色RGB(255,0,0)GREEN绿色RGB(0,255,0)BLUE蓝色RGB(0,0,255)YELLOW黄色RGB(255,255,0)WHITE白色RGB(255,255,255)BLACK黑色RGB(0,0,0)自定义颜色// RGB方式 COLORREF myColor RGB(0, 238, 60); // 自定义绿色 // 设置画笔颜色 setcolor(myColor);第三部分图形绘制一、基本图形绘制函数函数功能示例circle(x, y, r)画圆circle(100, 100, 50)rectangle(x1, y1, x2, y2)画矩形rectangle(50, 50, 200, 100)line(x1, y1, x2, y2)画直线line(0, 0, 100, 100)fillcircle(x, y, r)填充圆fillcircle(100, 100, 50)fillrectangle(x1, y1, x2, y2)填充矩形fillrectangle(50, 50, 200, 100)二、填充颜色设置// 设置填充颜色 setfillcolor(GREEN); fillcircle(100, 100, 50); // 设置无填充 setfillcolor(0);三、完整绘图示例#include easyx.h int main() { // 创建窗口 initgraph(800, 600); // 设置背景颜色 setbkcolor(WHITE); cleardevice(); // 用背景色清屏 // 画红色填充圆 setfillcolor(RED); fillcircle(200, 200, 80); // 画蓝色矩形 setfillcolor(BLUE); fillrectangle(400, 150, 550, 250); // 画绿色线条 setcolor(GREEN); line(0, 0, 800, 600); // 等待用户按键 system(pause); closegraph(); return 0; }第四部分文字输出一、设置文字样式#include easyx.h int main() { initgraph(800, 600); // 设置文字颜色 settextcolor(RGB(51, 211, 216)); // 设置文字样式 // 参数字号, 字体宽度(0为自适应), 字体名称 settextstyle(72, 0, 华文彩云); // 输出文字参数(x, y, 字符串) outtextxy(200, 150, 你好EasyX); // 也可以使用标准输出 settextstyle(36, 0, 微软雅黑); char str[100] Hello World!; outtextxy(200, 250, str); system(pause); closegraph(); return 0; }二、字体支持EasyX支持Windows系统中安装的任何字体中文华文彩云、微软雅黑、宋体英文Arial、Consolas、Times New Roman第五部分图片处理一、图片加载与显示EasyX使用IMAGE对象来存储图片。#include easyx.h int main() { initgraph(800, 600); // 1. 定义IMAGE对象 IMAGE img; // 2. 从文件加载图片 loadimage(img, background.jpg); // 3. 在指定位置显示图片 putimage(0, 0, img); system(pause); closegraph(); return 0; }二、图片格式支持EasyX支持以下图片格式.jpg/.jpeg.png支持透明通道.bmp.gif仅第一帧三、图片透明绘制技巧// 方法1使用png图片自带透明通道 loadimage(img, character.png); // 透明背景 putimage(100, 100, img); // 方法2使用掩码图技术复杂需要两张图片配合 // 此处不再展开四、图片资源管理注意事项图片文件放在工程目录下.exe同级目录文件名不要包含空格中文文件名可能有编码问题第六部分音乐播放一、音乐播放基础EasyX本身不支持音乐播放需要使用Windows多媒体库winmm.lib。#include easyx.h #include mmsystem.h #pragma comment(lib, winmm.lib) int main() { // 1. 打开音乐文件 mciSendString(open bgm.mp3, NULL, 0, NULL); // 2. 播放音乐 mciSendString(play bgm.mp3, NULL, 0, NULL); // 3. 可选循环播放 // mciSendString(play bgm.mp3 repeat, NULL, 0, NULL); // 4. 暂停 // mciSendString(pause bgm.mp3, NULL, 0, NULL); // 5. 继续播放 // mciSendString(resume bgm.mp3, NULL, 0, NULL); // 6. 关闭文件 // mciSendString(close bgm.mp3, NULL, 0, NULL); // 保持程序运行 getchar(); return 0; }二、mciSendString函数详解// 函数原型 MCIERROR mciSendString( LPCTSTR lpszCommand, // 命令字符串 LPTSTR lpszReturn, // 返回值缓冲区 UINT cchReturn, // 缓冲区大小 HANDLE hwndCallback // 回调窗口句柄 );常用命令命令格式说明openopen 文件名打开文件playplay 文件名播放pausepause 文件名暂停resumeresume 文件名继续播放stopstop 文件名停止closeclose 文件名关闭三、音乐播放注意事项问题解决方案全平台音乐加密使用本地未加密的mp3文件文件名有空格用双引号包裹open \my music.mp3\中文路径使用英文字符串或设置多字节字符集播放器关联将默认打开方式设为Windows Media Player第七部分综合案例——简单的音乐播放器#include easyx.h #include mmsystem.h #pragma comment(lib, winmm.lib) // 播放音乐 void playMusic(const char* filename) { char cmd[256]; sprintf(cmd, open %s, filename); mciSendString(cmd, NULL, 0, NULL); sprintf(cmd, play %s, filename); mciSendString(cmd, NULL, 0, NULL); } // 停止音乐 void stopMusic(const char* filename) { char cmd[256]; sprintf(cmd, stop %s, filename); mciSendString(cmd, NULL, 0, NULL); sprintf(cmd, close %s, filename); mciSendString(cmd, NULL, 0, NULL); } int main() { // 创建窗口 initgraph(400, 300); setbkcolor(WHITE); cleardevice(); // 绘制界面 settextstyle(24, 0, 微软雅黑); outtextxy(50, 50, 音乐播放器); settextstyle(16, 0, 微软雅黑); outtextxy(50, 120, 按 P 播放音乐); outtextxy(50, 150, 按 S 停止音乐); outtextxy(50, 180, 按 ESC 退出); const char* musicFile bgm.mp3; while (1) { // 检测键盘输入 if (GetAsyncKeyState(P) 0x8000) { playMusic(musicFile); outtextxy(200, 250, 播放中...); } if (GetAsyncKeyState(S) 0x8000) { stopMusic(musicFile); outtextxy(200, 250, 已停止 ); } if (GetAsyncKeyState(VK_ESCAPE) 0x8000) { break; } Sleep(100); } stopMusic(musicFile); closegraph(); return 0; }第八部分鼠标与键盘交互一、键盘交互函数说明GetAsyncKeyState(key)检测按键状态_kbhit()检测是否有按键// 检测按键 if (GetAsyncKeyState(A) 0x8000) { // 按下了 A 键 } // 常用虚拟键码 VK_ESCAPE // ESC键 VK_SPACE // 空格键 VK_UP // 上箭头 VK_DOWN // 下箭头 VK_LEFT // 左箭头 VK_RIGHT // 右箭头二、鼠标交互函数说明GetMouseMsg()获取鼠标消息MOUSEMSG鼠标消息结构体#include easyx.h int main() { initgraph(800, 600); while (1) { MOUSEMSG msg GetMouseMsg(); switch (msg.uMsg) { case WM_LBUTTONDOWN: printf(左键点击: (%d, %d)\n, msg.x, msg.y); break; case WM_RBUTTONDOWN: printf(右键点击: (%d, %d)\n, msg.x, msg.y); break; case WM_MOUSEMOVE: // 鼠标移动事件 break; } } closegraph(); return 0; }第九部分完整项目——猜数字游戏#include easyx.h #include stdio.h #include stdlib.h #include time.h int main() { initgraph(500, 400); setbkcolor(WHITE); cleardevice(); // 设置字体 settextstyle(24, 0, 微软雅黑); settextcolor(BLACK); // 游戏初始化 srand(time(NULL)); int target rand() % 100 1; int guess 0; int attempts 0; char input[10] ; outtextxy(150, 50, 猜数字游戏); outtextxy(100, 100, 我已经想好了一个1-100之间的数字); outtextxy(100, 140, 请在下方输入你的猜测); // 输入框 setfillcolor(RGB(240, 240, 240)); fillrectangle(100, 180, 400, 220); setcolor(BLACK); rectangle(100, 180, 400, 220); InputBox(input, 10, 猜数字, 请输入你的猜测1-100, 50); guess atoi(input); while (guess ! target) { attempts; // 清空提示区域 setfillcolor(WHITE); setcolor(WHITE); fillrectangle(100, 250, 450, 300); setcolor(BLACK); if (guess target) { outtextxy(100, 260, 太小了再试试看); } else if (guess target) { outtextxy(100, 260, 太大了再试试看); } InputBox(input, 10, 猜数字, 请输入你的猜测1-100, ); guess atoi(input); } attempts; // 显示胜利信息 setfillcolor(WHITE); fillrectangle(100, 250, 450, 350); char result[100]; sprintf(result, 恭喜你猜了 %d 次猜中了数字 %d, attempts, target); settextcolor(RGB(0, 150, 0)); outtextxy(50, 260, result); outtextxy(150, 310, 按任意键退出...); system(pause nul); closegraph(); return 0; }总结一、EasyX 核心函数速查表类别函数功能窗口initgraph()创建图形窗口closegraph()关闭图形窗口cleardevice()清屏绘图circle()/fillcircle()画圆/填充圆rectangle()/fillrectangle()画矩形/填充矩形line()画直线颜色setcolor()设置画笔颜色setfillcolor()设置填充颜色setbkcolor()设置背景颜色文字settextstyle()设置文字样式settextcolor()设置文字颜色outtextxy()输出文字图片loadimage()加载图片putimage()显示图片输入GetAsyncKeyState()检测按键GetMouseMsg()获取鼠标消息音乐mciSendString()播放音乐二、注意事项项目注意事项窗口使用while(1)保持窗口否则程序立即退出音乐文件名不要有空格路径不要有中文图片放到工程目录下字体使用系统已安装的字体名称EasyX是一个非常适合C/C初学者的图形库它让我们能够快速创建图形化程序而不必深入Windows API的复杂细节。我们还可以用EasyX做更多有趣的事情贪吃蛇、俄罗斯方块等小游戏数据可视化图表简单的绘图工具学生成绩管理系统图形化版学习建议从简单的绘图开始熟悉坐标系和颜色尝试加载图片和播放音乐加入鼠标键盘交互制作可操作的程序综合运用所学知识完成一个小项目