ios opengl es 2.0,当我应用正交时我的矩形不是正方形

标签 ios opengl-es-2.0 orthographic

我正在学习 opengl es 2.0。 我正在尝试在 opengl es 2.0 中应用正射投影 我画了一个正方形,但实际上我并没有在屏幕上得到正方形。 而且我不确定我缺少哪一部分。 感谢您的帮助! setupRenderingEnv 中有一些方法我没有贴出来。但这些方法用于设置框架并且工作正常。 并且 m_program 创建良好。 再次感谢您的帮助。

// my vertex shader
attribute vec4 Position;
attribute vec4 SourceColor;

uniform mat4 Projection;

varying vec4 DestinationColor;

void main(void)
{
    DestinationColor = SourceColor;
    gl_Position = Projection * Position;
}  

// my drawing file
typedef struct 
{
    float Position[3];
    float Color[4];
}Vertex;

const Vertex Vertices[] =
{
    {{100, -100, 0}, {1, 0, 0, 1}},
    {{100, 100, 0}, {0, 1, 0, 1}},
    {{-100, 100, 0}, {0, 0, 1, 1}},
    {{-100, -100, 0}, {0, 0, 0, 1}}
};

const GLubyte Indices[] =
{
    0, 1, 2,
    2, 3, 0
};

- (void)setupRenderingEnv
{
    [super setupRenderingEnv];
    [self setupVertexBufferObjects];
    [self setupRunLoop];

    [self applyOrthoWithX:self.frame.size.width andY:self.frame.size.height];

    glViewport(0, 0, self.frame.size.width, self.frame.size.height);

}


//-- used for applying ortho in opengl es 2.0
- (void)applyOrthoWithX:(float)maxX andY:(float)maxY
{
    float a = 1.0f / maxX;
    float b = 1.0f / maxY;
    float ortho[16] =
    {
        a, 0, 0, 0,
        0, b, 0, 0,
        0, 0, -1, 0,
        0, 0, 0, 1
    };

    GLint projectionUniform = glGetUniformLocation(super.m_programHandle, "Projection");
    glUniformMatrix4fv(projectionUniform, 1, 0, &ortho[0]);
}


//-- overriding drawCandle. it render image, draw candle
- (void)drawCandle
{
    glClearColor(0, 104.0/255, 55.0/255, 1.0);
    glClear(GL_COLOR_BUFFER_BIT);

    GLuint positionSlot = glGetAttribLocation(super.m_programHandle, "Position");
    GLuint colorSlot = glGetAttribLocation(super.m_programHandle, "SourceColor");

    glEnableVertexAttribArray(positionSlot);
    glEnableVertexAttribArray(colorSlot);

    glVertexAttribPointer(positionSlot, 3, GL_FLOAT, GL_FALSE, 
                          sizeof(Vertex), 0);
    glVertexAttribPointer(colorSlot, 4, GL_FLOAT, GL_FALSE, 
                          sizeof(Vertex), (GLvoid *)(sizeof(float) *     3));


    glDrawElements(GL_TRIANGLES, sizeof(Indices)/sizeof(Indices[0]), GL_UNSIGNED_BYTE, 0);

    glDisableVertexAttribArray(positionSlot);
    glDisableVertexAttribArray(colorSlot);

    [super drawCandle];
}

最佳答案

您的视口(viewport)是什么形状?如果它不是方形的,那就是问题所在。您正在创建的矩阵 - 按反向宽度和反向高度缩放 ​​- 将使宽度始终为 1 个单位宽,高度始终为 1 个单位高。如果宽度和高度的像素数不同,则正方形不会绘制成正方形。您需要考虑视口(viewport)的纵横比。在我的脑海中,我认为它会更像这样:

float ortho [ 16 ] = {
    a / b, 0, 0, 0,
    0, b, 0, 0,
    0, 0, -1, 0,
    0, 0, 0, 1
};

(我可能把 a/b 颠倒了——不记得了)

关于ios opengl es 2.0,当我应用正交时我的矩形不是正方形,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11605691/

相关文章:

ios - 使用 Storyboard 设置tableview的静态单元格的行距

objective-c - 在 cocos2d 2.0 中重复绑定(bind)到山丘的 OpenGL-es 纹理

opengl-es - OES_vertex_array_object 和客户端状态

ios - URL AFNetworking GET 中的变音符号

ios - 为什么在 iTunes Connect "Start External Testing"页面中按下“下一步”按钮没有任何反应?

ios - 如何加密 iOS 中的移动配置文件(在 OTA 部署中)?

javascript - Three.js 正交相机 : Zoom All

ios - OpenGL图像查看器

c++ - 在保持纵横比的 openGL 中调整圆圈的大小

java - 为什么示例作者对正交相机的宽度和高度进行硬编码?(LibGdx Zombie Bird 教程)