关于在linux下搞opengl的问题。

用虚拟机装了centos6.5基本服务版,然后写了一段opengl测试程序,GCC编译通过了,但是无法显示窗口。
后来又装了个做面版,把源代码拷贝过去编译通过运行也成功了,我想知道linux下运行opengl程序要依赖那些东西?Xwindown X server的资料没看的太懂。。。

好像没分了0.0

1个回答

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
linux下使用codeblocks学习OpenGL
我最近开始在linux下学习OpenGL,系统是CentOS,下载了OpenGL超级宝典第五版及源码,安装了mesa、glut、glew等依赖项,使用源码中提供的makefile编译源码能成功,可是我把GLTools文件夹拷到自己的工程文件夹下面,并设置了GLTools/include为搜索路径,也将GLTools/src下的文件都添加到了项目中,编译第一个源码的时候总是通不过,先是说GLenum、GLuint等类型没有定义,我改动了一下,将include glew.h之前的ifdefine给去掉了,结果又显示在glew.h之前包含了gl.h。。。。问题来了: 1、用make可以编译成功,是不是说明我机器上的基本配置没有问题? 2、我使用codeblocks开发,如何将书中的GLTools添加到我自己的项目中才能正确运行? 弄了两天了,快崩溃了,希望哪个兄弟来帮帮忙,再不行,只能回去用windows了。先谢谢了!
opengl linux 视频显示
求教:在 linux 环境下 使用 opengl 指定窗体上绘制连续的rgb数据。不用 opengl 自己创建的窗体
求助关于opengl鼠标的问题
怎样在vc2012下opengl实现鼠标控制方向?详细过程代码。新人求帮忙了,网上的教程不是很明白
一个关于opengl的视角的问题
一个OpenGL中可以建立两个摄像机吗?有不同的用途,其一是跟随物体的相机,第二个是我可以随时控制相机位置的相机,求大神指教
OpenGL ES3.0纹理贴图问题,贴图发生错误,无法显示贴图细节是怎么回事啊?
最近在学习OpenGL ES,按照书上教程尝试写了个demo,然后发现在纹理贴图这块遇到问题了,求助各位大佬 程序思路很简单,画5个点然后贴上纹理,但是纹理总是出现错误,下面是截图: ![图片说明](https://img-ask.csdn.net/upload/202002/12/1581502455_517510.jpg) 这个是要贴的纹理,大小为512 \*1024,另外正方形纹理我也试过同样不行 ![图片说明](https://img-ask.csdn.net/upload/202002/12/1581502536_603856.png) 接下来是代码: 首先是Render: ```java package com.example.firstopengl; import android.content.Context; import android.opengl.GLES30; import android.opengl.GLSurfaceView; import android.opengl.Matrix; import com.airhockey.android.objects.Mallet; import com.airhockey.android.objects.Table; import com.airhockey.android.programs.ColorShaderProgram; import com.airhockey.android.programs.TextureShaderProgram; import com.airhockey.android.util.MatrixHelper; import com.airhockey.android.util.TextureHelper; import javax.microedition.khronos.egl.EGLConfig; import javax.microedition.khronos.opengles.GL10; public class AirHockeyRender implements GLSurfaceView.Renderer { private final String TAG = "AirHockeyRender"; private final Context context; private final float[] projectionMatrix = new float[16]; private final float[] modelMatrix = new float[16]; private Table table; private Mallet mallet; private TextureShaderProgram textureShaderProgram; private ColorShaderProgram colorShaderProgram; private int texture; public AirHockeyRender(Context context){ this.context = context; } @Override public void onSurfaceCreated(GL10 gl, EGLConfig config) { GLES30.glClearColor(0.0f, 0.0f, 0.0f, 0.0f); table = new Table(); mallet = new Mallet(); textureShaderProgram = new TextureShaderProgram(context); colorShaderProgram = new ColorShaderProgram(context); texture = TextureHelper.loadTexture(context, R.drawable.air_hockey_surface); } @Override public void onDrawFrame(GL10 gl) { GLES30.glClear(GLES30.GL_COLOR_BUFFER_BIT); textureShaderProgram.useProgram(); textureShaderProgram.setUniforms(projectionMatrix, texture); table.bindData(textureShaderProgram); table.draw(); colorShaderProgram.useProgram(); colorShaderProgram.setUniform(projectionMatrix); mallet.bindData(colorShaderProgram); mallet.draw(); } @Override public void onSurfaceChanged(GL10 gl, int width, int height) { final float[] temp = new float[16]; //设置视口 GLES30.glViewport(0, 0, width, height); MatrixHelper.perspectiveM(projectionMatrix, 45, (float)width/(float)height, 1f, 10f); Matrix.setIdentityM(modelMatrix, 0); Matrix.translateM(modelMatrix, 0, 0f, 0f, -3.1f); Matrix.rotateM(modelMatrix, 0, -60f, 1f, 0f, 0f); Matrix.multiplyMM(temp, 0 ,projectionMatrix, 0, modelMatrix, 0); System.arraycopy(temp, 0, projectionMatrix, 0, temp.length); } } ``` 接下来是纹理生成相关 ``` package com.airhockey.android.util; import android.content.Context; import android.graphics.Bitmap; import android.graphics.BitmapFactory; import android.opengl.GLES30; import android.opengl.GLUtils; import android.util.Log; import com.airhockey.android.Constants; import java.io.ByteArrayOutputStream; import java.nio.ByteBuffer; import java.nio.ByteOrder; public class TextureHelper { private final static String TAG = "TextureHelper"; public static int loadTexture(Context context, int resourceId){ final int[] textureObject = new int[1]; GLES30.glGenTextures(1, textureObject, 0); if(textureObject[0]==0){ if(LoggerConfig.ON){ Log.w(TAG, "Could not generate a new OpenGL texture object"); } return 0; } final BitmapFactory.Options options = new BitmapFactory.Options(); //需要原始的图像数据,而不是缩放的版本 options.inScaled = false; //将图像转换为位图 final Bitmap bitmap = BitmapFactory.decodeResource(context.getResources(), resourceId, options); if(bitmap==null){ if(LoggerConfig.ON){ Log.w(TAG, "Resource ID"+resourceId+"could not be decoded"); } GLES30.glDeleteTextures(1, textureObject, 0); return 0; } //告诉opengl纹理调用使用此纹理 GLES30.glBindTexture(GLES30.GL_TEXTURE_2D, textureObject[0]); GLES30.glTexParameteri(GLES30.GL_TEXTURE_2D, GLES30.GL_TEXTURE_MIN_FILTER, GLES30.GL_LINEAR_MIPMAP_LINEAR); GLES30.glTexParameteri(GLES30.GL_TEXTURE_2D, GLES30.GL_TEXTURE_MAG_FILTER, GLES30.GL_LINEAR); GLES30.glTexParameterf(GLES30.GL_TEXTURE_2D, GLES30.GL_TEXTURE_WRAP_S, GLES30.GL_REPEAT); GLES30.glTexParameterf(GLES30.GL_TEXTURE_2D, GLES30.GL_TEXTURE_WRAP_T, GLES30.GL_REPEAT); //将位图加载至opengl中 GLUtils.texImage2D(GLES30.GL_TEXTURE_2D, 0, bitmap, 0); //加载后释放位图,解除绑定 bitmap.recycle(); //生成mip贴图 GLES30.glGenerateMipmap(GLES30.GL_TEXTURE_2D); GLES30.glBindTexture(GLES30.GL_TEXTURE_2D, 0); return textureObject[0]; } } ``` 然后是画的物体: ``` package com.airhockey.android.objects; import android.opengl.GLES30; import com.airhockey.android.Constants; import com.airhockey.android.data.VertexArray; import com.airhockey.android.programs.TextureShaderProgram; public class Table { private static final int POSITION_COMPONENT_COUNT = 2; private static final int TEXTURE_COORDINATES_COMPONENT_COUNT = 2; private static final int STRIDE = (POSITION_COMPONENT_COUNT+TEXTURE_COORDINATES_COMPONENT_COUNT) * Constants.BYTE_PER_FLOAT; private final VertexArray vertexArray; private static final float[] VERTEX_DATA = { //x,y,s,t //三角扇区 0f, 0f, 0.5f, 0.5f, -0.5f, -0.8f, 0.0f, 1.0f, 0.5f, -0.8f, 1.0f, 1.0f, 0.5f, 0.8f, 1.0f, 0.0f, -0.5f, 0.8f, 0.0f, 0.0f, -0.5f, -0.8f, 0.0f, 1.0f // -0.5f, -0.8f, 0f, 1f, // -0.5f, 0.8f, 0f, 0f, // 0.5f, -0.8f, 1f, 1f, // // -0.5f, 0.8f, 0f, 0f, // 0.5f, -0.8f, 1f, 1f, // 0.5f, 0.8f, 1f, 0f }; public Table(){ vertexArray = new VertexArray(VERTEX_DATA); } public void bindData(TextureShaderProgram textureProgram){ vertexArray.setVertexAttribPointer(0, textureProgram.getPositonAttributeLocation(), POSITION_COMPONENT_COUNT, STRIDE); vertexArray.setVertexAttribPointer(POSITION_COMPONENT_COUNT, textureProgram.getTextureCoordinatesAttributeLocation(), TEXTURE_COORDINATES_COMPONENT_COUNT, STRIDE); } public void draw(){ GLES30.glDrawArrays(GLES30.GL_TRIANGLE_FAN, 0, 6); } } ``` 头真的大,研究了好久都没研究出来怎么回事
Linux 下编译c++ opengl的小程序
完整的代码如下 ``` #include <GL/glut.h> #include <cmath> #include <utility> #include <vector> using std::vector; using std::pair; vector<pair<int, int> > my_points(4); vector<pair<int, int> > current_point(4); my_points.push_back(make_pair(0, 0)); my_points.push_back(make_pair(50, 0)); my_points.push_back(make_pair(100, 0)); my_points.push_back(make_pair(150, 0)); current_point = my_points; struct Degree { Degree(int a, int b, int c) { first = a; second = b; third = c; } int first; int second; int third; }; map<int, Degree> position(4); position[0] = position(0, 0, 0); position[1] = position(90, 0, 0); position[2] = position(45, -45, 45); position[3] = position(-90, 0, 0); void init(); void display(); void draw_axis(); void reshape(int w, int h); void draw_frame(void); void translate(Degree& posi); void keyboard(unsigned char key, int x, int y); float matrix_rotat[3][3] = { // 旋转矩阵 {0.0, -1.0, 0.0}, {1.0, 0.0, 0.0}, {0.0, 0.0, 1.0} }; int main(int argc, char* argv[]) { glutInit(&argc, argv); glutInitDisplayMode(GLUT_SINGLE|GLUT_RGB); glutInitWindowSize(500, 500); glutInitWindowPosition(0, 0); glutCreateWindow(argv[0]); init(); glutDisplayFunc(display); glutReshapeFunc(reshape); glutKeyboardFunc(keyboard); glutMainLoop(); } void init(void) { glClearColor(0.1, 0.2, 0.4, 0.0); glShadeModel (GL_SMOOTH); } void reshape (int w, int h) { glViewport (0, 0, (GLsizei) w, (GLsizei) h); glMatrixMode (GL_PROJECTION); glLoadIdentity (); if (w <= h) gluOrtho2D(-200.0, 250.0, -100.0*(GLfloat)h/(GLfloat)w, 200.0*(GLfloat)h/(GLfloat)w); else gluOrtho2D(-200.0*(GLfloat)w/(GLfloat)h, 250.0*(GLfloat)w/(GLfloat)h, -50.0, 200.0); glColor3f(1, 0.5, 0.4); glMatrixMode(GL_MODELVIEW); } void display() { glClear(GL_COLOR_BUFFER_BIT); glColor3f(1, 0.5, 0.4); draw_axis(); glLoadIdentity(); // draw_frame(); glFlush (); } void draw_frame() { glShadeModel(GL_SMOOTH); glBegin (GL_LINE_STRIP);//draw frame for (int i = 0; i < 4; i++) { glColor3f(1.0, 0.0, 0.0); glVertex2f(current_point[i].first, current_point[i].second); } glEnd(); } void draw_axis() { // draw coordinate axis glBegin(GL_LINES); glColor3f(1.0, 1.0, 1.0); // x axis glVertex2f(-500.0, 40.0); glVertex2f(500.0, 40.0); glColor3f(1.0, 1.0, 1.0); // y axis glVertex2f(0.0, 400.0); glVertex2f(0.0, -400.0); glEnd(); // draw scale glBegin(GL_LINES); for (int i = -50; i <= 50; i++) { // x axis glColor3f(1.0, 1.0, 1.0); glVertex2f(10.0*i, 40.0); glVertex2f(10.0*i, 44.0); } for (int i = -40; i <= 40; i++) { // y axis glColor3f(1.0, 1.0, 1.0); glVertex2f(0.0, 10.0*i); glVertex2f(4.0, 10.0*i); } glEnd(); } void translate(Degree& posi) { ///// changed into matrix later vector<vector<double> > trans_matrix(2); for (int i = 0; i < 2; i++) for (int j = 0; j < 2; j++) trans_matrix[i].push_back(0); double num1[] = {cos(posi.first), -sin(posi.first)}; //initialize the transform matrix for (int i = 0; i < 2; i++) trans_matrix[0][i] = num1[i]; double num2 = {sin(posi.first), cos(posi.first)}; for (int i = 0; i < 2; i++) trans_matrix[1][i] = num2[i]; current_point[0].first = current_point[0].second = 0; for (int i = 0; i < 2; i++) { current_point[0].first += (trans_matrix[i][0]*my_points[0].first + trans_matrix[i][1]*my_points[1].second); current_point[0].second += (trans_matrix[i][0]*my_points[0].first + trans_matrix[i][1]*my_points[0].second); } glBegin (GL_LINES);//draw frame glColor3f(1.0, 0.0, 0.0); glVertex2f(0, 0); glVertex2f(current_point[0].first, current_point[0].second); glEnd(); } /* void rotate_frame(void) { float (*tmp_frame)[7] = new float[3][7]; memset(tmp_frame, 0.0, sizeof(tmp_frame)); frame = tmp_frame; glLoadIdentity(); draw_frame(); // draw the frame after transformation glFlush(); } */ void keyboard(unsigned char key, int x, int y) { switch (key) { case 'Q': case 'q': translate(position[0]); break; case 'W': case 'w': translate(position[1]); break; case 'E': case 'e': translate(position[2]); break; case 'R': case 'r': translate(position[3]); break; } } ``` 编译器报错> arm.cpp:12:1: error: ‘my_points’ does not name a type my_points.push_back(make_pair(0, 0)); ^ arm.cpp:13:1: error: ‘my_points’ does not name a type my_points.push_back(make_pair(50, 0)); ^ arm.cpp:14:1: error: ‘my_points’ does not name a type my_points.push_back(make_pair(100, 0)); ^ arm.cpp:15:1: error: ‘my_points’ does not name a type my_points.push_back(make_pair(150, 0)); ^ arm.cpp:16:1: error: ‘current_point’ does not name a type current_point = my_points; ^ arm.cpp:28:1: error: ‘map’ does not name a type map<int, Degree> position(4); ^ arm.cpp:30:1: error: ‘position’ does not name a type position[0] = position(0, 0, 0); ^ arm.cpp:31:1: error: ‘position’ does not name a type position[1] = position(90, 0, 0); ^ arm.cpp:32:1: error: ‘position’ does not name a type position[2] = position(45, -45, 45); ^ arm.cpp:33:1: error: ‘position’ does not name a type position[3] = position(-90, 0, 0); ^ 不知道这里是什么问题,STL为什么不能用,是编译选项的问题吗? 编译命令g++ arm.cpp -o arm -lGL -lglut -lGLU
关于调用OpenGL的math3d库的问题
我想用Tao框架调用OpenGL,但是发现Tao框架里好像不含有OpenGL里的math3d库和shadermanager库, 请问怎么才能调用这两个库呢?或者我下载了math3d库的math3d.h和math3d.cpp, 我通过生成这两个文件的dll在C#中调用,这样可行吗?
一个关于opengl的问题
具体错误说明如下: 2017-03-31 10:12:23.909523+0800 opengl[6662:327498] [General] ERROR: Setting <GLFWContentView: 0x100303f80> as the first responder for window <GLFWWindow: 0x102a1b800>, but it is in a different window ((null))! This would eventually crash when the view is freed. The first responder will be set to nil. 程序代码如下: #include <glew.h> #include <glfw3.h> #include <iostream> using namespace std; int main() { glfwInit(); glfwWindowHint(GLFW_CONTEXT_VERSION_MAJOR, 3); glfwWindowHint(GLFW_CONTEXT_VERSION_MINOR, 3); glfwWindowHint(GLFW_OPENGL_PROFILE, GLFW_OPENGL_CORE_PROFILE); glfwWindowHint(GLFW_RESIZABLE, GL_FALSE); GLFWwindow* window = glfwCreateWindow(800, 600, "LearnOpenGL", nullptr, nullptr); if (window == nullptr) { cout << "Failed to create GLFW window" << endl; glfwTerminate(); return -1; } glfwMakeContextCurrent(window); } 新手刚跟着教程学opengl,所以看不懂这个错误说明到底是什么意思,希望有大佬赐教 编译器是xcode,系统是macOS Sierra 10.2.4
openGL关于圆柱的一些问题?
我最近正在学习OpenGL底层的一些东西,有这么一句话我不理解,请高手帮忙解释一下,如下: 一个圆柱体的侧面是一个卷起来的长方形,由一个三角形带构造,围着顶部圆的每个点都需要两个顶点,并且前两个顶点要重复两次才能使这个管闭合。 “围着顶部圆的每个点都需要两个顶点”就这句为什么要两个顶点?
关于OpenGL矩阵变换的问题
如题,小弟有一个初级问题想请教,OpenGL中矩阵堆栈的最大深度是什么概念呢?希望高手可以用通俗的语言表达。另外,我在用OpenGL绘制装配体的时候,画完之前的装配体后(这个装配体包含在了压栈和出栈之间),再画下一个装配体的时候,进行平移变换时,发现变换的方向是按照上一个装配体中最后绘制零件的局部坐标系的方向进行的,但是对场景进行旋转操作时,第二个绘制的装配体的位置就发生了变化,其变化方向是按照原点坐标系的方向进行的,每次都是这样,也就是说,场景刚生成时第二个装配体在一个位置上,对场景旋转,第二个装配体就跑到另一个位置,此后再怎么旋转场景,第二个装配体的位置也不会发生变化。请问这是怎么回事?求高手解答
openGL 图形的问题
Problem Description Jiaoshou selected a course about “openGL” this semester. He was quite interested in modelview, which is a part of “openGL”. Just using three functions, it could make the model to move, rotate and largen or lessen. But he was puzzled with the theory of the modelview. He didn’t know a vertex after several transformations where it will be. Now, He tells you the position of the vertex and the transformations. Please help Jiaoshou find the position of the vertex after several transformations. Input The input will start with a line giving the number of test cases, T. Each case will always begin with “glBegin(GL_POINTS);”.Then the case will be followed by 5 kinds of function. 1. glTranslatef(x,y,z); This function will translate the vertex(x’,y’,z’) to vertex(x+x’,y+y’,z+z’). 2. glRotatef(angle,x,y,z); This function will turn angle radians counterclockwise around the axis (0,0,0)->(x,y,z). 3. glScalef(x,y,z); This function wiil translate the vertex(x’,y’,z’) to vertex(x*x’,y*y’,z*z’). 4. glVertex3f(x,y,z); This function will draw an initial vertex at the position(x,y,z). It will only appear once in one case just before “glEnd();”. In openGL, the transformation matrices are right multiplied by vertex matrix. So you should do the transformations in the reverse order. 5. glEnd(); This function tells you the end of the case. In this problem angle,x,y,z are real numbers and range from -50.0 to 50.0. And the number of functions in each case will not exceed 100. Output For each case, please output the position of the vertex after several transformations x,y,z in one line rounded to 1 digits after the decimal point , separated with a single space. We guarantee that x,y,z are not very large. Sample Input 1 glBegin(GL_POINTS); glScalef(2.0,0.5,3.0); glTranslatef(0.0,1.0,0.0); glVertex3f(1.0,1.0,1.0); glEnd(); Sample Output 2.0 1.0 3.0
OpenGL模型导入中关于材质的问题。
最近在根据Learn OpenGL学OpenGL。在通过Assimp加载.OBJ文件模型时,在.mtl文件中保存有下面的所示材质信息。 newmtl Arm Ns 96.078431 Ka 0.000000 0.000000 0.000000 Kd 0.640000 0.640000 0.640000 Ks 0.500000 0.500000 0.500000 Ni 1.000000 d 1.000000 illum 2 map_Kd arm_dif.png map_Bump arm_showroom_ddn.png map_Ks arm_showroom_spec.png Learn OpenGL 只处理了纹理映射部分,但是没有处理材质颜色Ka,Kd,Ks这些部分,我在网上下载的一些模型有的没有纹理映射,只有材质颜色Ka,Kd,Ks。 所以我现在不知道当只有材质颜色Ka,Kd,Ks时要怎么处理,而两者都有时又要怎么处理。 刚刚学习OpenGL,可能这个问题问的比较蠢,希望大家见谅。
关于用Opengl中NURBS画出圆柱面后的裁剪问题
首先用相应的控制点、节点等画出圆柱面(不裁剪),结果是正确的,如图所示: ![图片说明](https://img-ask.csdn.net/upload/202001/03/1578021922_478530.png) 但当我通过以下的裁剪代码进行裁剪后,却出现了我不能理解的结果,裁剪代码以及裁剪结果如下图: ``` GLfloat outSidePts[5][2] = { {0.0f, 0.0f} ,{1.0f, 0.0f}, {1.0f, 1.0f},{0.0f, 1.0f}, {0.0f, 0.0f} }; gluBeginTrim(theNurbs); gluPwlCurve(theNurbs, 5, //修剪点的个数 &outSidePts[0][0], //修剪点数组 2, //点之间的间隔 GLU_MAP1_TRIM_2);//修剪的类型 gluEndTrim(theNurbs); ``` ![图片说明](https://img-ask.csdn.net/upload/202001/03/1578021995_755222.png) 我的理解是,因为我裁剪的是整个UV参数域,从0到1,按道理说应该与裁剪前结果是一样的,但是结果却出现了多余线条,这是为什么?求大神解答
请教opengl学内容的问题
各位大牛,小白刚学图形处理方面的东西,想学学opengl,找到了opengl超级宝典,但是它一上来是花了很大篇幅来讲固定管线的东西,听说这玩意儿现在不怎么用,不知道还要学么?有没有opengl教学书籍是直接将着色器的? 请有经验的大神们给点建议,谢谢!
请教大神关于OpenGL的问题,恳求大神指教
![图片说明](https://img-ask.csdn.net/upload/201703/22/1490146548_810003.png) 初学OpenGL编程,需要写一个设计 ,但是出现这样的问题,找了好多资料都是那种操作命令的解决办法,放在Windows,VS环境下不会解决.恳请大神帮帮忙. 实在没办法才麻烦大神的 ,希望帖子不要沉
opengl es绘制纹理的问题
为什么我绘制的纹理总是在屏幕的右上角,我怎么才能才纹理的中心点位于opengl的原点呢。
OpenGL绘图颜色设置无效(MFC环境下)
用MFC做了一个小程序,大致功能是先显示一个读入的图形,然后在条件变化时显示另一个图形,最初的显示是正常的,然后消息处理函数也没问题,自定义了一个draw函数如下 void CReadView::Draw(){ glClearColor(1.0, 1.0,1.0, 0.0); glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); // Clear Screen And Depth Buffer glEnable(GL_COLOR_MATERIAL); glLoadIdentity(); // Reset The Current Modelview Matrix glTranslatef(-1.5f, 0.0f, -6.0f);//物体左移1.5,向内移6,相当于移动镜头一样,让物体进入镜头中 glColor3f(1.0, 0.0, 0.0); glBegin(GL_TRIANGLES); // 绘制三角形(逆时针画出来的三角形才是正面朝着我们的) glVertex3f(-1.0, -1.0, 0.0); // 左下顶点(//glVertex 的第一个参数是X坐标,然后依次是Y坐标和Z坐标) glVertex3f(1.0, -1.0, 0.0); // 右下顶点 glVertex3f(0.0, 1.0, 0.0); // 上顶点 glEnd(); // 三角形绘制结束 glColor3f(0.4, 0.75, 1.0); glRectf(1.5f, 1.5f, 2.5f, 2.5f); glLineWidth(3); glBegin(GL_LINES); glColor3f(1.0, 0.0, 0.0); glVertex2f(3.0f, 0.0f); glVertex2f(3.5f, 0.0f); //在这里使用glVertex*系列函数 指定你所希望的顶点位置 glEnd(); glLineWidth(1); glColor3f(1.0f, 1.0f, 0.0f); glBegin(GL_LINES); glVertex3f(-3.0f, 2.0f, 3.0f); glVertex3f(3.0f, 1.0f, 0.0f); glEnd(); glColor3f(1.0f,0.0f,0.0f); glBegin(GL_LINES); glVertex2i(1, 1); glVertex2i(3, 3); glEnd(); glFlush(); } 把它放到的OnDraw函数里进行调用,程序可以正常执行,只是画出来的这些线段、图形都没有颜色(是默认的黑色),也就是glColor3f似乎失效了。 这些绘制的函数都是从网上找来做测试的,在正常单独的OpenGL环境里应该也都是没问题的。是MFC的问题吗?或者是OpenGL需要某些重新的预设置?求解答
向opengl传递的坐标数据都是在-1到1之间的,这个数据是要自己计算吗?
因为opengl中坐标范围都是在-1到1之间,所有示例程序在输入数据的时候都是直接固定为常数且都在-1到1之间。那假如我在一个1000到-1000的范围内作图,画一个500宽度的正方体,这个正方体的坐标是(0,0,0)和(500,500,500)之间,那么(500,500,500)这个坐标值怎么转换到-1和1之间?这个是自己实现还是直接提交给opengl让opengl来实现?
OpenGL 默认的Z轴方向问题
OpenGL默认的Z坐标轴的方向是垂直窗口向外的,以前用C语言开发OpenGL程序时一直没有出现问题。现在我用C#开发OpenGL程序,却发现默认的Z轴方向是垂直窗口向内,真的搞不懂怎么回事。我没有使用模型变换和投影变换,仅仅是是在窗口绘制两个简单的图形,发现Z坐标为负的图形可以看得见,而Z坐标为正的图形却被覆盖。已经开启了深度测试。代码如下: ``` void Draw() { GL.glEnable(GLCONST.GL_DEPTH_TEST); GL.glClear(GLCONST.GL_COLOR_BUFFER_BIT); GL.glClear(GLCONST.GL_DEPTH_BUFFER_BIT); //红色的三角形,Z=0; GL.glBegin(GLCONST.GL_TRIANGLES); GL.glColor3(1f, 0f, 0f); GL.glVertex3(-0.5f, -0.5f,0f); GL.glVertex3(0.5f, -0.5f,0f); GL.glVertex3(0f, 0.5f,0f); GL.glEnd(); //绿色的直线,Z=-0.5 GL.glColor3(0f, 1f, 0f); GL.glBegin(GLCONST.GL_LINES); GL.glVertex3(-0.8f, 0f, -0.5f); GL.glVertex3(0.8f, 0f, -0.5f); GL.glEnd(); //蓝色的直线,Z=0.5 GL.glColor3(0f, 0f, 1f); GL.glBegin(GLCONST.GL_LINES); GL.glVertex3(0f, 0.8f, 0.5f); GL.glVertex3(0f, -0.8f, 0.5f); GL.glEnd(); GL.glFlush(); } ``` 绘制时,发现红色的三角形(Z=0)会把蓝色的直线(Z=0.5)掩盖,而绿色的直线(Z=-0.5)浮在三角形之上。效果如下图: ![图片说明](https://img-ask.csdn.net/upload/201712/28/1514439525_203737.jpg) 这种问题,似乎有不少人遇到,但都没有的到很好的解决。特此悬赏160金币,希望有人能解决。只要提供解决的方法,或者给予启示,或者提供线索都可以获得悬赏。
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小人工智障。 思路可以运用在不同地方,主要介绍的是思路。
Linux(服务器编程):15---两种高效的事件处理模式(reactor模式、proactor模式)
前言 同步I/O模型通常用于实现Reactor模式 异步I/O模型则用于实现Proactor模式 最后我们会使用同步I/O方式模拟出Proactor模式 一、Reactor模式 Reactor模式特点 它要求主线程(I/O处理单元)只负责监听文件描述符上是否有事件发生,有的话就立即将时间通知工作线程(逻辑单元)。除此之外,主线程不做任何其他实质性的工作 读写数据,接受新的连接,以及处...
为什么要学数据结构?
一、前言 在可视化化程序设计的今天,借助于集成开发环境可以很快地生成程序,程序设计不再是计算机专业人员的专利。很多人认为,只要掌握几种开发工具就可以成为编程高手,其实,这是一种误解。要想成为一个专业的开发人员,至少需要以下三个条件: 1) 能够熟练地选择和设计各种数据结构和算法 2) 至少要能够熟练地掌握一门程序设计语言 3) 熟知所涉及的相关应用领域的知识 其中,后两个条件比较容易实现,而第一个...
C语言魔塔游戏
很早就很想写这个,今天终于写完了。 游戏截图: 编译环境: VS2017 游戏需要一些图片,如果有想要的或者对游戏有什么看法的可以加我的QQ 2985486630 讨论,如果暂时没有回应,可以在博客下方留言,到时候我会看到。 下面我来介绍一下游戏的主要功能和实现方式 首先是玩家的定义,使用结构体,这个名字是可以自己改变的 struct gamerole { char n
进程通信方式总结与盘点
​ 进程通信是指进程之间的信息交换。这里需要和进程同步做一下区分,进程同步控制多个进程按一定顺序执行,进程通信是一种手段,而进程同步是目标。从某方面来讲,进程通信可以解决进程同步问题。 ​ 首先回顾下我们前面博文中讲到的信号量机制,为了实现进程的互斥与同步,需要在进程间交换一定的信息,因此信号量机制也可以被归为进程通信的一种方式,但是也被称为低级进程通信,主要原因为: 效率低:一次只可操作少量的...
究竟你适不适合买Mac?
我清晰的记得,刚买的macbook pro回到家,开机后第一件事情,就是上了淘宝网,花了500元钱,找了一个上门维修电脑的师傅,上门给我装了一个windows系统。。。。。。 表砍我。。。 当时买mac的初衷,只是想要个固态硬盘的笔记本,用来运行一些复杂的扑克软件。而看了当时所有的SSD笔记本后,最终决定,还是买个好(xiong)看(da)的。 已经有好几个朋友问我mba怎么样了,所以今天尽量客观
听说了吗?阿里双11作战室竟1根网线都没有
双11不光是购物狂欢节,更是对技术的一次“大考”,对于阿里巴巴企业内部运营的基础保障技术而言,亦是如此。 回溯双11历史,这背后也经历过“小米加步枪”的阶段:作战室从随处是网线,交换机放地上的“一地狼藉”;到如今媲美5G的wifi网速,到现场却看不到一根网线;从当年使用商用AP(无线路由器),让光明顶双11当天断网一分钟,到全部使用阿里自研AP……阿里巴巴企业智能事业部工程师们提供的基础保障...
在阿里,40岁的奋斗姿势
在阿里,40岁的奋斗姿势 在阿里,什么样的年纪可以称为老呢?35岁? 在云网络,有这样一群人,他们的平均年龄接近40,却刚刚开辟职业生涯的第二战场。 他们的奋斗姿势是什么样的呢? 洛神赋 “翩若惊鸿,婉若游龙。荣曜秋菊,华茂春松。髣髴兮若轻云之蔽月,飘飖兮若流风之回雪。远而望之,皎若太阳升朝霞;迫而察之,灼若芙蕖出渌波。” 爱洛神,爱阿里云 2018年,阿里云网络产品部门启动洛神2.0升...
关于研发效能提升的思考
研发效能提升是最近比较热门的一个话题,本人根据这几年的工作心得,做了一些思考总结,由于个人深度有限,暂且抛转引入。 三要素 任何生产力的提升都离不开这三个因素:人、流程和工具,少了其中任何一个因素都无法实现。 人,即思想,也就是古人说的“道”,道不同不相为谋,是制高点,也是高层建筑的基石。 流程,即方法,也是古人说的“法”。研发效能的提升,也就是要提高投入产出比,既要增加产出,也要减...
Python爬虫爬取淘宝,京东商品信息
小编是一个理科生,不善长说一些废话。简单介绍下原理然后直接上代码。 使用的工具(Python+pycharm2019.3+selenium+xpath+chromedriver)其中要使用pycharm也可以私聊我selenium是一个框架可以通过pip下载 pip install selenium -i https://pypi.tuna.tsinghua.edu.cn/simple/ 
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
Java工作4年来应聘要16K最后没要,细节如下。。。
前奏: 今天2B哥和大家分享一位前几天面试的一位应聘者,工作4年26岁,统招本科。 以下就是他的简历和面试情况。 基本情况: 专业技能: 1、&nbsp;熟悉Sping了解SpringMVC、SpringBoot、Mybatis等框架、了解SpringCloud微服务 2、&nbsp;熟悉常用项目管理工具:SVN、GIT、MAVEN、Jenkins 3、&nbsp;熟悉Nginx、tomca
2020年,冯唐49岁:我给20、30岁IT职场年轻人的建议
点击“技术领导力”关注∆  每天早上8:30推送 作者| Mr.K   编辑| Emma 来源| 技术领导力(ID:jishulingdaoli) 前天的推文《冯唐:职场人35岁以后,方法论比经验重要》,收到了不少读者的反馈,觉得挺受启发。其实,冯唐写了不少关于职场方面的文章,都挺不错的。可惜大家只记住了“春风十里不如你”、“如何避免成为油腻腻的中年人”等不那么正经的文章。 本文整理了冯
程序员该看的几部电影
##1、骇客帝国(1999) 概念:在线/离线,递归,循环,矩阵等 剧情简介: 不久的将来,网络黑客尼奥对这个看似正常的现实世界产生了怀疑。 他结识了黑客崔妮蒂,并见到了黑客组织的首领墨菲斯。 墨菲斯告诉他,现实世界其实是由一个名叫“母体”的计算机人工智能系统控制,人们就像他们饲养的动物,没有自由和思想,而尼奥就是能够拯救人类的救世主。 可是,救赎之路从来都不会一帆风顺,到底哪里才是真实的世界?
入职阿里5年,他如何破解“技术债”?
简介: 作者 | 都铎 作为一名技术人,你常常会听到这样的话: “先快速上线” “没时间改” “再缓一缓吧” “以后再解决” “先用临时方案处理” …… 当你埋下的坑越来越多,不知道哪天哪位同学就会踩上一颗雷。特别赞同“人最大的恐惧就是未知,当技术债可说不可见的时候,才是最让人不想解决的时候。” 作为一个程序员,我们反对复制粘贴,但是我们经常会见到相似的代码,相同的二方包,甚至整个代码...
Python绘图,圣诞树,花,爱心 | Turtle篇
每周每日,分享Python实战代码,入门资料,进阶资料,基础语法,爬虫,数据分析,web网站,机器学习,深度学习等等。 公众号回复【进群】沟通交流吧,QQ扫码进群学习吧 微信群 QQ群 1.画圣诞树 import turtle screen = turtle.Screen() screen.setup(800,600) circle = turtle.Turtle()...
作为一个程序员,CPU的这些硬核知识你必须会!
CPU对每个程序员来说,是个既熟悉又陌生的东西? 如果你只知道CPU是中央处理器的话,那可能对你并没有什么用,那么作为程序员的我们,必须要搞懂的就是CPU这家伙是如何运行的,尤其要搞懂它里面的寄存器是怎么一回事,因为这将让你从底层明白程序的运行机制。 随我一起,来好好认识下CPU这货吧 把CPU掰开来看 对于CPU来说,我们首先就要搞明白它是怎么回事,也就是它的内部构造,当然,CPU那么牛的一个东
破14亿,Python分析我国存在哪些人口危机!
2020年1月17日,国家统计局发布了2019年国民经济报告,报告中指出我国人口突破14亿。 猪哥的朋友圈被14亿人口刷屏,但是很多人并没有看到我国复杂的人口问题:老龄化、男女比例失衡、生育率下降、人口红利下降等。 今天我们就来分析一下我们国家的人口数据吧! 一、背景 1.人口突破14亿 2020年1月17日,国家统计局发布了 2019年国民经济报告 ,报告中指出:年末中国大陆总人口(包括31个
在家远程办公效率低?那你一定要收好这个「在家办公」神器!
相信大家都已经收到国务院延长春节假期的消息,接下来,在家远程办公可能将会持续一段时间。 但是问题来了。远程办公不是人在电脑前就当坐班了,相反,对于沟通效率,文件协作,以及信息安全都有着极高的要求。有着非常多的挑战,比如: 1在异地互相不见面的会议上,如何提高沟通效率? 2文件之间的来往反馈如何做到及时性?如何保证信息安全? 3如何规划安排每天工作,以及如何进行成果验收? ......
作为一个程序员,内存和磁盘的这些事情,你不得不知道啊!!!
截止目前,我已经分享了如下几篇文章: 一个程序在计算机中是如何运行的?超级干货!!! 作为一个程序员,CPU的这些硬核知识你必须会! 作为一个程序员,内存的这些硬核知识你必须懂! 这些知识可以说是我们之前都不太重视的基础知识,可能大家在上大学的时候都学习过了,但是嘞,当时由于老师讲解的没那么有趣,又加上这些知识本身就比较枯燥,所以嘞,大家当初几乎等于没学。 再说啦,学习这些,也看不出来有什么用啊!
2020年的1月,我辞掉了我的第一份工作
其实,这篇文章,我应该早点写的,毕竟现在已经2月份了。不过一些其它原因,或者是我的惰性、还有一些迷茫的念头,让自己迟迟没有试着写一点东西,记录下,或者说是总结下自己前3年的工作上的经历、学习的过程。 我自己知道的,在写自己的博客方面,我的文笔很一般,非技术类的文章不想去写;另外我又是一个还比较热衷于技术的人,而平常复杂一点的东西,如果想写文章写的清楚点,是需要足够...
别低估自己的直觉,也别高估自己的智商
所有群全部吵翻天,朋友圈全部沦陷,公众号疯狂转发。这两周没怎么发原创,只发新闻,可能有人注意到了。我不是懒,是文章写了却没发,因为大家的关注力始终在这次的疫情上面,发了也没人看。当然,我...
Java坑人面试题系列: 包装类(中级难度)
Java Magazine上面有一个专门坑人的面试题系列: https://blogs.oracle.com/javamagazine/quiz-2。 这些问题的设计宗旨,主要是测试面试者对Java语言的了解程度,而不是为了用弯弯绕绕的手段把面试者搞蒙。 如果你看过往期的问题,就会发现每一个都不简单。 这些试题模拟了认证考试中的一些难题。 而 “中级(intermediate)” 和 “高级(ad
深度学习入门笔记(十八):卷积神经网络(一)
欢迎关注WX公众号:【程序员管小亮】 专栏——深度学习入门笔记 声明 1)该文章整理自网上的大牛和机器学习专家无私奉献的资料,具体引用的资料请看参考文献。 2)本文仅供学术交流,非商用。所以每一部分具体的参考资料并没有详细对应。如果某部分不小心侵犯了大家的利益,还望海涵,并联系博主删除。 3)博主才疏学浅,文中如有不当之处,请各位指出,共同进步,谢谢。 4)此属于第一版本,若有错误,还需继续修正与...
这个世界上人真的分三六九等,你信吗?
偶然间,在知乎上看到一个问题 一时间,勾起了我深深的回忆。 以前在厂里打过两次工,做过家教,干过辅导班,做过中介。零下几度的晚上,贴过广告,满脸、满手地长冻疮。 再回首那段岁月,虽然苦,但让我学会了坚持和忍耐。让我明白了,在这个世界上,无论环境多么的恶劣,只要心存希望,星星之火,亦可燎原。 下文是原回答,希望能对你能有所启发。 如果我说,这个世界上人真的分三六九等,...
节后首个工作日,企业们集体开晨会让钉钉挂了
By 超神经场景描述:昨天 2 月 3 日,是大部分城市号召远程工作的第一天,全国有接近 2 亿人在家开始远程办公,钉钉上也有超过 1000 万家企业活跃起来。关键词:十一出行 人脸...
Java基础知识点梳理
Java基础知识点梳理 摘要: 虽然已经在实际工作中经常与java打交道,但是一直没系统地对java这门语言进行梳理和总结,掌握的知识也比较零散。恰好利用这段时间重新认识下java,并对一些常见的语法和知识点做个总结与回顾,一方面为了加深印象,方便后面查阅,一方面为了学好java打下基础。 Java简介 java语言于1995年正式推出,最开始被命名为Oak语言,由James Gosling(詹姆
2020年全新Java学习路线图,含配套视频,学完即为中级Java程序员!!
新的一年来临,突如其来的疫情打破了平静的生活! 在家的你是否很无聊,如果无聊就来学习吧! 世上只有一种投资只赚不赔,那就是学习!!! 传智播客于2020年升级了Java学习线路图,硬核升级,免费放送! 学完你就是中级程序员,能更快一步找到工作! 一、Java基础 JavaSE基础是Java中级程序员的起点,是帮助你从小白到懂得编程的必经之路。 在Java基础板块中有6个子模块的学
B 站上有哪些很好的学习资源?
哇说起B站,在小九眼里就是宝藏般的存在,放年假宅在家时一天刷6、7个小时不在话下,更别提今年的跨年晚会,我简直是跪着看完的!! 最早大家聚在在B站是为了追番,再后来我在上面刷欧美新歌和漂亮小姐姐的舞蹈视频,最近两年我和周围的朋友们已经把B站当作学习教室了,而且学习成本还免费,真是个励志的好平台ヽ(.◕ฺˇд ˇ◕ฺ;)ノ 下面我们就来盘点一下B站上优质的学习资源: 综合类 Oeasy: 综合
你也能看懂的:蒙特卡罗方法
蒙特卡罗方法,也称统计模拟方法,是1940年代中期由于科学技术的发展和电子计算机的发明,而提出的一种以概率统计理论为指导的数值计算方法。是指使用随机数(或更常见的伪随机数)来解决很多计算问题的方法 蒙特卡罗方法可以粗略地分成两类:一类是所求解的问题本身具有内在的随机性,借助计算机的运算能力可以直接模拟这种随机的过程。另一种类型是所求解问题可以转化为某种随机分布的特征数,比如随机事件出现的概率,或...
相关热词 c#如何定义数组列表 c#倒序读取txt文件 java代码生成c# c# tcp发送数据 c#解决时间格式带星期 c#类似hashmap c#设置istbox的值 c#获取多线程返回值 c# 包含数字 枚举 c# timespan
立即提问