关于opengl中贴图的问题

屏幕上有个矩形,选中进行贴图。图形是水平的,若矩形是水平的贴图很简单,但若矩形是斜的怎么办?尝试逐像素对应贴图但计算公式带来误差,会使某些像素点没有贴上,有什么好的方法吗

2个回答

图形的大小也不一定与矩形相同,需要进行拉伸

你只需要找到矩形四个定点对应的纹理四个定点
比如矩形四个顶点坐标为:(20,50,0),(20,20,0),(50,20,0),(50,50,0)
那么找到纹理的四个定点坐标:(0,0),(0,1)(1,1),(1,0)
把他们对应起来,不论矩形怎么旋转,纹理贴图也会跟着旋转

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
关于OpenGL球体贴图问题
现在画了一个球体,但是不知道怎样把一张世界地图的图片贴到他的表面上,希望有大神能帮帮我,谢谢你们了~!
OpenGL中贴图的路径怎样从绝对路径改为相对路径?
OpenGL中贴图的路径怎样从绝对路径改为相对路径?最好能举个例子。
opengl纹理贴图的插值
大家好。我在编写opengl的时候,想做出纹理贴图的插值。 好比,一张纹理是f1(x),一张为f2(x)。能够得到g(x)= t * f1(x)+ (1-t)* f2(x) t:0~1 这样的效果. 谢谢~
关于OpenGL用shader来使用贴图的一些问题
我想实现用shader来显示贴图,但是总是没办法显示图片,只能显示一个灰色的三角形,希望有人能帮我看看是什么问题,下面是代码 void initTest(char* fileName1, char* fileName2) { Shader shader("D:\\VS2013Project\\CPP_Project\\subdivision\\subdivision\\Shader\\shaderTextureTest"); shader.Bind(); currentShader = shader.GetProgram(); tex_model_view_matrix_loc = glGetUniformLocation(shader.GetProgram(), "model_view_matrix"); tex_projection_matrix_loc = glGetUniformLocation(shader.GetProgram(), "projection_matrix"); tex_sampler_texture_unit = glGetUniformLocation(shader.GetProgram(), "tex"); int imageWidth1, imageHeight1; FREE_IMAGE_FORMAT fif1 = FreeImage_GetFileType(fileName1); FIBITMAP* dib1 = FreeImage_Load(fif1, fileName1, 0); if (dib1 == NULL) return; dib1 = FreeImage_ConvertTo24Bits(dib1); BYTE* image1Data; imageWidth1 = FreeImage_GetWidth(dib1); imageHeight1 = FreeImage_GetHeight(dib1); image1Data = FreeImage_GetBits(dib1); static const GLfloat vertex_array[] = { 0.0f, 0.0f, 0.0f, 1.0f, 10.0f, 0.0f, 0.0f, 1.0f, 0.0f, 10.0f, 0.0f, 1.0f, 10.0f, 10.0f, 0.0f, 1.0f }; static const GLfloat tex_coord_array[] = { 0.0f, 0.0f, 1.0f, 0.0f, 0.0f, 1.0f, 1.0f, 1.0f }; //glActiveTexture(GL_TEXTURE1); //以下是处理顶点数据和纹理坐标数据的代码 glGenBuffers(1, textureVertexDataBuffer); glBindBuffer(GL_ARRAY_BUFFER, textureVertexDataBuffer[0]); glBufferData(GL_ARRAY_BUFFER, sizeof(vertex_array) + sizeof(tex_coord_array), NULL, GL_STATIC_DRAW); glBufferSubData(GL_ARRAY_BUFFER, 0, sizeof(vertex_array), vertex_array); glBufferSubData(GL_ARRAY_BUFFER, sizeof(vertex_array), sizeof(tex_coord_array), tex_coord_array); glGenVertexArrays(1, textureVAO); glBindVertexArray(textureVAO[0]); glVertexAttribPointer(0, 4, GL_FLOAT, GL_FALSE, 0, (void*)(0)); glVertexAttribPointer(1, 2, GL_FLOAT, GL_FALSE, 0, (void*)(vertex_array)); glEnableVertexAttribArray(0); glEnableVertexAttribArray(1); glGenTextures(1, textureBuffer); glActiveTexture(GL_TEXTURE0); glBindTexture(GL_TEXTURE_2D, textureBuffer[0]); glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, imageWidth1, imageHeight1, 0, GL_RGB, GL_UNSIGNED_BYTE, image1Data); glUniform1i(tex_sampler_texture_unit, 0); glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE); glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE); glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR); glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR); } void display() { glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); glUseProgram(currentShader); vmath::mat4 projection_matrix(vmath::perspective(45, aspect, 0.1, 100)); vmath::vecN<float, 3> eye; eye[0] = 0.0f; eye[1] = 0.0f; eye[2] = 6.0f; vmath::vecN<float, 3> center; center[0] = 0.0f; center[1] = 0.0f; center[2] = 0.0f; vmath::vecN<float, 3> up; up[0] = 0.0f; up[1] = 1.0f; up[2] = 0.0f; vmath::mat4 modelView_matrix(vmath::lookat(eye, center, up)); glUniformMatrix4fv(tex_model_view_matrix_loc, 1, GL_FALSE, modelView_matrix); glUniformMatrix4fv(tex_projection_matrix_loc, 1, GL_FALSE, projection_matrix); glActiveTexture(GL_TEXTURE0); glBindTexture(GL_TEXTURE_2D, textureBuffer[0]); glBindVertexArray(textureVAO[0]); glDrawArrays(GL_TRIANGLES, 0, 3); glutSwapBuffers(); } 下面是shader的代码: vert: #version 430 core layout (location = 0) in vec4 vertex_position; layout (location = 1) in vec2 texture_coord; uniform mat4 model_view_matrix; uniform mat4 projection_matrix; out vec2 output_tex_coord; void main() { gl_Position = projection_matrix * model_view_matrix * vertex_position; output_tex_coord = texture_coord; } frag: #version 430 core uniform sampler2D tex; layout (location = 0) out vec4 color; in vec2 output_tex_coord; void main() { color = texture(tex, output_tex_coord); } 下面是结果 ![图片说明](https://img-ask.csdn.net/upload/201706/04/1496571190_821232.png)
关于用OpenGL实现飘雪效果
OpenGL用贴图制作雪花,贴图是黑底白色圆形,启用了混合,但雪花是一个个白色方片。 要如何解决?
关于opengl管理纹理对象的问题
蓝宝书上生成三个mip贴图的代码如下: for(iLoop = 0; iLoop < TEXTURE-COUNT; iLoop++) { // Bind to next texture object glBindTexture(GL_TEXTURE_2D, textures[iLoop]); // Load texture, set filter and wrap modes pBytes = gltReadTGABits(szTextureFiles[iLoop],&iWidth, &iHeight, &iComponents, &eFormat); // Load texture, set filter and wrap modes glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST); glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST); glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE); glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE); glTexImage2D(GL_TEXTURE_2D, 0, iComponents, iWidth, iHeight, 0, eFormat, GL_UNSIGNED_BYTE, pBytes); glGenerateMipmap(GL_TEXTURE_2D); // Don't need original texture data any more free(pBytes); } 示例代码通过不断的调用 glBindTexture(GL_TEXTURE_2D, textures[i])来使用这三个纹理对像。我想知道这三个纹理对象是如何管理的。是在GL_TEXTURE_2D这个变量中分别储存多个纹理,并通过纹理对象名来调用的吗?
请教一个OpenGL编程问题
一个包含了天空盒子、地形和摄像机的OpenGL程序,退出的时候弹出如下窗口。![图片说明](https://img-ask.csdn.net/upload/201509/18/1442562452_765963.jpg) 是资源释放的问题么?贴图尺寸格式什么的都对。 ——————————————————————————————————— 现在知道了,内存没释放。
opengl图片读取路径问题
在VS2013中用Opengl时 想用自己的图片给物体贴图 可是不知道图片的路径是怎么设置 的,我看参考的代码上是这样的 bool LoadT8(char *filename, GLuint &texture) { AUX_RGBImageRec *pImage = NULL; pImage = auxDIBImageLoad(filename); if (pImage == NULL) return false; glGenTextures(1, &texture); glBindTexture(GL_TEXTURE_2D, texture); gluBuild2DMipmaps(GL_TEXTURE_2D, 4, pImage->sizeX, pImage->sizeY, GL_RGB, GL_UNSIGNED_BYTE, pImage->data); free(pImage->data); free(pImage); return true; } void myinit(void) { LoadT8("floor.bmp", g_cactus[0]); LoadT8("ceiling.bmp", g_cactus[1]); 但是我把图片放在工程的文件夹中 运行出来是无法读取图片 只能在LoadT8中写明文件的具体路径才能读取 我想知道是哪里出错了 怎么才能不写图片路径 只要把图片放在文件夹就能读取图片?
opengl shadow mapping 和原有纹理冲突
在opengl的阴影贴图的时候,创建了阴影纹理之后,要对当前纹理状态改变,然后绘制模型,但是我模型里面有之前的问题,改变了纹理状态之后之前的纹理就会错乱了,不知道怎么能在不影响之前的纹理的情况下创建阴影贴图呢
为什么我的win32+opengl纹理贴图是图形是空白的
#include"utils.h" unsigned char * DecodeBMP(unsigned char *bmpFileData,int&width,int&height) { if(0x4D42==*(unsigned short*)bmpFileData) { int pixeiDataOffset=*((int*)(bmpFileData+10)); width=*((int*)(bmpFileData+18)); height=*((int*)(bmpFileData+22)); unsigned char*pixelData=bmpFileData+pixeiDataOffset;//像素块的起始位置 for(int i=0;i<width*height*3;i+=3) { unsigned char temp=pixelData[i]; pixelData[i]=pixelData[i+2]; pixelData[i+2]=temp; } return pixelData; } return nullptr; } GLuint CreateTexture2D(unsigned char *pixelData,int width,int height,GLenum type) { GLuint texture; glGenTextures(1,&texture);//第一个表示申请一个纹理对象 glBindTexture(GL_TEXTURE_2D,texture);//对当前纹理对象进行指定 glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR); glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR); glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_REPEAT); glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_REPEAT); glTexImage2D(GL_TEXTURE_2D, 0, type, width, height, 0, type, GL_UNSIGNED_BYTE, pixelData); //最后一个参数是 你的纹理在哪 此时纹理对象就已经生成了 glBindTexture(GL_TEXTURE_2D,0);//最后将当前纹理设置成为0号纹理以免后面的操作对texture纹理造成影响 不想再被修改 return texture; } GLuint CreateTexture2DFromBMP(const char *bmpPath) { int nFileSize=0; unsigned char *bmpFileContent=LoadFileContent(bmpPath,nFileSize); if(bmpFileContent==nullptr) { return 0; } int bmpWidth=0,bmpHeight=0; unsigned char *pixelData=DecodeBMP(bmpFileContent,bmpWidth,bmpHeight); if(bmpWidth==0) { delete bmpFileContent; return 0; } GLuint texture=CreateTexture2D(pixelData,bmpWidth,bmpHeight,GL_RGB); delete bmpFileContent; return texture; } ``` #include"scene.h" #include"utils.h" GLuint texture; void Init() { glMatrixMode(GL_MODELVIEW); glLoadIdentity(); int nFileSize =0; unsigned char *bmpFileContent=LoadFileContent("Res/test.bmp",nFileSize); int bmpWidth=0,bmpHeight=0; unsigned char *pixelData=DecodeBMP(bmpFileContent,bmpWidth,bmpHeight); texture=CreateTexture2D(pixelData,bmpWidth,bmpHeight,GL_RGB); } void Draw() { glClearColor(1.0f,0.0f,0.0f,1.0f); glClear(GL_COLOR_BUFFER_BIT); glEnable(GL_TEXTURE_2D); glBindTexture(GL_TEXTURE_2D,texture); glBegin(GL_QUADS); glColor3f(1.0,1.0,1.0); glTexCoord2f(0.0f,0.0f); glVertex3f(-0.1f,-0.1f,-0.4f); glTexCoord2f(1.0f,0.0f); glVertex3f(0.1f,-0.1f,-0.4f); glTexCoord2f(1.0f,1.0f); glVertex3f(0.1f,0.1f,-0.4f); glTexCoord2f(0.0f,1.0f); glVertex3f(-0.1f,0.1f,-0.4f); glEnd(); } ```
有没有熟悉OpenGL的大神?求救急!!!
我想用OpenGL实现一个对三维模型的纹理贴图。有OBJ格式的模型数据和影像数据。我的C币不足没法悬赏,求求会的大神帮帮我,定会答谢!!!
QCamera与OpenGL显示摄像头视频
用QCamera做了个摄像头视频采集程序, 现在想将视频显示在OpenGL的模型上应该怎么处理呀 看帖子一般OpenGL都是使用纹理贴图来完成, opencv的话有cvQueryFrame命令 问题是QCamera 貌似没有 类似返回每帧图片的命令呀 该如何操作 求大神指点
基于MFC的opengl实现路径飞行
基于MFC的opengl,现已进行了房屋绘制和纹理贴图光照,三维漫游等,接下来的功能是指定几个点构成路径,让相机沿着这个路径进行飞行,希望大神可以指导一下如何实现这个功能?
不同显卡 不同贴图结果
各位大神 请问opengl为啥在a卡上贴图正确 而在n卡上就变成纯色块了???
opengl怎么实现一个柱面全景图
如何用opengl实现柱面全景图,圆柱侧面贴图?主要运用什么知识,ru'he做出来像Unity3D 柱面全景漫游的效果?
OpenGL如何正确混合材质颜色?
我在修改一段程序时,在片元着色器中混合两个材质的颜色时报错,由于OpenGL版本较老,没找到相关解释。 具体是这样的: 基础的颜色是一个叫baseColor的变量,它是从一张1D贴图上取样下来的: ```GLSL vec4 baseColor=texture1D(heightColorMapSampler,heightColorMapTexCoord); ``` 这个heightColorMapTexCoord坐标是通过顶点坐标计算来的,好像是OpenGL里一个很老的方式了: ```GLSL uniform mat4 depthProjection; ......... ......... vec4 vertexDic=gl_Vertex; vec4 vertexCc=depthProjection*vertexDic; heightColorMapTexCoord=dot(heightColorMapPlaneEq,vertexCc); ``` 以上是定点着色器里的代码,然后我在片元着色器加入了一张新的材质,尝试把baseColor这个颜色和我加进来的材质做一个混合,我先这样做试了一下自己加的材质是否成功的导入进来了: ```GLSL vec4 mycolor = vec4(texture2DRect(mapSampler,gl_FragCoord.xy).rgb, 1.0); baseColor =mycolor; ``` 发现我导入的材质完全覆盖了之前渲染的结果,这正是我想要的效果。然后我用一个mix函数,把上面两行代码改成下面这样,希望可以混合baseColor和我自己的贴图颜色。 ```GLSL vec4 mycolor = vec4(texture2DRect(mapSampler,gl_FragCoord.xy).rgb, 1.0); baseColor =mix(baseColor, mycolor, 0.5); ``` 结果就报错了:Invalid operation。 我以为baseColor是从1D贴图上采样的,所以不能和2D贴图混合,但是我发现这个渲染器本身就有一个地方讲baseColor与2D贴图混合,所以应该是可以混合的。 求问各位这中间出了什么问题?应该怎么办来将两个颜色混合?
opengl +qt 显示图像 和 文本 纹理贴图 显示文本
1.利用opengl对图片进行显示,点击图片画出一个角度,角度的线可以显示,但是角度的数字没有显示。我把文本的代码单独放到控制台显示,显示是正常的,所以推断可能是图片的纹理 对文本的显示造成了干扰,哪些代码影响到了。 ![图片说明](https://img-ask.csdn.net/upload/201906/20/1561032261_180148.jpg) 具体代码如下: 1> 图像关键代码: QImage GlImage = mpCurQImg->convertToFormat(QImage::Format_RGBA8888); glGenTextures(TEXTURE_SIZE,&m_TextureIndex); glBindTexture(GL_TEXTURE_2D,m_TextureIndex); glTexParameteri( GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR ); glTexParameteri( GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR ); glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE); glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE); glTexImage2D( GL_TEXTURE_2D, 0, GL_RGB, GlImage.width(), GlImage.height(), 0, GL_RGBA, GL_UNSIGNED_BYTE, GlImage.bits() ); glPushMatrix(); glBindTexture(GL_TEXTURE_2D,m_TextureIndex); glBegin( GL_QUADS ); glTexCoord2f( 0.0, 0.0 ); glVertex3f( pTextRect[0], pTextRect[2],0); glTexCoord2f( 1.0, 0.0 ); glVertex3f( pTextRect[1], pTextRect[2],0); glTexCoord2f( 1.0, 1.0 ); glVertex3f( pTextRect[1], pTextRect[3],0); glTexCoord2f( 0.0, 1.0 ); glVertex3f( pTextRect[0], pTextRect[3],0); glEnd(); glDisable(GL_TEXTURE_2D); glDisable(GL_DEPTH_TEST); glPopMatrix(); ``` ``` 2>角度的数值显示代码: DrawStringInfo(QString * str,QPointF pt) glColor3f(1.0f, 0.0f, 0.0f); glDisable(GL_DEPTH_TEST); QByteArray ba = str->toLatin1(); const char*ch = "test"; glRasterPos2f(0.0f,0.0f);//测试放在中央 static int isFirstCall = 1; static GLuint lists; if (isFirstCall) { isFirstCall = 0; lists = glGenLists(MAX_CHAR); wglUseFontBitmaps(wglGetCurrentDC(), 0, MAX_CHAR, lists); } for (; *ch != '\0'; ++ch) { glCallList(lists + *ch); } glEnable(GL_DEPTH_TEST);
新手问题opengl贴不上图片
这是源码,在一个旋转的正方体上贴图,结果整个正方体变成了白色的 #include <iostream> #include <stdlib.h> #include <GL/glut.h> #include<glaux.h> using namespace std; //纹理数组 GLuint texture[1]; float _angle=0.0f; AUX_RGBImageRec *LoadBMP(char *Filename) { FILE *file=NULL; if(!Filename) { return NULL; } file=fopen(Filename,"r"); if(file) { fclose(file); return auxDIBImageLoad((LPCWSTR )Filename); } return NULL; } int LoadGLTexture() { int Status =FALSE; AUX_RGBImageRec *TextureImage[1]; //创建空间 memset(TextureImage,0,sizeof(void *)*1);//清除图像记录 if(TextureImage[0]=LoadBMP("vtr.bmp")) { Status=TRUE; glGenTextures(1,&texture[0]);//创建纹理 glBindTexture(GL_TEXTURE_2D,texture[0]);//绑定纹理 glTexImage2D(GL_TEXTURE_2D,0,3,TextureImage[0]->sizeX,TextureImage[0]->sizeY, 0,GL_RGB,GL_UNSIGNED_BYTE,TextureImage[0]->data); // 线形滤波 glTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MIN_FILTER,GL_LINEAR); // 线形滤波 glTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MAG_FILTER,GL_LINEAR); } if (TextureImage[0]) // 纹理是否存在 { if (TextureImage[0]->data)// 纹理图像是否存在 { // 释放纹理图像占用的内存 free(TextureImage[0]->data); } free(TextureImage[0]); // 释放图像结构 } return Status; } void handleKeyPressed(unsigned char key,int x,int y)//按键及鼠标坐标 { switch(key) { case 27:exit(0); } } //初始化3D视角 void initRendering() { glEnable(GL_DEPTH_TEST); } //窗口改变大小时调用 void handleResize(int w,int h) { glViewport(0,0,w,h); glMatrixMode(GL_PROJECTION); glLoadIdentity();//重设视角 gluPerspective(45.0,(double)w/(double)h,1.0,200.0); glEnable(GL_TEXTURE_2D); // 启用纹理映射 glShadeModel(GL_SMOOTH); // 启用阴影平滑 glClearColor(0.0f, 0.0f, 0.0f, 0.5f); // 黑色背景 glClearDepth(1.0f); // 设置深度缓存 glEnable(GL_DEPTH_TEST); // 启用深度测试 glDepthFunc(GL_LEQUAL); // 所作深度测试的类型 // 真正精细的透视修正 glHint(GL_PERSPECTIVE_CORRECTION_HINT, GL_NICEST); } //画图 void drawScence() { glClear(GL_COLOR_BUFFER_BIT|GL_DEPTH_BUFFER_BIT); glMatrixMode(GL_MODELVIEW); glLoadIdentity(); glTranslatef(0.0f, 0.0f, -5.0f); //Move forward 5 units glRotatef(_angle, 0.1f, 0.1f, 0.1f); //Rotate the camera glBindTexture(GL_TEXTURE_2D, texture[0]); // 选择纹理 glBegin(GL_QUADS); // 前面 glTexCoord2f(0.0f, 0.0f); glVertex3f(-1.0f, -1.0f, 1.0f); // 纹理和四边形的左下 glTexCoord2f(1.0f, 0.0f); glVertex3f( 1.0f, -1.0f, 1.0f); // 纹理和四边形的右下 glTexCoord2f(1.0f, 1.0f); glVertex3f( 1.0f, 1.0f, 1.0f); // 纹理和四边形的右上 glTexCoord2f(0.0f, 1.0f); glVertex3f(-1.0f, 1.0f, 1.0f); // 纹理和四边形的左上 // 后面 glTexCoord2f(1.0f, 0.0f); glVertex3f(-1.0f, -1.0f, -1.0f); // 纹理和四边形的右下 glTexCoord2f(1.0f, 1.0f); glVertex3f(-1.0f, 1.0f, -1.0f); // 纹理和四边形的右上 glTexCoord2f(0.0f, 1.0f); glVertex3f( 1.0f, 1.0f, -1.0f); // 纹理和四边形的左上 glTexCoord2f(0.0f, 0.0f); glVertex3f( 1.0f, -1.0f, -1.0f); // 纹理和四边形的左下 // 顶面 glTexCoord2f(0.0f, 1.0f); glVertex3f(-1.0f, 1.0f, -1.0f); // 纹理和四边形的左上 glTexCoord2f(0.0f, 0.0f); glVertex3f(-1.0f, 1.0f, 1.0f); // 纹理和四边形的左下 glTexCoord2f(1.0f, 0.0f); glVertex3f( 1.0f, 1.0f, 1.0f); // 纹理和四边形的右下 glTexCoord2f(1.0f, 1.0f); glVertex3f( 1.0f, 1.0f, -1.0f); // 纹理和四边形的右上 // 底面 glTexCoord2f(1.0f, 1.0f); glVertex3f(-1.0f, -1.0f, -1.0f); // 纹理和四边形的右上 glTexCoord2f(0.0f, 1.0f); glVertex3f( 1.0f, -1.0f, -1.0f); // 纹理和四边形的左上 glTexCoord2f(0.0f, 0.0f); glVertex3f( 1.0f, -1.0f, 1.0f); // 纹理和四边形的左下 glTexCoord2f(1.0f, 0.0f); glVertex3f(-1.0f, -1.0f, 1.0f); // 纹理和四边形的右下 // 右面 glTexCoord2f(1.0f, 0.0f); glVertex3f( 1.0f, -1.0f, -1.0f); // 纹理和四边形的右下 glTexCoord2f(1.0f, 1.0f); glVertex3f( 1.0f, 1.0f, -1.0f); // 纹理和四边形的右上 glTexCoord2f(0.0f, 1.0f); glVertex3f( 1.0f, 1.0f, 1.0f); // 纹理和四边形的左上 glTexCoord2f(0.0f, 0.0f); glVertex3f( 1.0f, -1.0f, 1.0f); // 纹理和四边形的左下 // 左面 glTexCoord2f(0.0f, 0.0f); glVertex3f(-1.0f, -1.0f, -1.0f); // 纹理和四边形的左下 glTexCoord2f(1.0f, 0.0f); glVertex3f(-1.0f, -1.0f, 1.0f); // 纹理和四边形的右下 glTexCoord2f(1.0f, 1.0f); glVertex3f(-1.0f, 1.0f, 1.0f); // 纹理和四边形的右上 glTexCoord2f(0.0f, 1.0f); glVertex3f(-1.0f, 1.0f, -1.0f); // 纹理和四边形的左上 glEnd(); glutSwapBuffers();//将3d图画放到窗口 } void updateAngle(int v) { _angle+=2.0f; if(_angle>360) { _angle-=360; } glutPostRedisplay(); glutTimerFunc(25,updateAngle,0); } int main(int argc,char** argv) { glutInit(&argc,argv); glutInitDisplayMode(GLUT_DOUBLE|GLUT_RGB|GLUT_DEPTH); glutInitWindowSize(500,500); //建立窗口 glutCreateWindow("我的三角形"); initRendering(); //gl的函数,实现具体绘制 glutDisplayFunc(drawScence); glutKeyboardFunc(handleKeyPressed); glutReshapeFunc(handleResize); glutTimerFunc(25,updateAngle,0); glutMainLoop(); return 0; }
通过assimp给OpenGL加载模型为什么显示模型为全黑?
我是根据网站learnopengl.com上的模型载入部分来学的。根据示例应该显示一个纳米服战士的模型。但是实际上只有一个黑色的模型,什么纹理细节都没有,我换了一个蜘蛛的模型也不行。这是为什么啊?是不是贴图丢失了?代码都是网站作者写的,我复制过来,模型是OBJ格式,可以正常生成就是模型全黑为什么啊,是不是我assimp库配置还有问题?
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 free -m 其中:m表示兆,也可以用g,注意都要小写 Men:表示物理内存统计 total:表示物理内存总数(total=used+free) use...
Vue + Spring Boot 项目实战(十四):用户认证方案与完善的访问拦截
本篇文章主要讲解 token、session 等用户认证方案的区别并分析常见误区,以及如何通过前后端的配合实现完善的访问拦截,为下一步权限控制的实现打下基础。
比特币原理详解
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入 假设现有4个人...
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发...
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 演示地点演示 html代码如下` music 这个年纪 七月的风 音乐 ` 然后就是css`*{ margin: 0; padding: 0; text-decoration: none; list-...
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。
数据库优化 - SQL优化
以实际SQL入手,带你一步一步走上SQL优化之路!
2019年11月中国大陆编程语言排行榜
2019年11月2日,我统计了某招聘网站,获得有效程序员招聘数据9万条。针对招聘信息,提取编程语言关键字,并统计如下: 编程语言比例 rank pl_ percentage 1 java 33.62% 2 cpp 16.42% 3 c_sharp 12.82% 4 javascript 12.31% 5 python 7.93% 6 go 7.25% 7 p...
通俗易懂地给女朋友讲:线程池的内部原理
餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”
经典算法(5)杨辉三角
杨辉三角 是经典算法,这篇博客对它的算法思想进行了讲解,并有完整的代码实现。
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹...
面试官:你连RESTful都不知道我怎么敢要你?
干货,2019 RESTful最贱实践
SQL-小白最佳入门sql查询一
不要偷偷的查询我的个人资料,即使你再喜欢我,也不要这样,真的不好;
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // doshom...
漫话:什么是平衡(AVL)树?这应该是把AVL树讲的最好的文章了
这篇文章通过对话的形式,由浅入深带你读懂 AVL 树,看完让你保证理解 AVL 树的各种操作,如果觉得不错,别吝啬你的赞哦。 1、若它的左子树不为空,则左子树上所有的节点值都小于它的根节点值。 2、若它的右子树不为空,则右子树上所有的节点值均大于它的根节点值。 3、它的左右子树也分别可以充当为二叉查找树。 例如: 例如,我现在想要查找数值为14的节点。由于二叉查找树的特性,我们可...
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,...
程序员:我终于知道post和get的区别
是一个老生常谈的话题,然而随着不断的学习,对于以前的认识有很多误区,所以还是需要不断地总结的,学而时习之,不亦说乎
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU...
开源并不是你认为的那些事
点击上方蓝字 关注我们开源之道导读所以 ————想要理清开源是什么?先要厘清开源不是什么,名正言顺是句中国的古代成语,概念本身的理解非常之重要。大部分生物多样性的起源,...
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1...
程序员把地府后台管理系统做出来了,还有3.0版本!12月7号最新消息:已在开发中有github地址
第一幕:缘起 听说阎王爷要做个生死簿后台管理系统,我们派去了一个程序员…… 996程序员做的梦: 第一场:团队招募 为了应对地府管理危机,阎王打算找“人”开发一套地府后台管理系统,于是就在地府总经办群中发了项目需求。 话说还是中国电信的信号好,地府都是满格,哈哈!!! 经常会有外行朋友问:看某网站做的不错,功能也简单,你帮忙做一下? 而这次,面对这样的需求,这个程序员...
网易云6亿用户音乐推荐算法
网易云音乐是音乐爱好者的集聚地,云音乐推荐系统致力于通过 AI 算法的落地,实现用户千人千面的个性化推荐,为用户带来不一样的听歌体验。 本次分享重点介绍 AI 算法在音乐推荐中的应用实践,以及在算法落地过程中遇到的挑战和解决方案。 将从如下两个部分展开: AI算法在音乐推荐中的应用 音乐场景下的 AI 思考 从 2013 年 4 月正式上线至今,网易云音乐平台持续提供着:乐屏社区、UGC...
【技巧总结】位运算装逼指南
位算法的效率有多快我就不说,不信你可以去用 10 亿个数据模拟一下,今天给大家讲一讲位运算的一些经典例子。不过,最重要的不是看懂了这些例子就好,而是要在以后多去运用位运算这些技巧,当然,采用位运算,也是可以装逼的,不信,你往下看。我会从最简单的讲起,一道比一道难度递增,不过居然是讲技巧,那么也不会太难,相信你分分钟看懂。 判断奇偶数 判断一个数是基于还是偶数,相信很多人都做过,一般的做法的代码如下...
《C++ Primer》学习笔记(六):C++模块设计——函数
专栏C++学习笔记 《C++ Primer》学习笔记/习题答案 总目录 https://blog.csdn.net/TeFuirnever/article/details/100700212 —————————————————————————————————————————————————————— 《C++ Primer》习题参考答案:第6章 - C++模块设计——函数 文章目录专栏C+...
8年经验面试官详解 Java 面试秘诀
作者 |胡书敏 责编 | 刘静 出品 | CSDN(ID:CSDNnews) 本人目前在一家知名外企担任架构师,而且最近八年来,在多家外企和互联网公司担任Java技术面试官,前后累计面试了有两三百位候选人。在本文里,就将结合本人的面试经验,针对Java初学者、Java初级开发和Java开发,给出若干准备简历和准备面试的建议。 Java程序员准备和投递简历的实...
面试官如何考察你的思维方式?
1.两种思维方式在求职面试中,经常会考察这种问题:北京有多少量特斯拉汽车?某胡同口的煎饼摊一年能卖出多少个煎饼?深圳有多少个产品经理?一辆公交车里能装下多少个乒乓球?一个正常成年人有多少根头发?这类估算问题,被称为费米问题,是以科学家费米命名的。为什么面试会问这种问题呢?这类问题能把两类人清楚地区分出来。一类是具有文科思维的人,擅长赞叹和模糊想象,它主要依靠的是人的第一反应和直觉,比如小孩...
so easy! 10行代码写个"狗屁不通"文章生成器
前几天,GitHub 有个开源项目特别火,只要输入标题就可以生成一篇长长的文章。 背后实现代码一定很复杂吧,里面一定有很多高深莫测的机器学习等复杂算法 不过,当我看了源代码之后 这程序不到50行 尽管我有多年的Python经验,但我竟然一时也没有看懂 当然啦,原作者也说了,这个代码也是在无聊中诞生的,平时撸码是不写中文变量名的, 中文...
知乎高赞:中国有什么拿得出手的开源软件产品?(整理自本人原创回答)
知乎高赞:中国有什么拿得出手的开源软件产品? 在知乎上,有个问题问“中国有什么拿得出手的开源软件产品(在 GitHub 等社区受欢迎度较好的)?” 事实上,还不少呢~ 本人于2019.7.6进行了较为全面的回答,对这些受欢迎的 Github 开源项目分类整理如下: 分布式计算、云平台相关工具类 1.SkyWalking,作者吴晟、刘浩杨 等等 仓库地址: apache/skywalking 更...
相关热词 c#选择结构应用基本算法 c# 收到udp包后回包 c#oracle 头文件 c# 序列化对象 自定义 c# tcp 心跳 c# ice连接服务端 c# md5 解密 c# 文字导航控件 c#注册dll文件 c#安装.net
立即提问