- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我无法将 hello 三角形从我习惯在 Qt 之外使用 Glew 和 GLFW 移植到 Qt 5.5 和 QOpenGlWidget,使用"new"方式使用 QSurfaceFormat、QOpenGLfunctions、QOpenGLShaderProgram 和 Core profile 等opengl >= 3.3。
这是我的 QOpenGLWidget 子类“OGLWidget”,我改编自 this post.还有这个Qt tutorial
#include "oglwidget.h"
#include <QOpenGLWidget>
#include <QtGui/QWindow>
#include <QtGui/QOpenGLFunctions>
#include <QtGui/QOpenGLShaderProgram>
OGLWidget::OGLWidget(QWidget *parent)
:QOpenGLWidget(parent)
, m_program(0)
{
}
OGLWidget::~OGLWidget()
{
}
static const char *vertexShaderSource =
"attribute highp vec4 posAttr;\n"
"attribute lowp vec4 colAttr;\n"
"varying lowp vec4 col;\n"
"uniform highp mat4 matrix;\n"
"void main() {\n"
" col = colAttr;\n"
" gl_Position = matrix * posAttr;\n"
"}\n";
static const char *fragmentShaderSource =
"varying lowp vec4 col;\n"
"void main() {\n"
" gl_FragColor = col;\n"
"}\n";
void OGLWidget::initializeGL()
{
initializeOpenGLFunctions();
m_program = new QOpenGLShaderProgram(this);
m_program->addShaderFromSourceCode(QOpenGLShader::Vertex, vertexShaderSource);
m_program->addShaderFromSourceCode(QOpenGLShader::Fragment, fragmentShaderSource);
m_program->link();
m_posAttr = m_program->attributeLocation("posAttr");
m_colAttr = m_program->attributeLocation("colAttr");
m_matrixUniform = m_program->uniformLocation("matrix");
}
void OGLWidget::paintGL()
{
const qreal retinaScale = devicePixelRatio();
glViewport(0, 0, width() * retinaScale, height() * retinaScale);
glClear(GL_COLOR_BUFFER_BIT);
m_program->bind();
m_program->setUniformValue(m_matrixUniform, matrix);
GLfloat vertices[] = {
0.0f, 0.707f, 0.0f,
-0.5f, -0.5f, 0.0f,
0.5f, -0.5f, 0.0f
};
GLfloat colors[] = {
1.0f, 0.0f, 0.0f,
0.0f, 1.0f, 0.0f,
0.0f, 0.0f, 1.0f
};
glVertexAttribPointer(m_posAttr, 3, GL_FLOAT, GL_FALSE, 0, vertices);
glVertexAttribPointer(m_colAttr, 3, GL_FLOAT, GL_FALSE, 0, colors);
glEnableVertexAttribArray(0);
glEnableVertexAttribArray(1);
glDrawArrays(GL_TRIANGLES, 0 , 3);
glDisableVertexAttribArray(1);
glDisableVertexAttribArray(0);
}
void OGLWidget::resizeGL(int w, int h)
{
matrix.setToIdentity();
matrix.perspective(60.0f, 4.0f/3.0f, 0.1f, 100.0f);
matrix.translate(0, 0, -2);
}
这适用于这个 main.cpp:
#include <QApplication>
#include <QSurfaceFormat>
#include "oglwidget.h"
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
QSurfaceFormat format;
format.setDepthBufferSize(24);
format.setStencilBufferSize(8);
format.setVersion(3, 3);
QSurfaceFormat::setDefaultFormat(format);
OGLWidget myGLWidget;
myGLWidget.resize(640, 480);
myGLWidget.show();
return a.exec();
}
但是,当我添加:format.setProfile(QSurfaceFormat::CoreProfile);
到上面的 block ,并将我的着色器更改为我最近使用核心配置文件和 GLSL 3.3 的 openGL 教程学习的着色器:
static const char *vertexShaderSource =
"#version 330 core;\n"
"layout (location = 0) in vec3 posAttr;\n"
"layout (location = 1) in vec3 colAttr;\n"
"out vec3 fragColor;\n"
"void main(){\n"
" gl_Position = matrix * vec4(posAttr, 1.0f);\n"
" fragColor = colAttr;\n"
"}\n";
static const char *fragmentShaderSource =
"#version 330 core;\n"
"in vec3 fragColor;\n"
"out vec4 color;\n"
"void main(){\n"
" color = vec4(fragColor, 1.0f);"
"}\n";
我的代码可以编译,但我有黑屏。没有三角形了。
我在 macbook pro retina,yosemite 10.10.5 上使用 Qt 5.5。 GPU 英特尔虹膜。
知道我应该在那里修改什么以再次向我的彩色三角形问好吗?
谢谢
编辑
这是新版本的代码,其中包含评论,建议添加 VAO。我认为 VBO 是必需的,但没有我即兴创作的这些最近的 Qt 类的工作示例。尽管如此,我的三角形仍然没有出现。我在这里进行了简化,因为我使用了直接在着色器中编码的单一颜色。
OGLWidget::OGLWidget(QWidget *parent)
:QOpenGLWidget(parent)
, m_program(0)
{
}
OGLWidget::~OGLWidget()
{
}
static const char *vertexShaderSource =
"#version 330 core\n"
"layout (location = 0) in vec3 posAttr;\n"
"uniform mat4 matrix;\n"
"void main(){\n"
" gl_Position = matrix * vec4(posAttr, 1.0f);\n"
"}\n";
static const char *fragmentShaderSource =
"#version 330 core\n"
"out vec4 color;\n"
"void main(){\n"
" color = vec4(0.5f, 0.0f, 0.0f, 1.0f);\n"
"}\n";
void OGLWidget::initializeGL()
{
initializeOpenGLFunctions();
GLfloat vertices[] = {
0.0f, 0.707f, 0.0f,
-0.5f, -0.5f, 0.0f,
0.5f, -0.5f, 0.0f
};
m_program = new QOpenGLShaderProgram(this);
m_program->addShaderFromSourceCode(QOpenGLShader::Vertex, vertexShaderSource);
m_program->addShaderFromSourceCode(QOpenGLShader::Fragment, fragmentShaderSource);
m_program->link();
m_posAttr = m_program->attributeLocation("posAttr");
m_matrixUniform = m_program->uniformLocation("matrix");
const qreal retinaScale = devicePixelRatio();
glViewport(0, 0, width() * retinaScale, height() * retinaScale);
// Create Vertex Array Object
m_vao.create();
m_vao.bind();
// Create Vertex Buffer (Do not release until VAO is created)
m_vertexBuffer = QOpenGLBuffer(QOpenGLBuffer::VertexBuffer);
m_vertexBuffer.create();
m_vertexBuffer.bind();
m_vertexBuffer.setUsagePattern(QOpenGLBuffer::StaticDraw);
m_vertexBuffer.allocate(sizeof(vertices));
m_program->bind();
m_program->setAttributeBuffer(m_posAttr, GL_FLOAT, 0, 3*sizeof(GLfloat));
m_program->enableAttributeArray(m_posAttr);
m_program->setAttributeArray(m_posAttr, vertices, 3);
m_vao.release();
m_vertexBuffer.release();
m_program->release();
}
void OGLWidget::paintGL()
{
glClear(GL_COLOR_BUFFER_BIT);
m_program->bind();
m_program->setUniformValue(m_matrixUniform, matrix);
m_vao.bind();
glDrawArrays(GL_TRIANGLES, 0 , 3);
m_vao.release();
glDisableVertexAttribArray(1);
glDisableVertexAttribArray(0);
m_program->release();
}
void OGLWidget::resizeGL(int w, int h)
{
matrix.setToIdentity();
matrix.perspective(60.0f, 4.0f/3.0f, 0.1f, 100.0f);
matrix.translate(0, 0, -2);
}
最佳答案
在阅读和测试了一些代码之后,我在这里提交了一些有效的代码。如果您认为有一种甚至“更好”的方法(相对于 Qt 或 openGL 推荐的方法更好),无论如何,请纠正我。
(main.cpp没有变化)
oglwidget.h
#include <QWidget>
#include <QOpenGLWidget>
#include <QtGui/QWindow>
#include <QtGui/QOpenGLFunctions>
#include <QtGui/QOpenGLShaderProgram>
#include <QOpenGLVertexArrayObject>
#include <QOpenGLBuffer>
class QPainter;
class QOpenGLContext;
class QOpenGLPaintDevice;
class OGLWidget : public QOpenGLWidget, protected QOpenGLFunctions
{
public:
OGLWidget(QWidget *parent = 0);
~OGLWidget();
protected:
void initializeGL();
void resizeGL(int w, int h);
void paintGL();
private:
bool prepareShaderProgram( const QString& vertexShaderPath,
const QString& fragmentShaderPath );
QOpenGLVertexArrayObject m_vao;
QOpenGLBuffer m_vertexBuffer;
QOpenGLShaderProgram m_shader;
};
我没有把上面的放在我原来的帖子里。所以这会让事情变得更清楚。下面是更正后的 oglwidget.cpp,用于显示红色三角形。
oglwidget.cpp
OGLWidget::OGLWidget(QWidget *parent)
:QOpenGLWidget(parent)
, m_shader(0)
, m_vertexBuffer(QOpenGLBuffer::VertexBuffer)
{
}
OGLWidget::~OGLWidget()
{
}
void OGLWidget::initializeGL()
{
initializeOpenGLFunctions();
glClearColor( 0.0f, 0.0f, 0.0f, 1.0f );
if ( !prepareShaderProgram( "/file Path To vertex shader source file", "/file Path To fragment shader source file" ) )
return;
GLfloat vertices[] = {
0.0f, 0.707f, 0.0f,
-0.5f, -0.5f, 0.0f,
0.5f, -0.5f, 0.0f
};
// Setup Vertex Buffer
m_vertexBuffer.create();
m_vertexBuffer.setUsagePattern(QOpenGLBuffer::StaticDraw);
// Bind Vertex Buffer + check
if ( !m_vertexBuffer.bind() )
{
qWarning() << "Could not bind vertex buffer to the context";
return;
}
m_vertexBuffer.allocate(vertices, sizeof(vertices));
// Bind the shader program so that we can associate variables from
// our application to the shaders
if ( !m_shader.bind() )
{
qWarning() << "Could not bind shader program to context";
return;
}
// Create Vertex Array Object
m_vao.create();
m_vao.bind();
m_shader.setAttributeBuffer("vertex", GL_FLOAT, 0, 3);
m_shader.enableAttributeArray("vertex");
m_vao.release();
m_vertexBuffer.release();
m_shader.release();
}
void OGLWidget::paintGL()
{
glClear(GL_COLOR_BUFFER_BIT);
m_shader.bind();
m_vao.bind();
glDrawArrays(GL_TRIANGLES, 0 , 3);
m_vao.release();
m_shader.release();
}
void OGLWidget::resizeGL(int w, int h)
{
// const qreal retinaScale = devicePixelRatio();
// glViewport(0, 0, width() * retinaScale, height() * retinaScale);
glViewport( 0, 0, w, qMax( h, 1 ) );
}
bool OGLWidget::prepareShaderProgram(const QString &vertexShaderPath, const QString &fragmentShaderPath)
{
// First we load and compile the vertex shader…
bool result = m_shader.addShaderFromSourceFile( QOpenGLShader::Vertex, vertexShaderPath );
if ( !result )
qWarning() << m_shader.log();
// fragment shader
result = m_shader.addShaderFromSourceFile( QOpenGLShader::Fragment, fragmentShaderPath );
if ( !result )
qWarning() << m_shader.log();
// link the shaders
result = m_shader.link();
if ( !result )
qWarning() << "Could not link shader program:" << m_shader.log();
return result;
}
我不清楚是否需要使用:glDisableVertexAttribArray
,我一直在非 Qt 代码中使用它。在这里我没有,但如果我必须,我应该什么时候使用它?无论如何,三角形显示。
关于c++ - 带有 QOpenGLWidget 的 Qt 5.5,核心配置文件中的隐形三角形,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33639109/
SDL3 提供了 SDL_RenderGeometry 函数绘制几何图形,用法和 OpenGL 差不多,先定义顶点数据,然后根据顶点数据绘制几何图形。 绘制三角形的代码如下: std::array
我想在图像上使用三角形类型按钮,但我无法执行此操作... 如何做到这一点? 最佳答案 这个project可以帮你。您可以自定义 UIButton 的形状。 关于iphone - 定制非矩形按钮 三角形
我一直在尝试找出如何使用 Python 制作彩虹三角螺旋。我可以制作一个方形螺旋,但它不会导入颜色。而且它不使用三角形。 输出应该是什么样子: 我取得的成就: 我的代码: import tur
我正在使用 this 研究三角形检测算法文章。我编写了这段代码,但不幸的是,当三角形之间存在交集时,该方法返回 false。 private boolean checkTriangleCollisio
我在资源文件中找到了几个关于如何在 Android 中绘制三角形的答案。但是我没有找到任何可以解释如何更改三角形旋转的内容。 我找到的例子:
对于编码类(class)中的作业,我应该找到一种方法让 Python 制作星号三角形,如下所示: x xx xxx 但是,无论我用我的代码做什么,我都无法做到这一点。最好的我可以得到的是:
我在绘制两个多边形时遇到问题。我想填充两个三角形,但一个大于第二个。我在 winforms 中使用 UserControl。代码: Point[] DOWN = new Point[] {new Po
如何测试三角形和正方形是否相交? 当我们知道它是正方形而不是矩形时,有什么方法可以优化它吗?此外,正方形是轴对齐的,这样应该可以进一步提升性能? 或者我应该把正方形分成三角形,然后对三角形-三角形相交
我有一个方法是画一个多边形,然后将多边形向右旋转90度,使其原来的顶点现在指向右边。 这是绘制多边形(三角形)的代码,但我不知道如何旋转它。 Point[] points = new Point[3]
我知道有高效的多边形裁剪算法(例如 Maillot、Vatti、Greiner-Hormann)。然而,这些算法适用于任意多边形,尽管它们适合我的情况,但在我看来,对像我这样的简单情况使用这种通用算法
我的问题可能很愚蠢,但我没有找到三角形 strip 使用的好例子: http://i.stack.imgur.com/KL8jk.png 像这样的顶点: A: -0.5f, -0.5f, // Bo
我正在尝试创建一个等边三角形,您可以在 fiddle 中看到它: 我的想法是,我将笔放在 (0, 0) 处,然后在 (20, 11) 处画线,但三角形看起来不正确。 最佳答案 您的三角形已被
通过编写一些逻辑代码,只是无法弄清楚如何以所需的形式获得 01 三角形的输出,三角形确实打印出来,但不是根据要求的输出。 import java.util.Scanner; import java
我一直在尝试制作一个简单的 pygame 程序来检查光标是否在三角形内部或外部。我通过找到较大三角形的面积,然后从鼠标位置到所有三个点制作三个内部三角形并找到它们的面积来完成此操作。 根据我的理解,如
我有一个方法 drawTriangle,它在 JAVA 中的 OpenGL 程序的 display() 方法中被引用。 public void drawTriangle(GL gl, int x1,
我正在尝试用 C++ 创建一个程序,该程序将数字的三角形模式放入二维数组中。 示例: 1 3 4 5 9 2 9 4 6 1 顶行是一个数字(整数),三角形的每一行比它上面的行多一
所以我最近一直在尝试学习 OpenGL,遵循了几个文本和视频教程。 我无法绘制三角形,我已经双重和三次检查我是否以正确的顺序执行了所有必要的步骤,但我显然遗漏了一些东西 在添加一些代码之前,我应该声明
我遇到了一个用递归绘制谢尔宾斯基三角形的程序。我如何解释这段代码是调用 sierpinski1 直到 n == 0,然后只绘制 3 个小三角形(每次调用一个三角形),因为 n == 0 是绘制某些东西
我有一个需要 3 个点的函数,我将使用这些点来绘制一个三角形,就好像我在使用 glVertex 函数一样。 但由于我想在避免透视变形的同时对这个三角形进行纹理贴图,我必须对其进行 segmentati
下面的代码应该为三角形添加一个 3d 对象,但我收到错误 Assets/Scripts/MakeTriangle.cs(6,28):错误 CS0120:需要对象引用才能访问非静态成员 `UnityEn
我是一名优秀的程序员,十分优秀!