簡體   English   中英

OpenGL嘗試使用紋理拉伸四邊形但拉伸三角形?

[英]OpenGL trying to stretch quad with texture but stretches triangles?

我編寫了代碼以重塑已紋理化的四邊形。 當我拉伸四邊形時,圖像確實會拉伸到我期望的樣子。 我似乎在拉伸圖像時,有兩個不同的三角形與一個四邊形相對。 左上方的像素會延伸在一起,但不會影響右下方的像素。 反之亦然。 是否有一個設置應該延伸到整個四邊形。

這是一張圖片:

在此處輸入圖片說明

要使用我的代碼,您可以使用箭頭鍵移動拐角。 按空格鍵可切換要控制的角。

我的密碼

// textureMapping.cpp
#include <OpenGL/gl.h>
#include <OpenGL/glu.h>
#include <GLUT/glut.h>
#include <stdlib.h>
#include <stdio.h>
#include <iostream>

#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>


static GLuint texName;
int mode = 0;
double tol = 0.2f;

double xLoc = 0.0;
double yLoc = 0.0;

double xLocLL = 0.0;
double yLocLL = 0.0;

double xLocUL = 0.0;
double yLocUL = 0.0;

double xLocLR = 0.0;
double yLocLR = 0.0;

double xLocUR = 0.0;
double yLocUR = 0.0;

void init(void)
{    

   cv::Mat image = cv::imread("lena.tiff");
  //cv::Mat flipped;
  //cv::flip(image, flipped, 0);
  //image = flipped;
  if(image.empty()){
      std::cout << "image empty" << std::endl;
  }else{
      cv::flip(image, image, 0);
      glGenTextures(1, &texName);
      glBindTexture(GL_TEXTURE_2D, texName);

      glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
      glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);

        // Set texture clamping method
      glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP);
      glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP);


      glTexImage2D(GL_TEXTURE_2D,     // Type of texture
                     0,                 // Pyramid level (for mip-mapping) - 0 is the top level
                     GL_RGB,            // Internal colour format to convert to
                     image.cols,          // Image width  i.e. 640 for Kinect in standard mode
                     image.rows,          // Image height i.e. 480 for Kinect in standard mode
                     0,                 // Border width in pixels (can either be 1 or 0)
                     GL_BGR, // Input image format (i.e. GL_RGB, GL_RGBA, GL_BGR etc.)
                     GL_UNSIGNED_BYTE,  // Image data type
                     image.ptr());        // The actual image data itself

      glGenerateMipmap(GL_TEXTURE_2D);
  }
}

void display(void)
{
   glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
   glEnable(GL_TEXTURE_2D);
   glTexEnvf(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_DECAL);
   glBindTexture(GL_TEXTURE_2D, texName);
   glBegin(GL_QUADS);
   glTexCoord2f(0.0, 0.0); glVertex3f(-1.0+xLoc+xLocLL, -1.0+yLoc+yLocLL, 0.0);
   glTexCoord2f(0.0, 1.0); glVertex3f(-1.0+xLoc+xLocUL, 1.0+yLoc+yLocUL, 0.0);
   glTexCoord2f(1.0, 1.0); glVertex3f(1.0+xLoc+xLocUR, 1.0+yLoc+yLocUR, 0.0);
   glTexCoord2f(1.0, 0.0); glVertex3f(1.0+xLoc+xLocLR, -1.0+yLoc+yLocLR, 0.0);
   //glTexCoord2f(0.0, 0.0); glVertex3f(-1.0+xLoc, -1.0+yLoc, 0.0);
   //glTexCoord2f(0.0, 1.0); glVertex3f(-1.0+xLoc, 1.0+yLoc, 0.0);
   //glTexCoord2f(1.0, 1.0); glVertex3f(1.0+xLoc, 1.0+yLoc, 0.0);
   //glTexCoord2f(1.0, 0.0); glVertex3f(1.0+xLoc, -1.0+yLoc, 0.0);
   glEnd();
   glFlush();
   glDisable(GL_TEXTURE_2D);
   glutSwapBuffers();
}

void reshape(int w, int h)
{
   glViewport(0, 0, (GLsizei) w, (GLsizei) h);
   glMatrixMode(GL_PROJECTION);
   glLoadIdentity();
   gluPerspective(60.0, (GLfloat) w/(GLfloat) h, 1.0, 30.0);
   glMatrixMode(GL_MODELVIEW);
   glLoadIdentity();
   glTranslatef(0.0, 0.0, -3.6);
}

void keyboard (unsigned char key, int x, int y)
{
   switch (key) {
      case 27:
         exit(0);
         break;
      case 32:
         mode += 1;
         if (mode == 5)
         {
            mode = 0;
         }
         break;
      default:
         break;
   }
}

void processSpecialKeys(int key, int x, int y) {

   switch(key) {
      case GLUT_KEY_LEFT:
         switch(mode)
         {
            case 0:
               xLoc -= tol;
               break;
            case 1:
               xLocLL -= tol;
               break;
            case 2:
               xLocUL -= tol;
               break;
            case 3:
               xLocUR -= tol;
               break;
            case 4:
               xLocLR -= tol;
               break;
         }
         break;
      case GLUT_KEY_RIGHT:
         switch(mode)
         {
            case 0:
               xLoc += tol;
               break;
            case 1:
               xLocLL += tol;
               break;
            case 2:
               xLocUL += tol;
               break;
            case 3:
               xLocUR += tol;
               break;
            case 4:
               xLocLR += tol;
               break;
         }
         break;
      case GLUT_KEY_DOWN:
         switch(mode)
         {
            case 0:
               yLoc -= tol;
               break;
            case 1:
               yLocLL -= tol;
               break;
            case 2:
               yLocUL -= tol;
               break;
            case 3:
               yLocUR -= tol;
               break;
            case 4:
               yLocLR -= tol;
               break;
         }
         break;
      case GLUT_KEY_UP:
         switch(mode)
         {
            case 0:
               yLoc += tol;
               break;
            case 1:
               yLocLL += tol;
               break;
            case 2:
               yLocUL += tol;
               break;
            case 3:
               yLocUR += tol;
               break;
            case 4:
               yLocLR += tol;
               break;
         }
         break;
   }
}


int main(int argc, char** argv)
{
   glutInit(&argc, argv);
   glutInitDisplayMode(GLUT_SINGLE | GLUT_RGB | GLUT_DEPTH);
   glutInitWindowSize(500, 500);
   glutInitWindowPosition(100, 100);
   glutCreateWindow(argv[0]);
   init();
   glutDisplayFunc(display);
   glutReshapeFunc(reshape);
   glutIdleFunc(display);
   glutKeyboardFunc(keyboard);
   glutSpecialFunc(processSpecialKeys);

   glutMainLoop();
   return 0; 
}

Makefile文件

textureMapping: textureMapping.cpp
    g++ -o textureMapping textureMapping.cpp -L/usr/local/lib -I/usr/local/include -lopencv_core -lopencv_highgui -framework GLUT -framework OpenGL -framework Cocoa -framework IOKit -framework CoreVideo

不,這是正確的行為。 GL規范(3.0之前的版本)允許將四邊形繪制為成對的三角形,這就是您所看到的。 在3.0版中將四邊形完全從規范中刪除。

如果您希望它看起來像一個帶有透視圖的四邊形,那么您實際上需要提供3d坐標。

如果您期望OpenGL猜測要應用哪種透視變換來使矩形彎曲成要推動的2d形狀,那么您就顯得格格不入。 這是一個高度特定於應用程序的功能。 您應該查找單應性。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM