SDL2的学习之路<三>显示文字

article/2025/10/11 0:15:07

前言

上节介绍了怎么利用SDL接口去显示图片,这节主要介绍怎么去显示文本信息。


SDL2展示文字需要在官网下载SDL2_ttf的扩展库。这个第一节已经讲过了。
使用时需要先初始化库,使用结束时释放库资源。
TTF_Init(); //初始化库

TTF_Quit(); //释放

显示文字的基本步骤:
1、打开字体
首先需要有字体库,这个可以在windows系统里找到很多的字体库,比如这里用的就是msyh.ttf这个字体库。
API:*TF_Font * SDLCALL TTF_OpenFont(const char file, int ptsize);
第一个参数是字体所在的路径,第二个参数是字体大小。成功打开会返回一个字体结构指针。
API: **SDL_Surface * SDLCALL TTF_RenderUTF8_Blended(TTF_Font font, const char text, SDL_Color fg);
根据字体,文字和颜色创建surface表面。这里注意这个地方是有三个api可以来创建surface表面的,这里用的是带utf8的,如果传入中文的编码不是utf8格式的会导致显示的字体乱码问题,c++的转码确实是非常麻烦的一件事情,如果象要方便显示中文,可以用SDL_Surface * SDLCALL TTF_RenderUNICODE_Blended(TTF_Font *font,const Uint16 *text, SDL_Color fg);这里传入的文字用wstring就好了。
API:SDL_Texture * SDLCALL SDL_CreateTextureFromSurface(SDL_Renderer * renderer, SDL_Surface * surface);
根据surface表面创建纹理。SDL的展示是基于纹理的,需要将上面创建的表面转化成纹理才能显示。
API:**int SDLCALL TTF_SizeUTF8(TTF_Font *font, const char *text, int w, int h);
这个是根据文字和字体来计算文字的宽和高的。当然也不是必须的,因为后面展示的时候也是跟上节显示图片一样调用显示纹理的接口,那个地方需要传入纹理的高度和宽度,当然也可以根据需求自己在那里更改纹理大小,只是不建议那么做,毕竟会导致纹理拉伸变形。需要注意的是,如果上面创建表面的时候是用的unicode接口,这个地方就需要调用TTF_SizeUNICODE去计算字体的大小。
API:*int SDLCALL TTF_GetFontStyle(const TTF_Font font);
获取字体当前的风格类型。
#define TTF_STYLE_NORMAL 0x00 // 正常。
#define TTF_STYLE_BOLD 0x01 // 加粗
#define TTF_STYLE_ITALIC 0x02 // 倾斜
#define TTF_STYLE_UNDERLINE 0x04 // 下划线
#define TTF_STYLE_STRIKETHROUGH 0x08 // 删除线
API:*void SDLCALL TTF_SetFontStyle(TTF_Font font, int style);
设置字体风格。
主要就是上面几个函数,后面就是跟上节显示纹理一样去展示纹理了。

代码展示:

bool displayText(std::string text, std::string font, int height, SDL_Point point)
{TTF_Font * pFont = TTF_OpenFont(font.c_str(), height);if (pFont == nullptr) return false;SDL_Color color = { 255,255,255,255 };SDL_Surface * surface = TTF_RenderUTF8_Blended(pFont, text.c_str(), color);SDL_Texture * texture = SDL_CreateTextureFromSurface(m_render, surface);int w = 0, h = 0;TTF_SizeUTF8(pFont, text.c_str(), &w, &h);SDL_Rect des = { point.x, point.y, w, h };SDL_RenderCopy(m_render, texture, NULL, &des);SDL_FreeSurface(surface);SDL_DestroyTexture(texture);return true;
}

这里的m_render是上节创建的渲染指针。注意在使用前记得初始化字体库。
下面是我自己写了个推箱子的游戏,感兴趣的可以交流下
效果展示:

在这里插入图片描述


http://chatgpt.dhexx.cn/article/NaEYWKCX.shtml

相关文章

VS2019配置SDL2库

“SDL(Simple DirectMedia Layer)是一套开放源代码的跨平台多媒体开发库,使用C语言写成。SDL提供了数种控制图像、声音、输出入的函数,让开发者只要用相同或是相似的代码就可以开发出跨多个平台(Linux、Windows、MacOS…

SDL系列教程(一):SDL简介

SDL教程(一) 作者:akinggw 在阔别半年后,我又回来了。这次回来,首先要向大家问声好,然后继续我们的游戏开发之旅。在以前的日子里,我主要在翻译一些游戏开发方面的文章,而现在&…

SDL2源代码分析1:初始化(SDL_Init())

SDL源代码分析系列文章列表: SDL2源代码分析1:初始化(SDL_Init()) SDL2源代码分析2:窗口(SDL_Window) SDL2源代码分析3:渲染器(SDL_Renderer) SDL2源代码…

SDL2入门教程(01_hello_SDL)

注: 本教程翻译自 lazyfoo的教程,原网址戳这里。翻译目的为鼓励自己坚持下去,可能语言不准确,仅供参考。 Hello SDL: 你的第一个图形窗口 这一篇教程包含最主要也最基础的一步——弹出一个窗口(Window) …

SDL2源代码分析2:窗口(SDL_Window)

SDL源代码分析系列文章列表: SDL2源代码分析1:初始化(SDL_Init()) SDL2源代码分析2:窗口(SDL_Window) SDL2源代码分析3:渲染器(SDL_Renderer) SDL2源代码…

SDL2使用简介

转自我的Gitee项目 SDL2使用简介 SDL2使用简介开发环境搭建WindowsVisual StudioCode::BlocksDev-Cpp CMake(CLion)问题总结 SDL2库使用介绍初始化创建窗口绘制矩形刷新屏幕读取输入直接扫描键盘读取系统事件 实例 绘制图片 SDL2使用简介 开发环境搭建 Windows Visual Stud…

SDL2 简明教程(二):创建一个空的窗口

系列文章目录 SDL2 简明教程(一):使用 Cmake 和 Conan 构建 SDL2 编程环境 SDL2 简明教程(二):创建一个空的窗口 文章目录 系列文章目录创建空窗口总结 创建空窗口 在上一篇文章中,我们了解…

强大无比的嵌入式多媒体开发神器:SDL2

SDL 是什么? SDL(Simple DirectMedia Layer)是一套开源的跨平台多媒体开发库,使用 C 语言写成。 它提供了绘制图像、播放声音、获取键盘输入等相关的 API,大大降低多媒体应用开发难度的同时,也让开发者只要…

SDL2 简明教程(五):OpenGL 绘制

系列文章目录 SDL2 简明教程(一):使用 Cmake 和 Conan 构建 SDL2 编程环境 SDL2 简明教程(二):创建一个空的窗口 SDL2 简明教程(三):显示图片 SDL2 简明教程&#xf…

SDL —— SDL2及API简介

SDL2框架 SDL( Simple DirectMedia Layer) 是一套开放源代码的跨平台多媒体开发库, 使用 C 语 言写成。 SDL 提供了数种控制图像、 声音、 输出入的函数, 让开发者只要用相同或是相似的 代码就可以开发出跨多个平台( L…

SDL2学习笔记(一):SDL2初步

一、Windows系统下的安装 MinGW ①安装MinGW并配置好环境变量; ②官网下载SDL for MinGW; ③将解压文件中的 .\i686-w64-mingw32\include\SDL2 复制到 .\MinGW\include ; //有的设备需要用x86_64-w64-mingw32中的文件,下同 ④将解…

ISCC2021—ISCC客服一号冲冲冲(二)

ISCC客服一号冲冲冲(二) 呦,又见面了,狗子 打开链接,发现登录接口似乎是个图片截了一块啊,把图片下载下来,lsp隐写发现源代码,同时php弱比较登录页面 (都看到这里啦&a…

ISCC2021——web部分

练武 ISCC客服冲冲冲(一) 该题目需要左边的客服票数高于右边的 我会的就两种方法,毕竟是废物嘛,允许 1、 把左右按钮换一下 然后就 2、在控制台输入 回车,走你 你涨啊,涨啊,接着涨啊…没吃…

ISCC,Misc:隐秘的信息

解码得到解压密码 解压出一张图,低位时头部显示有一串字符被 f f f f f 包裹,将可疑的字符单独拿出来 由于单个字符可能是由二进制错位导致的 fffffa4a9a1a1bd9 9b7a1a9ba34b127a 0b8abbc20b7a2b7a 2b524b43e9f8007f fffc7e3fe00fff00 71fffffffffffff…

ISCC理论题小解

B 域、工作组和家庭组表示在网络中组织计算机的不同方法。它们之间的主要区别是对网络中的计算机和其他资源的管理方式。 网络中运行 Windows 的计算机必须属于某个工作组或某个域。家庭网络中运行 Windows 的计算机也可以属于某个家庭组,但这不是必需的。 家庭网络…

ISCC web4

ISCC web4 打开网页看到: 代码审计。。。。。。。。。 一开始以为是sha256解密,结果半天搞不出来 后来才知道parse_url函数存在变量覆盖漏洞 因为要存在action参数,传入actionauth key也要传入key0 由于key是要被sha256加密的 传入一个has…

ISCC2022 擂台misc

文章目录 666扫!弱雪真扫黑暗森林PNGstego这是压缩包吗?小 数 学习了 P.S:抬杠就是你对 666 考查知识点:伪加密、猜谜的steghide弱口令爆破、流量分析、gif帧、键盘密码、AES 下载下来是一个压缩包,但是图片显示需要密码&#xf…

ISCC-2022 部分wp

目录 Web冬奥会解题步骤详细描述解题收获 Easy_sql解题步骤详细描述解题收获 Pop2022解题步骤详细描述解题收获 findme解题步骤详细描述 爱国敬业好青年-2解题步骤详细描述解题收获 这是一道代码审计题 Misc单板小将苏翊鸣解题步骤详细描述解题收获 2022冬奥会解题步骤详细描述…

ISCC——部分题wp

练武场 WEB: ISCC客服冲冲冲(一) 知识点: js解密 解题思路: 1.打开后出现投票的页面 2.查看源码 发现可疑的function.js 3.function.js,js加密 var _0xodqjsjiami.com.v6,_0x3e40[_0xodq,\x77\x35\x4c\x…

ISCC ISCC客服一号冲冲冲(二)

这个题其实是转自Bugku的Login4 (CBC字节翻转攻击) 题目有提示密码就是web1 的flag 然后登入 这里有回显,然后我们换一下 下面cookie里的iv和cipher看着就像CBC加密的方式 利用的就是CBC解密的特点:前16个密文字符用来解密接下来的一组16个密文&#…