1. 引言

OpenGL,一般它被认为是一个API(Application Programming Interface, 应用程序编程接口),包含了一系列可以操作图形、图像的函数。然而,OpenGL本身并不是一个API,它仅仅是一个由Khronos组织制定并维护的规范(Specification)

OpenGL规范严格规定了每个函数该如何执行,以及它们的输出值。至于内部具体每个函数是如何实现(Implement)的,将由OpenGL库的开发者自行决定(译注:这里开发者是指编写OpenGL库的人)。因为OpenGL规范并没有规定实现的细节,具体的OpenGL库允许使用不同的实现,只要其功能和结果与规范相匹配(亦即,作为用户不会感受到功能上的差异)

OpenGL只是一种规范,不仅语言无关,而且平台无关。规范只字未提获得和管理OpenGL上下文相关的内容,而是将这些作为细节交给底层的窗口系统。出于同样的原因,OpenGL纯粹专注于渲染,而不提供输入、音频以及窗口相关的API

PyOpenGL是常见的跨平台语言Python与OpenGL和相关API的绑定,支持:

  • OpenGL v1.1 to 4.4
  • GLES 1 to 3.1 (Experimental)
  • GLU
  • EGL, WGL, GLX
  • GLUT, FreeGLUT
  • GLE 3 (GL Extrusion Library)
  • hundreds of extensions to GL, GLES, EGL, WGL and GLX

OpenGL_accelerate,PyOpenGL的cython编码加速器模块,可选,但建议在可用的情况下使用

2. 安装使用

诚然,直接使用Pip进行安装是最简便的,但是往往存在问题(当然,不妨试试)

按照PyOpenGL官网PyOpenGL -- The Python OpenGL Binding (sourceforge.net)的指导,使用以下命令安装:

$ pip install PyOpenGL PyOpenGL_accelerate

不妨按照示例代码测试一下:

from OpenGL.GL import *
from OpenGL.GLUT import * def drawFunc():
glClear(GL_COLOR_BUFFER_BIT)
glRotatef(1, 1, 1, 0)
glutWireTeapot(0.5)
glFlush() glutInit()
glutInitDisplayMode(GLUT_SINGLE | GLUT_RGBA)
glutInitWindowSize(400, 400)
#参数为b类型而不是string
glutCreateWindow(b"First")
glutDisplayFunc(drawFunc)
glutMainLoop()

如果顺利的话,应该会出现一个茶壶:

但是,往往会出现这个错误:Attempt to call an undefined function glutInit, check for bool(glutInit) before calling

大部分博客都有说到这个问题:

这些博客基本都提到了动态链接库与32/64位库的问题,采取的问题基本都是去下载whl文件再安装:

下载地址:Archived: Python Extension Packages for Windows - Christoph Gohlke (uci.edu)

选择对应的版本进行安装,可以参考:Python安装配置OpenGL环境的全过程记录--易采站长站 (easck.com)

3. 错误解决

使用pip安装的方式错在哪里呢?

笔者下载Archived: Python Extension Packages for Windows - Christoph Gohlke (uci.edu)的安装文件,使用解压软件打开,可以发现里面GLUT对应含有DLL文件:

然而,通过pip方式安装的whl文件却不包含DLL文件:

笔者下载源码安装包,可以看到源码里面包含了DLL文件:

所以问题的根源就显而易见了:通过pip方式安装的whl文件却不包含DLL文件所以无法直接执行

解决的方法有很多:

  • 下载对应的DLL添加到PATH(环境变量)中,无需纠结放在那个文件
  • 下载包含DLL的whl安装包,本地安装
  • 下载源码进行安装

以下对上述三种方法进行进一步叙述:

下载对应的DLL添加到PATH(环境变量)

获取glut或者freeglut的对应的dll文件,然后将dll文件添加到PATH(环境变量),DLL可以去官网下载,也可以从PyOpenGL源码包、包含DLL的whl安装包中等获取,可以参考:

下载包含DLL的whl安装包本地安装

下载包含DLL的whl安装包,本地安装,就解决了DLL缺失的问题,可以参考:

下载源码进行安装

下载PyOpenGL源码(包含DLL),进行本地安装,可以参考:

推荐:下载包含DLL的whl安装包本地安装

从上图中,我们可以看到PyOpenGL 3.1.6 版本中使用的是freeglut,在 3.1.5 中是glut和freeglut都有,笔者发现在3.1.1版本中用的是glut(如下图所示),可以看到glut逐渐被废弃,如果搞不清楚需要什么DLL,那就下载包含DLL的whl安装包本地安装

一些想法:

笔者看到pip源上有源码包,那能否跳过whl文件直接使用源码安装呢?

经过笔者搜索,在没有whl文件的情况下,pip就会下载源码进行安装,然而,在有whl文件的情况下,pip似乎没有办法跳过whl文件直接源码安装,先下载源码再本地安装就显得麻烦

4. 参考资料

[1][OpenGL - LearnOpenGL CN (learnopengl-cn.github.io)](https://learnopengl-cn.github.io/01 Getting started/01 OpenGL/)

[2]OpenGL_百度百科 (baidu.com)

[3]PyOpenGL -- The Python OpenGL Binding (sourceforge.net)

[4]超简单的PyOpenGL安装教程,我竟然还要总结一下,有毒!!!_光子俊的博客-CSDN博客_pyopengl安装

[5]Python安装配置OpenGL环境的全过程记录--易采站长站 (easck.com)

[6]尝试调用未定义的函数 glutInit - IT宝库 (itbaoku.cn)

[7]PyOpenGL Installation (sourceforge.net)

[8]python opengl安装提示没有glutinit的解决方法。_ljhhh7890的博客-CSDN博客

PyOpenGL的安装与错误解决的更多相关文章

  1. 2016最新CocoaPods安装和错误解决 + 自己的经验

    p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 20.0px Times; color: #333333; background-color: #fffff ...

  2. setuptools安装和错误解决

    错误解决:ImportError No module named setuptools GitHub: https://github.com/pypa/setuptools 下载安装 wget htt ...

  3. redis 安装 与错误解决办法

    redis 安装与安装中遇到的错误 redis 安装 wget http://download.redis.io/releases/redis-4.0.11.tar.gz .tar.gz cd red ...

  4. SQL Server2005中文版x64安装29506错误解决办法

    在使用SQL Server 2005简体中版安装时,使用X86(32位操作系统下)安装没有出现任何问题.可是在X64(64位操作系统下)安装过程没有出现问题,可是安装完成后却没有Microsoft S ...

  5. MongoDB下载+安装+配置+错误解决方法

    下载 官网下载: https://www.mongodb.com/download-center/community Server=>Download 安装 下载完成后安装 建议下载根目录(下过 ...

  6. CTC安装及其错误解决办法:binding.cpp:92:49: error: cannot convert ‘THCudaTensor*’ to ‘const THFloatTensor*’ for argument ‘1’ to ‘int64_t THFloatTensor_size(const THFloatTensor*, int)’

    CTC安装: 1. 在终端执行命令:git clone https://github.com/SeanNaren/warp-c) (效果如下图,大家不用管我前面括号的内容,那是我打开的虚拟环境) 2. ...

  7. Linux下glui 的安装,以及错误解决

    下载源文件: http://sourceforge.net/projects/glui/ 2. 解压源文件 3. 用terminal进入glui-2.36/src文件 4. make 5. make之 ...

  8. mysql-5.6.27源码安装及错误解决办法

    wget http://mirrors.sohu.com/mysql/MySQL-5.6/mysql-5.6.27.tar.gz yum install -y cmake  当然也可以自己下载源码包安 ...

  9. java安装1335错误解决办法(亲测)

    心血来潮想了解一下java,结果一开始就碰到了让心"恶心"的1335错误. 废话不多说,直接看下面: 你可以先尝试在这个链接下载java.exe文件 http://www.orac ...

  10. wget在linux中安装出现错误解决办法

    在使用wget命令报错 certificate common name 'xxx' doesn't match requestde host name,我们一般的解决办法是查找下载地址,但是有时候更换 ...

随机推荐

  1. 复杂mysql/多表查询

    目录 多表查询的两种方法 sql语句基础语法补充 concat / existe / 表字段 增加 修改 删除 复杂sql练习题 多表查询的两种方法 方式1:连表操作 inner join 内连接 s ...

  2. Spring IOC源码(一):IOC容器启动流程核心方法概览

    Spring有两种方式加载配置,分别为xml文件.注解的方式,对于xml配置的方式相信大家都不陌生,往往通过new ClassPathXmlApplicationContext("*.xml ...

  3. 【Redis场景1】用户登录注册

    细节回顾: 关于cookie和session不熟悉的朋友: 建议阅读该博客:https://www.cnblogs.com/ityouknow/p/10856177.html 执行流程: 在单体模式下 ...

  4. linux安装Erlang和Rabbitmq以及安装问题解决

    安装环境: Alibaba Cloud Linux 安装erlang命令: rpm --import https://packages.erlang-solutions.com/rpm/erlang_ ...

  5. django.core.exceptions.ImproperlyConfigured: Field name `tester_id` is not valid for model `WebCase`.

    代码: class WebCase(models.Model): id = models.AutoField(primary_key=True) casename = models.CharField ...

  6. 教你用JavaScript实现乘法游戏

    案例介绍 欢迎来的我的小院,我是霍大侠,恭喜你今天又要进步一点点了!我们来用JavaScript编程实战案例,做一个乘法积分游戏.乘法游戏主要通过用户输入的数值和程序计算的数值进行对比,正确积一分,错 ...

  7. vite+ts+vue3+router4+Pinia+ElmPlus+axios+mock项目基本配置

    1.vite+TS+Vue3 npm create vite Project name:... yourProjectName Select a framework:>>Vue Selec ...

  8. C++进阶(位图+布隆过滤器的概念和实现+海量数据处理)

    位图 概念 位图: 所谓位图,就是用每一位来存放某种状态,适用于海量数据,数据无重复的场景.通常是用来判断某个数据存不存在的. 适用场景: 如果我们需要对大量的数据进行处理,判断该数据在不在,比如40 ...

  9. [python] 基于matplotlib_venn实现维恩图的绘制

    文章目录 VENN DIAGRAM(维恩图) 1. 具有2个分组的基本的维恩图 Venn diagram with 2 groups 2. 具有3个组的基本维恩图 Venn diagram with ...

  10. 【力扣】nSum问题模板

    nSum问题模板 两数之和.三数之和.四数之和. private List<List<Integer>> nSum(int[] nums, long target, int s ...