IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> [C++] [OpenGL] 帧缓冲2 -> 正文阅读

[C++知识库][C++] [OpenGL] 帧缓冲2

这个应该是多重渲染目标(MRT)吧,反正就这么命名了
r,g,b,d依次是red,green,blue,depth(其实是距离)
除100是因为太亮了,很容易就会达到1,而100是我视体的远平面
话说纹理竟然是反的

片段着色器代码

#version 330 core

in vec3 v_position;
in vec3 v_normal;
in vec3 v_normal2;
in vec2 v_texCoord;

layout(location = 0)out vec4 o_red;
layout(location = 1)out vec4 o_green;
layout(location = 2)out vec4 o_blue;
layout(location = 3)out vec4 o_depth;

uniform vec3 u_cameraposition;
uniform sampler2D s_sampler;

vec4 lighting()
{
	vec3 light_direction = normalize(v_position - u_cameraposition);
	vec3 view_direction = normalize(v_position - u_cameraposition);

	float ambient = 0.1;

	float diffuse = max(dot(v_normal, -light_direction), 0.0);
	float diffuse2 = max(dot(v_normal2, -light_direction), 0.0);

	vec3 reflect_direction = reflect(light_direction, v_normal);
	float specular = pow(max(dot(-view_direction, reflect_direction), 0.0), 32.0);
	vec3 reflect_direction2 = reflect(light_direction, v_normal2);
	float specular2 = pow(max(dot(-view_direction, reflect_direction2), 0.0), 32.0);

	return (ambient + diffuse + specular + diffuse2 + specular2) * texture(s_sampler,v_texCoord);
}

void main()
{
	vec4 finalColor = lighting();
	vec3 distance = (v_position - u_cameraposition) / 100.0;
	
	o_red = vec4(finalColor.r,0.0,0.0,1.0);
	o_green = vec4(0.0,finalColor.g,0.0,1.0);
	o_blue = vec4(0.0,0.0,finalColor.b,1.0);
	o_depth = vec4(distance.x,distance.y,distance.z,1.0);
}

宿主语言代码

初始化帧缓冲
p.s.其实我觉得RBO不需要

	GLFWmonitor* monitor = glfwGetPrimaryMonitor();
	const GLFWvidmode* videomode = glfwGetVideoMode(monitor);
	int width = videomode->width;
	int height = videomode->height;

	GLuint fbo;
	GLuint rbo;
	GLuint r_texture, g_texture, b_texture, d_texture;

	glGenFramebuffers(1, &fbo);
	glBindFramebuffer(GL_FRAMEBUFFER, fbo);

	glGenRenderbuffers(1, &rbo);
	glBindRenderbuffer(GL_RENDERBUFFER, rbo);
	glRenderbufferStorage(GL_RENDERBUFFER, GL_DEPTH24_STENCIL8, width, height);
	glBindRenderbuffer(GL_RENDERBUFFER, 0);

	glGenTextures(1, &r_texture);
	glBindTexture(GL_TEXTURE_2D, r_texture);
	glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, width, height, 0, GL_RGB, GL_UNSIGNED_BYTE, nullptr);
	glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
	glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
	glBindTexture(GL_TEXTURE_2D, 0);

	glGenTextures(1, &g_texture);
	glBindTexture(GL_TEXTURE_2D, g_texture);
	glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, width, height, 0, GL_RGB, GL_UNSIGNED_BYTE, nullptr);
	glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
	glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
	glBindTexture(GL_TEXTURE_2D, 0);

	glGenTextures(1, &b_texture);
	glBindTexture(GL_TEXTURE_2D, b_texture);
	glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, width, height, 0, GL_RGB, GL_UNSIGNED_BYTE, nullptr);
	glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
	glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
	glBindTexture(GL_TEXTURE_2D, 0);

	glGenTextures(1, &d_texture);
	glBindTexture(GL_TEXTURE_2D, d_texture);
	glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, width, height, 0, GL_RGB, GL_UNSIGNED_BYTE, nullptr);
	glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
	glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
	glBindTexture(GL_TEXTURE_2D, 0);

	glFramebufferTexture2D(GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, GL_TEXTURE_2D, r_texture, 0);
	glFramebufferTexture2D(GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT1, GL_TEXTURE_2D, g_texture, 0);
	glFramebufferTexture2D(GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT2, GL_TEXTURE_2D, b_texture, 0);
	glFramebufferTexture2D(GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT3, GL_TEXTURE_2D, d_texture, 0);

	GLuint attachments[4] = { GL_COLOR_ATTACHMENT0, GL_COLOR_ATTACHMENT1, GL_COLOR_ATTACHMENT2, GL_COLOR_ATTACHMENT3 };
	glDrawBuffers(4, attachments);
	glFramebufferRenderbuffer(GL_FRAMEBUFFER, GL_DEPTH_STENCIL_ATTACHMENT, GL_RENDERBUFFER, rbo);
	
	if (glCheckFramebufferStatus(GL_FRAMEBUFFER) != GL_FRAMEBUFFER_COMPLETE)
	{
		std::cout << "Framebuffer is not complete." << std::endl;
		return -1;
	}

	glBindFramebuffer(GL_FRAMEBUFFER, 0);

渲染代码

		glBindFramebuffer(GL_FRAMEBUFFER, fbo);
		glClearColor(0.1f, 0.1f, 0.1f, 1.0f);
		glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
		data->program_m.useProgram();
		data->program_m.setUniform("u_projection", data->camera.getProjectionMatrix());
		data->program_m.setUniform("u_view", data->camera.getViewMatrix());
		data->program_m.setUniform("u_cameraposition", data->camera.getPosition());
		glActiveTexture(GL_TEXTURE0);
		data->texture.bindTexture();
		data->model.render(data->program_m);

		glBindFramebuffer(GL_FRAMEBUFFER, 0);
		glClearColor(0.1f, 0.1f, 0.1f, 1.0f);
		glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
		data->program_t.useProgram();
		data->program_t.setUniform("u_projection", glm::mat4(1.0f));
		data->program_t.setUniform("u_view", glm::mat4(1.0f));
		data->program_t.setUniform("u_cameraposition", data->camera.getPosition());

		data->target.setPosition(target_pos_r);
		data->program_t.setUniform("u_model", data->target.getModelMatrix());
		glBindTexture(GL_TEXTURE_2D, r_texture);
		data->target.render(data->program_t);

		data->target.setPosition(target_pos_g);
		data->program_t.setUniform("u_model", data->target.getModelMatrix());
		glBindTexture(GL_TEXTURE_2D, g_texture);
		data->target.render(data->program_t);

		data->target.setPosition(target_pos_b);
		data->program_t.setUniform("u_model", data->target.getModelMatrix());
		glBindTexture(GL_TEXTURE_2D, b_texture);
		data->target.render(data->program_t);

		data->target.setPosition(target_pos_d);
		data->program_t.setUniform("u_model", data->target.getModelMatrix());
		glBindTexture(GL_TEXTURE_2D, d_texture);
		data->target.render(data->program_t);

		glBindTexture(GL_TEXTURE_2D, 0);

最后删除缓冲区

	glDeleteFramebuffers(1, &fbo);
	glDeleteRenderbuffers(1, &rbo);
	glDeleteTextures(1, &r_texture);
	glDeleteTextures(1, &g_texture);
	glDeleteTextures(1, &b_texture);
	glDeleteTextures(1, &d_texture);

运行结果

懒得放图:)

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2022-05-05 10:59:30  更:2022-05-05 11:03:30 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 3:55:50-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码