- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我开始了解 Visual Studio 2017 中的 OpenGL。按照 www.learnopengl.com 教程并通过了纹理检查点,转换是目前的主要问题。
我使用预先获取的统一位置 ID 将我的模型、 View 和透视矩阵发送到着色器,但是当将矩阵和 vec4(vertex, 1.0f)
vector 相乘时,窗口保持充满清除颜色。
如果我仅将 vec4(vertex, 1.0f)
与模型矩阵相乘,则绘制对象 (cube_flat.obj) 但分布在整个视口(viewport)中,因为未采用透视和 View 考虑在内。这是错误的,但有效。
代码: main.cpp
int main()
{
std::cout << "Application starting...\n" << std::endl;
glm::ivec2 resolution = glm::ivec2(1280, 720);
Window* window = new Window(resolution.x, resolution.y);
SimpleMaterial* simpleMaterial = new SimpleMaterial();
glFrontFace(GL_CCW);
glEnable(GL_DEPTH_TEST);
glEnable(GL_CULL_FACE);
glCullFace(GL_BACK);
glm::mat4 projection = glm::perspective(glm::radians(60.0f), (float)resolution.x / (float)resolution.y, 0.1f, 1000.0f);
glm::mat4 view = glm::inverse(glm::translate(glm::mat4(1.0f), glm::vec3(0.0f, 0.0f, -10.0f)));
glm::mat4 model = glm::translate(glm::mat4(1.0f), glm::vec3(0.0f));
Mesh* mesh = Mesh::load("cube_flat.obj");
// Render loop
while (!window->shouldClose())
{
// Input
window->processInput();
// Rendering commands
glClearColor(0.2f, 0.3f, 0.3f, 1.0f);
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
// Tell OpenGL to use this Shader Program
// Send attribute and uniform data to shader
// Stream vertex, normal and uv data to shader
simpleMaterial->render(projection, view, model, mesh);
// Check & Call events
window->poolEvents();
// Swap buffers
window->swapBuffers();
}
// Delete GLFW data
delete window;
return 0;
}
SimpleMaterial.cpp
SimpleMaterial::SimpleMaterial() : Material("simple")
{
_vertex = _shader->getAttrib("vertex");
_normal = _shader->getAttrib("normal");
_uv = _shader->getAttrib("uv");
_model = _shader->getUniform("model");
_view = _shader->getUniform("view");
_projection = _shader->getUniform("projection");
}
SimpleMaterial::~SimpleMaterial()
{
}
void SimpleMaterial::render(glm::mat4 pProjection, glm::mat4 pView, glm::mat4 pModel, Mesh* pMesh)
{
_shader->use();
glUniformMatrix4fv(_model, 1, GL_FALSE, glm::value_ptr(pModel));
glUniformMatrix4fv(_view, 1, GL_FALSE, glm::value_ptr(pView));
glUniformMatrix4fv(_projection, 1, GL_FALSE, glm::value_ptr(pProjection));
pMesh->draw(_vertex, _normal, _uv);
}
简单.vs
#version 460
in vec3 vertex;
in vec3 normal;
in vec2 uv;
uniform mat4 model;
uniform mat4 view;
uniform mat4 projection;
void main(void) {
gl_Position = projection * view * model * vec4(vertex, 1.0f);
}
简单.fs
#version 460
out vec4 fragment_color;
void main(void) {
fragment_color = vec4(1.0f, 0.0f, 0.0f, 1.0f);
}
由于没有透视和 View 转换,我希望从透视中看到一个立方体,而不是什么都没有/立方体散布在视口(viewport)上。
最佳答案
View 矩阵的设置是“错误的”。视线方向无处可去。
glm::mat4 view = glm::inverse(glm::translate(glm::mat4(1.0f), glm::vec3(0.0f, 0.0f, -10.0f)));
当然, View 矩阵是那个矩阵的逆矩阵,由 View 位置和方向定义。
View 坐标系描述了观察场景的方向和位置。 View 矩阵从世界空间转换到 View (眼睛)空间。
但 OpenGL View 空间坐标系是 Right-handed系统,其中 X 轴指向左侧,Y 轴指向上方。这会导致 Z 轴指向 View 之外(注意 Z 轴是 X 轴和 Y 轴的叉积)。
事实上,这种行为是由投影矩阵引起的,它定义了 View 体积和从 View 空间到裁剪空间(以及进一步标准化的设备空间)的转换。
这意味着 View 位置必须是glm::vec3(0.0f, 0.0f, 10.0f)
:
glm::mat4 view = glm::inverse(glm::translate(glm::mat4(1.0f), glm::vec3(0.0f, 0.0f, 10.0f)));
关于c++ - 为什么 VERTEX 着色器中的矩阵乘法不能正常工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55902379/
我在使用 dijkstra 时遇到了这个错误:TypeError:不可排序的类型:Vertex() dijkstra(g, g.get_vertex('a')) File "C:/Use
我对为自定义类实现迭代器感到困惑。我正在尝试为 std::set 实现一个迭代器,其中我的 Vertex 类声明为: class Vertex{
我正在尝试学习和实现有向图,但在执行程序时遇到了一些困难。 // ADD Function public boolean addVertex(Vertex v) { boolean added
我是 OpenGL 的初学者,我试图每 5 秒将大量“对象”从一个位置移动到另一个位置。如果我在顶点着色器中计算位置,fps 急剧下降,难道不应该在 GPU 上完成这些类型的计算吗? 这是顶点着色器代
我正在学习使用 Boost 图形库。我已经按照此处的说明定义了一个自定义结构来存储有关顶点的信息:Modifying vertex properties in a Boost::Graph . str
我正在尝试使用 boost::adjacency list 和捆绑属性创建一个 TreeMap 来存储每个顶点的父级,我想以一种它们不会失效的方式存储顶点描述符以防万一我删除了一个顶点,所以我使用了
要定义一个从 int 到 struct vertex 的映射,我应该定义 map[int]vertex 还是 map[int]*vertex?首选哪一个? 我扩展了 Chickencha 的代码: p
我创建了一个 VBO(顶点缓冲区对象)和 VAO(顶点数组对象)并执行了以下操作: glBindVertexArray(vao); glBindBuffer(GL_ARRAY_BUFFER, vbo)
我用 HBase 设置了 Titan。 我删除图中的所有顶点 全部删除后显示为空。 gremlin> g.V.count() ==>0 但是如果我重新登录泰坦,那么图中会有一堆空顶点 gremlin>
我正在探索使用计算着色器将骨骼变形应用于网格顶点,而不是使用流输出的顶点着色器。我发现计算着色器的执行速度比顶点着色器慢得多,但在我把它写下来之前,我想确定我没有做错什么。 使用我的 100,000
这里我有一个有向图G,我需要判断是否存在一组顶点不相交的循环,以便每个顶点都属于一个循环。 我不确定这是否可以在多项式时间内完成或者它是否是 NP-Complete?谁能至少指出我正确的方向? 最佳答
要检测一个点是否在多边形中,您可以从该点到无穷远投影一条线,然后查看它与多少个多边形顶点相交......足够简单。我的问题是,如果射线在其中一个点上与多边形相交,则将其视为与两个线段相交,并被视为在多
我在 VehicleHistoryGraph 数据库中创建了一个 Message 类型的顶点,并向其中加载了 50,000 个该类型的顶点。 当我尝试使用此 SQL 语句一次删除所有顶点时 - DEL
所以我正在尝试将 Graph 类作为另一个项目的一部分。顶点存储在由 unordered_map 定义的邻接表中。我正在尝试创建一个散列函数以允许我的 Vertex 类存储在此 map 中,但我不知道
我正在尝试使用 Parma Polyhedra 库 [1]枚举(凸)多面体的顶点,例如,我有一个由四个约束指定的矩形: Constraint_System cs; cs.insert(x >= 0);
我开始了解 Visual Studio 2017 中的 OpenGL。按照 www.learnopengl.com 教程并通过了纹理检查点,转换是目前的主要问题。 我使用预先获取的统一位置 ID 将我
有一个预定的笔记本,它使用 BigQuery 客户端和具有所有者权限的服务帐户。当我手动运行单元格时,它会更新 BQ 表。 BQ 和 Vertex AI 都有一个项目。 我发现了一个类似的问题,但是
我在 R 中使用 Igraph 包,当我通过 V(graph) 访问顶点名称列表时,我得到以下结果: Vertex sequence: [1] "d66cp96igcdnt25brjeics9d11
我有一个 U-SQL 脚本,它在数据湖中存储的多个 JSON 文件上运行,当我针对单个文件运行该脚本时,一切正常,但是打开它以针对我的所有文件运行每次都会出现以下错误,并且作业永远不会超过“准备”阶段
我正在尝试实现 phong 阴影,但无济于事。我正在一点一点地构建着色器(这本身可能是一个问题),但这就是我目前所处的位置。我希望它将我的结果(犹他茶壶)输出为黑色背景上的白色图像。当我从顶点着色器中
我是一名优秀的程序员,十分优秀!