- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在努力让立方体在 opengl 中呈现。当我将已经计算出的 MVP 传递给顶点着色器时,它工作正常,但是当我传递模型、 View 和投影然后在顶点着色器中进行计算时,它不显示立方体。当我将顶点着色器的统一类型更改为 mat4 而不是 vec4 时,我也会收到错误 1282。
main.cpp
#include <iostream>
#include <GL/glew.h>
#include <GLFW/glfw3.h>
#include <glm/glm.hpp>
#include <glm/gtc/type_ptr.hpp>
#include <glm/gtc/matrix_transform.hpp>
#include <glm/gtx/transform.hpp>
#include <fstream>
#include <stdlib.h>
#include <vector>
GLuint getShader(const char* shaderName, GLenum shaderType) {
std::cout << "Making shader " << shaderName << std::endl;
/* Read file */
std::cout << "Reading shader file" << std::endl;
std::ifstream shaderFile;
shaderFile.open(shaderName, std::ios_base::in);
if (!shaderFile) {
std::cout << shaderName << " not found" << std::endl;
return 0;
}
std::string line;
std::string shaderData;
while (std::getline(shaderFile, line)) {
shaderData += line + "\n";
}
shaderFile.close();
/* Create shader */
std::cout << "Compiling shader" << std::endl;
GLuint shader = glCreateShader(shaderType);
if (shader == 0) {
std::cout << "Failed to create shader for " << shaderName << std::endl;
return 0;
}
const char *shaderStr = shaderData.c_str();
glShaderSource(shader, 1, &shaderStr, nullptr);
glCompileShader(shader);
/* Check compile status */
GLint status;
glGetShaderiv(shader, GL_COMPILE_STATUS, &status);
if (status != GL_TRUE) {
GLint logLength;
glGetShaderiv(shader, GL_INFO_LOG_LENGTH, &logLength);
GLchar *infoLog = new GLchar[logLength + 1];
glGetShaderInfoLog(shader, logLength, nullptr, infoLog);
std::cout << shaderName << " failed to compile: " << infoLog << std::endl;
return 0;
}
GLenum error = glGetError();
if(error != GL_NO_ERROR) {
std::cout << "Failed making shader program, error " << error << ": " << glewGetErrorString(error) << std::endl;
return 0;
}
return shader;
}
int end(const char* message) {
glfwTerminate();
if(message != nullptr) {
std::cout << message << std::endl;
system("PAUSE");
}
return -1;
}
struct Shader {
const char* file;
GLenum type;
Shader(const char* file, GLenum type) {
this->type = type;
this->file = file;
}
};
GLuint getShader(Shader& shader) {
return getShader(shader.file, shader.type);
}
GLuint getShaderProgram(std::initializer_list<Shader> shaders, std::initializer_list<const char*> binds) {
/* Create the shader program */
GLuint shaderProgram = glCreateProgram();
GLenum error = glGetError();
if (shaderProgram == 0) {
std::cout << "Failed to create shader program" << std::endl;
return 0;
}
else if (glIsProgram(shaderProgram) != GL_TRUE) {
std::cout << "Failed to create shader program" << std::endl;
return 0;
}
else if(error != GL_NO_ERROR) {
std::cout << "Failed creating shader program, error " << error << ": " << glewGetErrorString(error) << std::endl;
return 0;
}
/* Compile & attach the shaders */
for(Shader shader : shaders) {
GLuint glShader = getShader(shader);
if (glShader == 0) {
std::cout << "Failed to load shader " << shader.file << std::endl;
return 0;
}
std::cout << "Attaching shader " << shader.file << std::endl;
glAttachShader(shaderProgram, glShader);
glDeleteShader(glShader);
error = glGetError();
if(error != GL_NO_ERROR) {
std::cout << "Failed attaching shader, error " << error << ": " << glewGetErrorString(error) << std::endl;
return 0;
}
}
/* Bind */
for(const char* bind : binds) {
std::cout << "Binding data location " << bind << std::endl;
glBindFragDataLocation(shaderProgram, 0, bind);
error = glGetError();
if(error != GL_NO_ERROR) {
std::cout << "Failed binding data location, error " << error << ": " << glewGetErrorString(error) << std::endl;
return 0;
}
}
/* Link to opengl */
glLinkProgram(shaderProgram);
error = glGetError();
if(error != GL_NO_ERROR) {
std::cout << "Failed linking shader program, error " << error << ": " << glewGetErrorString(error) << std::endl;
return 0;
}
return shaderProgram;
}
int main() {
/* Initial checks */
if (!glfwInit()) {
return end("Failed to startup GLFW");
}
int major = 3;
int minor = 3;
int rev = 0;
glfwGetVersion(&major, &minor, &rev);
/* Create the window */
GLFWwindow *window = glfwCreateWindow(500, 500, "3D world prototyping", nullptr, nullptr);
if (!window) {
return end("Failed to create window.");
}
glfwMakeContextCurrent(window); //make the window active
/* Startup GLEW */
glewExperimental = GL_TRUE;
if (glewInit() != GLEW_OK) {
return end("Failed to startup GLEW");
}
/* Start OpenGL constants */
glEnable(GL_DEPTH_TEST);
glEnableClientState(GL_VERTEX_ARRAY);
glViewport(0, 0, 800, 600);
/* Support for multiple shaders without the need to switch attributes */
GLuint vertexArray;
glGenVertexArrays(1, &vertexArray);
glBindVertexArray(vertexArray);
/* Shape vectors */
GLfloat verticies[] = {//X, Y, Z
-0.5f, -0.5f, -0.5f,
0.5f, -0.5f, -0.5f,
0.5f, 0.5f, -0.5f,
0.5f, 0.5f, -0.5f,
-0.5f, 0.5f, -0.5f,
-0.5f, -0.5f, -0.5f,
-0.5f, -0.5f, 0.5f,
0.5f, -0.5f, 0.5f,
0.5f, 0.5f, 0.5f,
0.5f, 0.5f, 0.5f,
-0.5f, 0.5f, 0.5f,
-0.5f, -0.5f, 0.5f,
-0.5f, 0.5f, 0.5f,
-0.5f, 0.5f, -0.5f,
-0.5f, -0.5f, -0.5f,
-0.5f, -0.5f, -0.5f,
-0.5f, -0.5f, 0.5f,
-0.5f, 0.5f, 0.5f,
0.5f, 0.5f, 0.5f,
0.5f, 0.5f, -0.5f,
0.5f, -0.5f, -0.5f,
0.5f, -0.5f, -0.5f,
0.5f, -0.5f, 0.5f,
0.5f, 0.5f, 0.5f,
-0.5f, -0.5f, -0.5f,
0.5f, -0.5f, -0.5f,
0.5f, -0.5f, 0.5f,
0.5f, -0.5f, 0.5f,
-0.5f, -0.5f, 0.5f,
-0.5f, -0.5f, -0.5f,
-0.5f, 0.5f, -0.5f,
0.5f, 0.5f, -0.5f,
0.5f, 0.5f, 0.5f,
0.5f, 0.5f, 0.5f,
-0.5f, 0.5f, 0.5f,
-0.5f, 0.5f, -0.5f
};
GLuint shaderProgram = getShaderProgram({
Shader("vertexShader.glsl", GL_VERTEX_SHADER),
Shader("fragmentShader.glsl", GL_FRAGMENT_SHADER)
}, {
"outcolor"
});
if(shaderProgram == 0) {
return end("");
}
/* Load verticies into memory */
GLuint vertexBuffer;
glGenBuffers(1, &vertexBuffer);
glBindBuffer(GL_ARRAY_BUFFER, vertexBuffer);
glBufferData(GL_ARRAY_BUFFER, sizeof(verticies), verticies, GL_STATIC_DRAW);
/* Getting uniform ids */
glUseProgram(shaderProgram);
// GLint mvpId = glGetUniformLocation(shaderProgram, "mvp");
GLint projectionId = glGetUniformLocation(shaderProgram, "projection");
GLint modelId = glGetUniformLocation(shaderProgram, "model");
GLint viewId = glGetUniformLocation(shaderProgram, "view");
GLenum error = glGetError();
if(error != GL_NO_ERROR) {
std::cout << "Uniform error " << error << ": " << glewGetErrorString(error) << std::endl;
return end("");
}
// else if(mvpId == -1) {
// return end("MVP ID failed to load");
// }
GLint positionAttribute = glGetAttribLocation(shaderProgram, "position");
if(positionAttribute == -1) {
std::cout << "Error: position attribute failed to load" << std::endl;
return end("");
}
/* Positioning */
//FOV, Screen ratio, display range short, display range long
glm::mat4 projection = glm::perspective(glm::radians(45.0f), 800.0f / 600.0f, 1.0f, 10.0f);
glm::mat4 model = glm::mat4(1.0f);
glm::mat4 mvp;
glm::vec3 camera = glm::vec3(0.0f, 0.0f, 3.0f);
glm::vec3 cameraLookingAt = glm::vec3(0.0f, 0.0f, 0.0f);
glm::vec3 cameraPitch = glm::vec3(0.0f, 1.0f, 0.0f);
float moveSpeed = 0.1f;
/* Rendering and logic */
while (!glfwWindowShouldClose(window)) {
/* Shutdown logic */
if (glfwGetKey(window, GLFW_KEY_ESCAPE)) {
break;
}
/* Clear */
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
glClearColor(0.2f, 0.2f, 0.2f, 1.0f);
/* Logic */
/* Keypresses */
glfwPollEvents();
if(glfwGetKey(window, GLFW_KEY_W)) {
camera.z -= moveSpeed;
cameraLookingAt.z -= moveSpeed;
}
else if(glfwGetKey(window, GLFW_KEY_S)) {
camera.z += moveSpeed;
cameraLookingAt.z += moveSpeed;
}
if(glfwGetKey(window, GLFW_KEY_A)) {
camera.x -= moveSpeed;
cameraLookingAt.x -= moveSpeed;
}
else if(glfwGetKey(window, GLFW_KEY_D)) {
camera.x += moveSpeed;
cameraLookingAt.x += moveSpeed;
}
if(glfwGetKey(window, GLFW_KEY_Z)) {
camera.y += moveSpeed;
cameraLookingAt.y += moveSpeed;
}
else if(glfwGetKey(window, GLFW_KEY_X)) {
camera.y -= moveSpeed;
cameraLookingAt.y -= moveSpeed;
}
if(glfwGetKey(window, GLFW_KEY_UP)) {
cameraLookingAt.y += moveSpeed;
}
else if(glfwGetKey(window, GLFW_KEY_DOWN)) {
cameraLookingAt.y -= moveSpeed;
}
if(glfwGetKey(window, GLFW_KEY_LEFT)) {
cameraLookingAt.x -= moveSpeed;
cameraLookingAt.z -= moveSpeed;
}
else if(glfwGetKey(window, GLFW_KEY_RIGHT)) {
cameraLookingAt.x += moveSpeed;
cameraLookingAt.z += moveSpeed;
}
/* Update position */
mvp = projection * glm::lookAt(
camera,
cameraLookingAt,
cameraPitch
) * model;
glm::mat4 view = glm::lookAt(
camera,
cameraLookingAt,
cameraPitch
);
/* Draw */
glUseProgram(shaderProgram);
/* Update the position */
// glUniformMatrix4fv(mvpId, 1, GL_FALSE, &mvp[0][0]);
glUniform4fv(viewId, 1, glm::value_ptr(view));
glUniform4fv(modelId, 1, glm::value_ptr(model));
glUniform4fv(projectionId, 1, glm::value_ptr(projection));
/* Redraw the position using the verticies */
glEnableVertexAttribArray(positionAttribute);
glBindBuffer(GL_ARRAY_BUFFER, vertexBuffer);
glVertexAttribPointer(positionAttribute, 3, GL_FLOAT, GL_FALSE, 0, (void*)0); //because not just XYZ need to tell opengl the size of the stride
/* Draw the triangles */
glDrawArrays(GL_TRIANGLES, 0, 36);
glDisableVertexAttribArray(positionAttribute);
glfwSwapBuffers(window);
/* Realtime error checking */
error = glGetError();
if(error != GL_NO_ERROR) {
std::cout << "Error " << error << ": " << glewGetErrorString(error) << std::endl;
}
}
glfwDestroyWindow(window);
glDeleteProgram(shaderProgram);
glDeleteBuffers(1, &vertexBuffer);
glDeleteVertexArrays(1, &vertexArray);
return end(nullptr);
}
顶点着色器:
#version 330
uniform mat4 projection; /* view port / perspective */
uniform mat4 model; /* object */
uniform mat4 view; /* camera */
in vec3 position;
void main() {
gl_Position = projection * view * model * vec4(position, 1.0);
}
最佳答案
您需要在调用 glVertexAttribPointer 时指定步幅因为你的顶点没有打包(你有交错的位置和颜色数据):
glVertexAttribPointer(positionAttribute, 3, GL_FLOAT, GL_FALSE, sizeof(GLfloat) * 6, 0);
关于c++ - 未渲染 OpenGL 立方体,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30540117/
我有 3 个具有相同结构但数据不同的数据库,因为它们来自不同的客户端。 现在,我有一个现有的 SSAS 项目。其数据源 View 、多维数据集和维度只能使用或访问一个数据库。 我想要的是能够使用具有相
所以我的目标是将这些立方体放在一个网格上,并让它们排成一行,可以拖动和捕捉。我根据 this example 使立方体运行良好,但我没有完全理解某些机制,因此遇到了一些问题。 立方体开始时比旋转后大。
我正在解决一个问题,我需要使用 C# 处理内存中的多维数据。我的要求类似于 OLAP 多维数据集,但没有那么复杂。例如,我不需要计算或聚合或类似的东西。我基本上想使用多维键来引用数据。例如: var
我在 Cubical agda 工作,并试图为以后的证明建立一些通用的实用程序。其中之一是,对于任何类型 A,它与 Σ A (\_ -> Top) 类型“相同”,其中 Top是具有一个元素的类型。问题
我有这个在 WPF Viewport3D 中绘制立方体的代码:
以下代码是我目前写的使用三个js尝试移动或翻译 使用 WASD 键上下左右旋转立方体对象,并使用空格键重置到原始位置(屏幕中间)。我对三个 js 很陌生,我不知道如何让运动发挥作用。任何帮助将不胜感激
我想通过使用 opengl 来绘制体素,但它似乎不受支持。我制作了一个立方体绘制函数,它有 24 个顶点(每个面 4 个顶点),但是当你绘制 2500 个立方体时它会降低帧速率。我希望有更好的方法。理
我正在努力为盒子基元创建线框。尝试了颜色、不透明度和透明属性,但似乎都不起作用。这是代码 - 需要渲染这样的东西 - 最佳答案 您需要查看THREE.Material docs对于这个,有一点需要注
我有一个 opengl 立方体,我想对所有 6 个面进行纹理处理。 我需要多个纹理吗? 这是当前立方体的屏幕截图: 基本上我不知道如何将纹理包裹在整个立方体周围...... 这是我的 cube.h 头
我正在为《我的世界》编写一个模组,并遇到了一个令人困惑的数学问题。我想找到中心 block 周围所有 block 的 ID。为此,我想循环遍历 3x3 的方 block 并返回哪些是我想要的方 blo
这是我的问题:我一直在尝试让这个 CSS 立方体打开滚动。我做到了!这是它的工作原理:https://codepen.io/vaninoo/pen/BmyYQd 我很高兴。但是和 friend 测试过
我正在尝试创建 3 个具有相同视角的 3d 立方体,这些立方体将在悬停时旋转 90 度。它几乎适用于 chrome,但如果你仔细观察左侧立方体的底部边框,你会看到 1 条蓝色像素线。当您将鼠标悬停在右
我正在编写一个立方体,但无法使其正确旋转,有人可以帮我吗?我已经尝试了一切。我的代码链接如下: Codepen Link @keyframes spin { from { transform: r
我想创建一个 CSS 立方体,它有 4 个面(正面、背面、顶部、底部),并且它仅在 X 轴上不断向上(或向下)旋转。但出于某种原因,我无法对齐所有 4 个边,所以它看起来像一个立方体。这是我的标记:
啊哈!看来我的问题是我给 gluPerspective 的 zNear 值必须大于 0,而且我必须启用深度缓冲区才能使其工作。我更新了下面的代码以使其正常工作。 我尝试过很多次这样做,并且一直认为我以
我正在为学校开发一个使用 HTML5 和 CSS3 的元素。该元素的目标是教幼儿如何计算简单的方程式。学习这一点的第一步是教他们识别不同形状的数字。 第一个练习是:显示一个随机数并让 child 选择
我用 html 和 css 制作了一个旋转立方体。 当我按向右和向左箭头键时,立方体会按预期围绕其中心旋转。但是,当我按下向上和向下箭头键时,它会在更大的空间内旋转。 在这种情况下,我也希望它围绕其中
我正在努力让立方体在 opengl 中呈现。当我将已经计算出的 MVP 传递给顶点着色器时,它工作正常,但是当我传递模型、 View 和投影然后在顶点着色器中进行计算时,它不显示立方体。当我将顶点着色
大家好,我是 opengl 世界的新手,所以这就像一个星期我试图了解 opengl 是如何工作的。所以我放下我的代码使用不同的例子,我编译它没有问题。但是立方体没有出现,我不知道为什么。谁能向我解释我
我有一个应该绘制立方体的类。 它在主体中很好地绘制了我的立方体,但我使用默认的 x、y、z 值创建它,以便默认情况下将其置于屏幕中央。在通过调用 build 绘制立方体后,我想平移和缩放立方体,但我显
我是一名优秀的程序员,十分优秀!