- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想使用现代 OpenGL 渲染我的第一个三角形。 (我正在使用 SFML)我有 2 个类(class):
global
,我用它来初始化全局 sfml 变量等(与我的问题无关)
#ifndef GLOBAL_H
#define GLOBAL_H
#include <SFML/OpenGL.hpp>
#include <SFML/Graphics.hpp>
#include <SFML/Window.hpp>
#include <glm/glm.hpp>
using namespace std;
extern sf::Event Event;
extern sf::Shader defaultShader;
extern sf::ContextSettings settings;
extern sf::Window window;
void initShader();
#endif // GLOBAL_H
和
Model
这会加载一个 obj 文件加载器。我使用 Blender 生成了它。这是它:
#ifndef MODEL_H
#define MODEL_H
#include <GL/glew.h>
#include "global.h"
struct Vertex{
float x,y,z;
Vertex(){};
Vertex(float a,float b,float c){x=a;y=b;z=c;};
};
struct TextureCoordinate{
float x;
float y;
TextureCoordinate(){};
TextureCoordinate(float a,float b){x=a;y=b;};
};
struct FaceTexture{
string texture;
int vertex[3];
};
class Model
{
public:
Model();
vector<Vertex> vertices;
vector<FaceTexture> faces;
vector<TextureCoordinate> textureCoordinates;
vector<Vertex> normals;
void loadModel(const char *fileName);
void setupMesh();
void draw();
private:
GLuint VAO, VBO;
};
#endif // MODEL_H
和 cpp:
#include "Model.h"
Model::Model()
{
}
void Model::loadModel(const char *fileName)
{
int i;
vector<string>line;
vector<string>tmp;
vector<int>V1;vector<int>V2;vector<int>V3;vector<int>T1;vector<int>T2;vector<int>T3;vector<int>N1;vector<int>N2;vector<int>N3;
vector<TextureCoordinate>tc;
vector<Vertex>nc;
ifstream fin(fileName);
char aux[200],matFileName[200];
float v1,v2,v3,t1,t2,t3,n1,n2,n3;
while(!fin.eof())
{
fin.getline(aux,256);
line.push_back(aux);
}
fin.close();
sscanf(line[2].c_str(),"mtllib %s",&matFileName);
fin.open(("models/"+string("matFileName")).c_str());
while(!fin.eof())
{
fin.getline(aux,200);
tmp.push_back(aux);
}
///***///
for(i=3;i<line.size();i++)
{
char matName[100];
if(line[i][0]=='v'&& line[i][1]==' ')
{
Vertex v;
sscanf(line[i].c_str(),"v %f %f %f",&v.x,&v.y,&v.z);
vertices.push_back(v);
continue;
}
if(line[i][0]=='v'&&line[i][1]=='t')
{
TextureCoordinate t;
sscanf(line[i].c_str(),"vt %f %f",&t.x,&t.y);
textureCoordinates.push_back(t);
continue;
}
if(line[i][0]=='v'&&line[i][1]=='n')
{
Vertex v;
sscanf(line[i].c_str(),"vn %f %f %f",&v.x,&v.y,&v.z);
normals.push_back(v);
continue;
}
if(line[i][0]=='u'&&line[i][1]=='s'&&line[i][2]=='e')
{
sscanf(line[i].c_str(),"usemtl %s",&matName);
continue;
}
if(line[i][0]=='f'&&line[i][1]==' ')
{
FaceTexture f;
sscanf(line[i].c_str(),"f %d/%d/%d %d/%d/%d %d/%d/%d ",&v1,&v2,&v3,&t1,&t2,&t3,&n1,&n2,&n3);
f.texture=matName;
faces.push_back(f);
V1.push_back(v1);V2.push_back(v2);V3.push_back(v3);
T1.push_back(t1);T2.push_back(t2);T3.push_back(t3);
N1.push_back(n1);N2.push_back(n2);N3.push_back(n3);
continue;
}
}
tc.resize(vertices.size());
nc.resize(vertices.size());
textureCoordinates.resize(vertices.size());
normals.resize(vertices.size());
for(i=0;i<faces.size();i++)
{
tc[V1[i]]=textureCoordinates[T1[i]];
nc[V1[i]]=normals[N1[i]];
tc[V2[i]]=textureCoordinates[T2[i]];
nc[V2[i]]=normals[N2[i]];
tc[V3[i]]=textureCoordinates[T3[i]];
nc[V3[i]]=normals[N3[i]];
}
for(i=0;i<vertices.size();i++)
{
textureCoordinates[i]=tc[i];
normals[i]=nc[i];
}
for(i=0;i<faces.size();i++)
{
faces[i].vertex[0]=V1[i];
faces[i].vertex[1]=V2[i];
faces[i].vertex[2]=V3[i];
}
setupMesh();
}
void Model::setupMesh()
{
glGenBuffers(1, & VBO);
glBindVertexArray(VAO);
glBindBuffer(GL_ARRAY_BUFFER, VBO);
glBufferData(GL_ARRAY_BUFFER, sizeof(vertices), &vertices[0], GL_STATIC_DRAW);
glVertexAttribPointer(0, 3, GL_FLOAT, GL_FALSE, sizeof(Vertex), (GLvoid*)0);
glEnableVertexAttribArray(0);
glBindBuffer(GL_ARRAY_BUFFER, 0);
glBindVertexArray(0);
}
void Model::draw()
{
glBindVertexArray(VAO);
glDrawArrays(GL_TRIANGLES, 0, 3);
glBindVertexArray(0);
}
顶点着色器:
#version 330 core
layout (location = 0) in vec3 position;
//layout (location = 1) in vec3 color;
out vec3 ourColor;
void main()
{
ourColor=vec3(1,0,0);
gl_Position = vec4(position, 1.0f);
//ourColor = color;
}
片段着色器:
#version 330 core
in vec3 ourColor;
out vec4 color;
void main()
{
color = vec4(ourColor, 1.0f);
}
主要.cpp:
#include <GL/glew.h>
#include <global.h>
#include "Model.h"
using namespace std;
Model model;
int main()
{
glewInit();
initShader();
glEnable(GL_DEPTH_TEST);
model.loadModel("models/1/cube.obj");
sf::Shader::bind(&defaultShader);
while (window.isOpen())
{
glClear(GL_COLOR_BUFFER_BIT|GL_DEPTH_BUFFER_BIT);
while (window.pollEvent(Event))
{
if (Event.type == sf::Event::Closed)
window.close();
}
model.draw();
window.display();
}
return 0;
}
为什么程序显示黑屏?当我使用旧函数时程序运行良好 (glBegin,glEnd
)
最佳答案
您使用变量 VAO
无需初始化它或创建 VAO。你将不得不打电话
glGenVertexArrays(1, &VAO);
获取一个有效的顶点数组。
编辑 1
下一个问题:你推送给VBO的数据大小不对
glBufferData(GL_ARRAY_BUFFER, sizeof(vertices), &vertices[0], GL_STATIC_DRAW);
sizeof(vertices)
在这种情况下等于 sizeof(vector<Vertex>)
这是 vector 对象在内存中的大小,而不是 vector 数据的大小。你想要的是
glBufferData(GL_ARRAY_BUFFER, sizeof(Vertex) * vertices.size(), &vertices[0], GL_STATIC_DRAW);
关于c++ - 使用现代 OpenGL 渲染我的第一个三角形,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33682240/
我有一个库(围绕nlohmann / json封装),可以从JSON反序列化: struct MyStruct { int propertyA; std::string propert
如果 的第 1、3、5、7、9、11、13 或 15 位之一,我希望 var 不等于 FALSE输入已设置。 一个似乎相当普遍的解决方案是: int var = 1 & (input >> 1) |
当我说目标类型时,我的意思是使用接收者变量或参数的类型作为信息来推断我分配给它的部分代码。例如,在 C# 中,您会编写类似这样的内容来传递可为 null 的值或 null (空)如有必要: void
我需要从 native 内存读取/写入一堆结构。我想弄清楚我是否应该为结构对齐而烦恼。这是我编写的用于测试的简单代码。它将压缩结构写入未对齐的指针,然后读回该结构: public static uns
采用以下代码: char chars[4] = {0x5B, 0x5B, 0x5B, 0x5B}; int* b = (int*) &chars[0]; (int*) &chars[0] 值将在循环(
因此,当我发现将整个解决问题的方法颠倒过来时,我正在网上搜索最佳实践,以实现使用多个数据存储的存储库模式。这就是我所拥有的... 我的应用程序是一个BI工具,它从四个数据库中提取数据。由于内部限制,我
我想仅使用现代 OpenGL 技术(即没有即时模式的东西)来设置正交投影。我在网络上看到有关如何处理此问题的相互矛盾的信息。 有些人说调用 glMatrixMode(GL_PROJECTION) 然后
我想知道当前的 cpus 是否避免在其中至少一个为零时将两个数字相乘。谢谢 最佳答案 这取决于 CPU 和(在某些情况下)操作数的类型。 较旧/较简单的 CPU 通常使用如下乘法算法: integer
在精美的 OpenGL 新版本(3.0 和 4.0 以上)中,不推荐使用 gl_Vertex 等内置顶点属性 .实际渲染任何东西的“新方法”是为位置、颜色等指定您自己的顶点属性,然后将这些自定义属性绑
在我的 OpenGL 研究(我认为是 OpenGL 红皮书)中,我遇到了一个关节机器人 ARM 模型的示例,该模型由“上臂”、“下臂”、“手”和五个或更多“手指”。每个部分都应该能够独立移动,但受“关
像 Kaby Lake 这样的现代 CPU 如何处理小分支? (在下面的代码中,它是跳转到标签 LBB1_67)。据我所知,分支不会有害,因为跳转低于 16 字节块大小,即解码窗口的大小。 或者是否有
编辑:此问题假设您启用了发生检查。不是关于 setting Prolog flags . 30 年前有很多关于在安全的情况下自动优化发生检查的论文(大约 90% 的谓词,在典型的代码库中)。提出了不同
现在是 2020 年,在 iOS 终于添加了对 Widget 的支持之后,Widget 再次风靡一时。但是,自 2012 年以来,Android 小部件似乎没有更新。 来自 Android docs
我正在看一些关于算法的讲座,教授用乘法作为如何改进朴素算法的例子...... 它让我意识到乘法并不是那么明显,虽然当我编码时我只是认为它是一个简单的原子操作,乘法需要一个算法来运行,它不像求和数字那样
我们将 PIXI.js 用于内部使用 WebGL 进行渲染的游戏。时不时地,我会偶然发现避免 NPOT 纹理(https://developer.mozilla.org/en-US/docs/Web/
我是一名计算机科学专业的学生,即将毕业。我们现在必须用我们选择的语言编写完整的应用程序。我们选择 Objective-C 因为我们都是 Mac 人。 为了让我们的教授高兴,必须做一些事情:-)一项
我正在编写一个带有 x86 后端的 JIT 编译器,并且正在学习 x86 汇编器和机器代码。大约 20 年前,我使用 ARM 汇编程序,并对这些架构之间的成本模型差异感到惊讶。 具体来说,内存访问和分
如果负载与两个较早的存储重叠(并且负载未完全包含在最旧的存储中),现代 Intel 或 AMD x86 实现能否从两个存储转发以满足负载? 例如,考虑以下序列: mov [rdx + 0], eax
http://www.lighthouse3d.com/opengl/glsl/index.php?ogldir2 报告 OpenGL 上下文中的半向量是“眼睛位置 - 灯光位置”,但接着又说“幸运的
在现代 (GL3.3+) GPU 上使用 GLSL 时,在统一上进行分支的可能成本是多少? 在我的引擎中,我已经达到了拥有大量着色器的程度。我为其中的很多预设了几种不同的质量预设。就目前情况而言,我在
我是一名优秀的程序员,十分优秀!