当前位置: 首页 > article >正文

SDL2常用函数:SDL_RendererSDL_CreateRendererSDL_RenderCopySDL_RenderPresent

SDL 渲染器系统详解

SDL_Renderer 概述

SDL_Renderer 是 SDL 2.0 引入的核心渲染抽象,它提供了一种高效的、硬件加速的 2D 渲染方式,比传统的表面(Surface)操作更加高效和灵活。

主要函数

1. SDL_CreateRenderer - 创建渲染器

SDL_Renderer* SDL_CreateRenderer(SDL_Window* window,int index,Uint32 flags);

参数说明

  • window: 关联的窗口
  • index: 渲染驱动索引,通常设为-1让SDL自动选择
  • flags: 渲染器标志,常用组合:
    • SDL_RENDERER_ACCELERATED: 使用硬件加速
    • SDL_RENDERER_PRESENTVSYNC: 垂直同步
    • SDL_RENDERER_TARGETTEXTURE: 支持渲染到纹理

返回值:成功返回渲染器指针,失败返回NULL

示例

SDL_Renderer* renderer = SDL_CreateRenderer(window, -1, SDL_RENDERER_ACCELERATED | SDL_RENDERER_PRESENTVSYNC);
if(!renderer) {printf("创建渲染器失败: %s\n", SDL_GetError());
}

2. SDL_RenderCopy - 纹理复制

int SDL_RenderCopy(SDL_Renderer* renderer,SDL_Texture* texture,const SDL_Rect* srcrect,const SDL_Rect* dstrect);

参数说明

  • renderer: 目标渲染器
  • texture: 要复制的纹理
  • srcrect: 源矩形区域(NULL表示整个纹理)
  • dstrect: 目标矩形区域(NULL表示填充整个渲染目标)

返回值:成功返回0,失败返回负数

示例

// 复制整个纹理到整个窗口
SDL_RenderCopy(renderer, texture, NULL, NULL);// 复制纹理的一部分到指定位置
SDL_Rect src = {0, 0, 64, 64}; // 纹理左上角64x64区域
SDL_Rect dst = {100, 100, 128, 128}; // 放大到128x128
SDL_RenderCopy(renderer, texture, &src, &dst);

3. SDL_RenderPresent - 呈现渲染结果

void SDL_RenderPresent(SDL_Renderer* renderer);

功能

  • 将渲染缓冲区的内容显示到屏幕
  • 相当于SDL 1.2中的SDL_Flip
  • 如果创建渲染器时指定了SDL_RENDERER_PRESENTVSYNC,则会等待垂直同步

示例

// 渲染循环中
while(running) {// 清屏SDL_RenderClear(renderer);// 渲染各种对象...SDL_RenderCopy(renderer, texture1, NULL, &rect1);SDL_RenderCopy(renderer, texture2, NULL, &rect2);// 显示到屏幕SDL_RenderPresent(renderer);
}

完整工作流程示例

#include <SDL2/SDL.h>int main(int argc, char* argv[]) {SDL_Init(SDL_INIT_VIDEO);// 创建窗口SDL_Window* window = SDL_CreateWindow("Renderer Demo",SDL_WINDOWPOS_CENTERED,SDL_WINDOWPOS_CENTERED,800, 600,SDL_WINDOW_SHOWN);// 创建渲染器SDL_Renderer* renderer = SDL_CreateRenderer(window, -1,SDL_RENDERER_ACCELERATED |SDL_RENDERER_PRESENTVSYNC);// 加载图像为纹理SDL_Surface* surface = SDL_LoadBMP("image.bmp");SDL_Texture* texture = SDL_CreateTextureFromSurface(renderer, surface);SDL_FreeSurface(surface); // 表面不再需要// 主循环SDL_Event e;int running = 1;while(running) {// 事件处理while(SDL_PollEvent(&e)) {if(e.type == SDL_QUIT) running = 0;}// 清屏(填充黑色)SDL_SetRenderDrawColor(renderer, 0, 0, 0, 255);SDL_RenderClear(renderer);// 渲染纹理SDL_Rect dst = {100, 100, 200, 200};SDL_RenderCopy(renderer, texture, NULL, &dst);// 绘制一个红色矩形SDL_Rect rect = {300, 300, 100, 100};SDL_SetRenderDrawColor(renderer, 255, 0, 0, 255);SDL_RenderFillRect(renderer, &rect);// 显示到屏幕SDL_RenderPresent(renderer);}// 清理资源SDL_DestroyTexture(texture);SDL_DestroyRenderer(renderer);SDL_DestroyWindow(window);SDL_Quit();return 0;
}

高级特性

1. 渲染目标(Render Target)

// 创建可渲染的纹理
SDL_Texture* target = SDL_CreateTexture(renderer,SDL_PIXELFORMAT_RGBA8888,SDL_TEXTUREACCESS_TARGET,512, 512);// 设置渲染目标
SDL_SetRenderTarget(renderer, target);// 渲染到纹理...
SDL_RenderCopy(renderer, otherTexture, NULL, NULL);// 重置渲染目标为默认(窗口)
SDL_SetRenderTarget(renderer, NULL);// 使用渲染好的纹理
SDL_RenderCopy(renderer, target, NULL, &dstRect);

2. 高级混合模式

// 设置混合模式
SDL_SetRenderDrawBlendMode(renderer, SDL_BLENDMODE_BLEND);// 绘制半透明矩形
SDL_SetRenderDrawColor(renderer, 255, 0, 0, 128); // 50%透明红色
SDL_RenderFillRect(renderer, &rect);

3. 纹理旋转和翻转

// 带旋转和翻转的复制
SDL_RenderCopyEx(renderer, texture, &src, &dst,45.0,  // 旋转角度(度)NULL,  // 旋转中心(NULL表示中心)SDL_FLIP_NONE); // 翻转标志

性能优化建议

  1. 纹理重用:避免频繁创建/销毁纹理
  2. 批处理渲染:合并多个RenderCopy调用
  3. 使用纹理图集:将多个小图像合并到一个大纹理
  4. 适当使用渲染目标:预渲染复杂场景
  5. 限制绘制区域:使用SDL_RenderSetViewport
  6. 选择合适的纹理格式:通常RGBA8888最通用
http://www.lryc.cn/news/2391828.html

相关文章:

  • [git]忽略.gitignore文件
  • FEMFAT许可的有效期限
  • Rust使用Cargo构建项目
  • Python训练营打卡Day39
  • UE5蓝图中播放背景音乐和使用代码播放声音
  • AI 赋能数据可视化:漏斗图制作的创新攻略
  • 用 Python 模拟下雨效果
  • C#对象集合去重的一种方式
  • 【LangChain】
  • Java 面试实录:从Spring到微服务的技术探讨
  • 在ROS2(humble)+Gazebo+rqt下,实时显示仿真无人机的相机图像
  • github双重认证怎么做
  • 数据的类型——认识你的数据
  • DeepSeek与AI提示语设计的全面指南
  • Kafka KRaft + SSL + SASL/PLAIN 部署文档
  • Codeforces Round 1027 (Div. 3)
  • 动态内容加载时,爬虫应如何处理?
  • 第五十二节:增强现实基础-简单 AR 应用实现
  • 前端高频面试题1:HTML/CSS/浏览器/计算机网络
  • LLaMaFactory 微调QwenCoder模型
  • Git全流程操作指南
  • 【最新版】Arduino IDE的安装入门Demo
  • 不起火,不爆炸,高速摄像机、数字图像相关DIC技术在动力电池新国标安全性能测试中的应用
  • thinkadmin中使用layui日期选择器,数据库存储时间戳
  • WSL中ubuntu通过Windows带代理访问github
  • RISC-V特权模式及切换
  • Python爬虫实战:研究Tornado框架相关技术
  • 【深度学习】11. Transformer解析: Self-Attention、ELMo、Bert、GPT
  • Ubuntu实现和主机的复制粘贴 VMware-Tools(open-vm-tools)
  • 4060显卡什么水平 4060显卡参数介绍