当前位置: 编程技术>移动开发
本页文章导读:
▪Layout 配置文件的定名规范 Layout 配置文件的命名规范
在创建XML布局文件时,千万要注意命名规范,要不能会报错的,配置文件的命名规范为:[a-z0-9_.],今天一不小心创建了一个名为:lifeCycle.xml的文件,控制台报.........
▪ Google Maps API map线路相关 Google Maps API 地图线路相关
本位属转载,作者:再见西瓜虫简介Google Maps JavaScript API方便用户将Google Map嵌入到他们的网页中,在iPhone中若要调用JavaScript API, 需要创建UIWebView并将HTML页面嵌入.........
▪ Opengl 运用函数 大全 Opengl 应用函数 大全
转自:http://www.eoeandroid.com/thread-53931-1-1.html开发基于OpenGL的应用程序,必须先了解OpenGL的库函数。它采用C语言风格,提供大量的函数来进行图形的处理和显示。OpenGL库函.........
[1]Layout 配置文件的定名规范
来源: 互联网 发布时间: 2014-02-18
Layout 配置文件的命名规范
在创建XML布局文件时,千万要注意命名规范,要不能会报错的,配置文件的命名规范为:[a-z0-9_.],今天一不小心创建了一个名为:lifeCycle.xml的文件,控制台报出了错误信息:[2011-03-14 15:51:30 - Android] res\layout\lifeCycle.xml: Invalid file name: must contain only [a-z0-9_.]
[2] Google Maps API map线路相关
来源: 互联网 发布时间: 2014-02-18
Google Maps API 地图线路相关
本位属转载,作者:再见西瓜虫
简介
Google Maps JavaScript API方便用户将Google Map嵌入到他们的网页中,在iPhone中若要调用JavaScript API, 需要创建UIWebView并将HTML页面嵌入到UIWebView中。
源码:
本位属转载,作者:再见西瓜虫
简介
Google Maps JavaScript API方便用户将Google Map嵌入到他们的网页中,在iPhone中若要调用JavaScript API, 需要创建UIWebView并将HTML页面嵌入到UIWebView中。
源码:
1: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> 2: <html xmlns="http://www.w3.org/1999/xhtml"> 3: <head> 4: <meta http-equiv="content-type" content="text/html; charset=utf-8" /> 5: <title>Google 地图 JavaScript API 示例</title> 6: <script src="http://ditu.google.com/maps?file=api&v=2" type="text/javascript"></script> 7: <script type="text/javascript"> 8: var map = null;// GMap2对象 9: var directions = null;// GDirections对象 10: var isFirstClick = true; // 用于判断地图上是否已有路线 11: var firstPin = null;// 清除地图上所有的控件后,第一次点击生成的GMarker对象 12: var secondPin = null;// 第二次点击的GMarker对象 13: var polyline = null;// 路线 14: 15: var zoomLevel = null;// 缩放等级 16: var center = null;// 地图中心 17: 18: var defaultPin = 'file:\\E:/Pin2.png';// 默认大头针图片 19: var movedPin = 'file:\\E:/PinFloating.png';// 移动时的大头针图片 20: 21: function load() { 22: if (GBrowserIsCompatible()) { 23: map = new GMap2(document.getElementById("map")); 24: map.setCenter(new GLatLng(31.877557643340015, 117.24609375), 13); 25: map.disableDoubleClickZoom(); 26: directions = new GDirections(map); 27: 28: //自定义GMarker. 29: var pinIcon = new GIcon(G_DEFAULT_ICON); 30: pinIcon.image = defaultPin; 31: pinIcon.iconSize = new GSize(29, 32); 32: pinIcon.iconAnchor = new GPoint(5, 27); 33: pinIcon.shadow = null; 34: markOptions = { draggable: true, icon: pinIcon };// 这这里我们设置GMarker可以拖动. 35: 36: // 对firstPin和secondPin进行初始化. 37: firstPin = new GMarker(new GLatLng(31.877557643340015, 117.24609375), markOptions); 38: secondPin = new GMarker(new GLatLng(31.877557643340015, 117.24609375), markOptions); 39: 40: // 添加监听. 41: addMapClickListener(); 42: addDraggingListener(); 43: addDirectionsListener(); 44: } 45: 46: // 监听地图的点击事件. 47: function addMapClickListener() { 48: if (map != null) { 49: GEvent.addListener(map, "click", function (marker, point) { 50: if (marker) { 51: map.removeOverlay(marker); 52: } 53: else { 54: if (isFirstClick == true) { 55: // 因为我们只想地图上只有一条路线,所以 56: // 在每次添加起点大头针时,清除地图上所有的控件. 57: map.clearOverlays(); 58: polyline = null; 59: isFirstClick = false; 60: 61: firstPin.setLatLng(point); 62: map.addOverlay(firstPin); 63: } 64: else { 65: isFirstClick = true; 66: secondPin.setLatLng(point); 67: map.addOverlay(secondPin); 68: 69: // 获取最短路径. 70: loadDirections(firstPin.getLatLng(), secondPin.getLatLng(), null); 71: } 72: } 73: }); 74: } 75: } 76: 77: // 监听大头针的拖动事件. 78: function addDraggingListener() { 79: if (firstPin != null && secondPin != null) { 80: 81: // 当开始拖动大头针时,我们需要将大头针的图片(Pin2.png)修改成拖动时的图片(PinFloating.png). 82: GEvent.addListener(firstPin, 'dragstart', function (latlng) { 83: firstPin.setImage(movedPin); 84: }); 85: 86: GEvent.addListener(secondPin, 'dragstart', function (latlng) { 87: secondPin.setImage(movedPin); 88: }); 89: 90: // 当结束拖动时,需要将大头针的图片改回拖动前,并重新获取最短路线. 91: GEvent.addListener(firstPin, 'dragend', function (latlng) { 92: firstPin.setImage(defaultPin); 93: 94: if (latlng != null && polyline != null) { 95: 96: window.setTimeout(function () { 97: loadDirections(latlng, secondPin.getLatLng()); 98: }, 300); 99: } 100: }); 101: 102: GEvent.addListener(secondPin, 'dragend', function (latlng) { 103: secondPin.setImage(defaultPin); 104: 105: if (latlng != null && polyline != null) { 106: 107: window.setTimeout(function () { 108: loadDirections(firstPin.getLatLng(), latlng); 109: }, 350); 110: } 111: }); 112: } 113: } 114: 115: // 获取最短路径. 116: function loadDirections(startLatLng, endLatLng, travelModel) { 117: 118: if (startLatLng == null || endLatLng == null) { 119: return; 120: } 121: 122: // 获取缩放级别和中心点的经纬度. 123: // 由于在GDirections.load得到经纬度之后,地图会自动缩放并平移, 124: // 所以需要在这里获取到load之前的值,在load结束后重新修改缩放级别 125: // 和中心点. 126: zoomLevel = map.getZoom(); 127: center = map.getCenter(); 128: 129: if (travelModel == null) { 130: directions.loadFromWaypoints(new Array(startLatLng, endLatLng)); 131: } 132: else { 133: directions.loadFromWaypoints(new Array(startLatLng, endLatLng), 134: { travelMode: travelModel }); 135: } 136: } 137: 138: // 监听GDirection的'addOverly'事件. 139: function addDirectionsListener() { 140: 141: // 由于地图会在GDirection.load事件后自动添加起点和终点的GMarker控件, 142: // 这是在页面上会出现2个起点和2个终点,我们需要将自动添加的GMarker删除, 143: // 并重新添加|firstPin|和|secondPin|。同时clearOverlays方法也会将地图 144: // 上的路线删除,所以我们在添加Garker的同时,也需要将路线重新添加到Map. 145: GEvent.addListener(directions, 'addoverlay', function () { 146: if (directions != null) { 147: map.clearOverlays(); 148: 149: var startMarker = directions.getMarker(0); 150: var endMarker = directions.getMarker(1); 151: polyline = directions.getPolyline(); 152: 153: firstPin.setLatLng(startMarker.getLatLng()); 154: secondPin.setLatLng(endMarker.getLatLng()); 155: 156: map.addOverlay(firstPin); 157: map.addOverlay(secondPin); 158: map.addOverlay(polyline); 159: 160: map.setZoom(zoomLevel); 161: map.setCenter(center); 162: } 163: }); 164: } 165: } 166: 167: </script> 168: </head> 169: <body onload="load()" onunload="GUnload()" > 170: <div id="map" > 171: </div> 172: </body> 173: </html>
[3] Opengl 运用函数 大全
来源: 互联网 发布时间: 2014-02-18
Opengl 应用函数 大全
转自:
http://www.eoeandroid.com/thread-53931-1-1.html
开发基于OpenGL的应用程序,必须先了解OpenGL的库函数。它采用C语言风格,提供大量的函数来进行图形的处理和显示。OpenGL库函数的命名方式非常有规律。所有OpenGL函数采用了以下格式:
<库前缀><根命令><可选的参数个数><可选的参数类型>
库前缀有gl、glu、aux、glut、wgl、glx、agl等等,分别表示该函数属于OpenGL那个开发库,从函数名后面中还可以看出需要多少个参数以及参数的类型。I代表int型,f代表float型,d代表double型,u代表无符号整型。例如glVertex3fv()表示了该函数属于gl库,参数是三个float型参数指针。我们用glVertex*()
来表示这一类函数。
OpenGL函数库相关的API有核心库(gl)、实用库(glu)、辅助库(aux)、实用工具库(glut)、窗口库(glx、agl、wgl)和扩展函数库等。从图可以看出,gl是核心,glu是对gl的部分封装。glx、agl、wgl 是针对不同窗口系统的函数。glut是为跨平台的OpenGL程序的工具包,比aux功能强大。扩展函数库是硬件厂商为实现硬件更新利用OpenGL的扩展机制开发的函数。下面逐一对这些库进行详细介绍。
1.OpenGL核心库
核心库包含有115个函数,函数名的前缀为gl。这部分函数用于常规的、核心的图形处理。此函数由gl.dll来负责解释执行。由于许多函数可以接收不同数以下几类。据类型的参数,因此派生出来的函数原形多达300多个。核心库中的函数主要可以分为以下几类函数:
• 绘制基本几何图元的函数:glBegain()、glEnd()、glNormal*()、glVertex*();
• 矩阵操作、几何变换和投影变换的函数:如矩阵入栈函数glPushMatrix(),矩阵出栈函数glPopMatrix(),装载矩阵函数glLoadMatrix(),矩阵相乘函数glMultMatrix(),当前矩阵函数glMatrixMode()和矩阵标准化函数glLoadIdentity(),几何变换函数glTranslate*()、glRotate*()和glScale*(),投影变换函数glOrtho()、glFrustum()和视口变换函数glViewport();
• 颜色、光照和材质的函数:如设置颜色模式函数glColor*()、glIndex*(),设置光照效果的函数glLight*() 、glLightModel*()和设置材质效果函数glMaterial();
• 显示列表函数:主要有创建、结束、生成、删除和调用显示列表的函数glNewList()、glEndList()、glGenLists()、glCallList()和glDeleteLists();
• 纹理映射函数:主要有一维纹理函数glTexImage1D()、二维纹理函数glTexImage2D()、设置纹理参数、纹理环境和纹理坐标的函数glTexParameter*()、glTexEnv*()和glTetCoord*();
• 特殊效果函数:融合函数glBlendFunc()、反走样函数glHint()和雾化效果glFog*();
• 光栅化、象素操作函数:如象素位置glRasterPos*()、线型宽度glLineWidth()、多边形绘制模式glPolygonMode(),读取象素glReadPixel()、复制象素glCopyPixel();
• 选择与反馈函数:主要有渲染模式glRenderMode()、选择缓冲区glSelectBuffer()和反馈缓冲区glFeedbackBuffer();
• 曲线与曲面的绘制函数:生成曲线或曲面的函数glMap*()、glMapGrid*(),求值器的函数glEvalCoord*() glEvalMesh*();
• 状态设置与查询函数:glGet*()、glEnable()、glGetError()。
2.OpenGL实用库The OpenGL Utility Library (GLU)
包含有43个函数,函数名的前缀为glu。OpenGL提供了强大的但是为数不多的绘图命令,所有较复杂的绘图都必须从点、线、面开始。Glu 为了减轻繁重的编程工作,封装了OpenGL函数,Glu函数通过调用核心库的函数,为开发者提供相对简单的用法,实现一些较为复杂的操作。此函数由glu.dll来负责解释执行。OpenGL中的核心库和实用库可以在所有的OpenGL平台上运行。主要包括了以下几种:
• 辅助纹理贴图函数:gluScaleImage() 、gluBuild1Dmipmaps()、gluBuild2Dmipmaps();
• 坐标转换和投影变换函数:定义投影方式函数gluPerspective()、gluOrtho2D() 、gluLookAt(),拾取投影视景体函数gluPickMatrix(),投影矩阵计算gluProject()和gluUnProject();
• 多边形镶嵌工具:gluNewTess()、gluDeleteTess()、gluTessCallback()、gluBeginPolygon()、gluTessVertex()、gluNextContour()、gluEndPolygon();
• 二次曲面绘制工具,主要有绘制球面、锥面、柱面、圆环面gluNewQuadric()、gluSphere()、gluCylinder()、gluDisk()、gluPartialDisk()、gluDeleteQuadric();
• 非均匀有理B样条绘制工具:主要用来定义和绘制Nurbs曲线和曲面,包括gluNewNurbsRenderer()、gluNurbsCurve()、gluBeginSurface()、gluEndSurface()、gluBeginCurve()、gluNurbsProperty();
• 错误反馈工具:获取出错信息的字符串gluErrorString()。
3.OpenGL辅助库
包含有31个函数,函数名前缀为aux。这部分函数提供窗口管理、输入输出处理以及绘制一些简单三维物体。此函数由glaux.dll来负责解释执行。创建aux库是为了学习和编写OpenGL程序,它更像是一个用于测试创意的预备基础接管。Aux库在windows实现有很多错误,因此很容易导致频繁的崩溃。在跨平台的编程实例和演示中,aux很大程度上已经被glut库取代。OpenGL中的辅助库不能在所有的OpenGL平台上运行。
辅助库函数主要包括以下几类:
• 窗口初始化和退出函数:auxInitDisplayMode()和auxInitPosition();
• 窗口处理和时间输入函数:auxReshapeFunc()、auxKeyFunc()和auxMouseFunc();
• 颜色索引装入函数:auxSetOneColor();
• 三维物体绘制函数:包括了两种形式网状体和实心体,如绘制立方体auxWireCube()和 auxSolidCube()。这里以网状体为例,长方体auxWireBox()、环形圆纹面auxWireTorus()、圆柱auxWireCylinder()、二十面体auxWireIcosahedron()、八面体auxWireOctahedron()、四面体auxWireTetrahedron()、十二面体auxWireDodecahedron()、圆锥体auxWireCone()和茶壶auxWireTeapot();
• 背景过程管理函数:auxIdleFunc();
• 程序运行函数:auxMainLoop()。
4.OpenGL工具库 OpenGL Utility Toolkit
包含大约30多个函数,函数名前缀为glut。glut是不依赖于窗口平台的OpenGL工具包,由Mark KLilgrad在SGI编写(现在在Nvidia),目的是隐藏不同窗口平台API的复杂度。 函数以glut开头,它们作为aux库功能更强的替代品,提供更为复杂的绘制功能,此函数由glut.dll来负责解释执行。由于glut中的窗口管理函数是不依赖于运行环境的,因此OpenGL中的工具库可以在X-Window, Windows NT, OS/2等系统下运行,特别适合于开发不需要复杂界面的OpenGL示例程序。对于有经验的程序员来说,一般先用glut理顺3D图形代码,然后再集成为完整的应用程序。
这部分函数主要包括:
• 窗口操作函数:窗口初始化、窗口大小、窗口位置函数等[glutInit()、glutInitDisplayMode()、glutInitWindowSize()、glutInitWindowPosition()];
• 回调函数:响应刷新消息、键盘消息、鼠标消息、定时器函数[GlutDisplayFunc()、glutPostRedisplay()、glutReshapeFunc()、glutTimerFunc()、glutKeyboardFunc()、glutMouseFunc()];
• 创建复杂的三维物体:这些和aux库的函数功能相同;
• 菜单函数:创建添加菜单的函数GlutCreateMenu()、glutSetMenu()、glutAddMenuEntry()、glutAddSubMenu()和glutAttachMenu();
• 程序运行函数:glutMainLoop()。
5.Windows专用库
针对windows平台的扩展,包含有16个函数,函数名前缀为wgl。这部分函数主要用于连接OpenGL和Windows ,以弥补OpenGL在文本方面的不足。 Windows专用库只能用于Windows环境中。
这类函数主要包括以下几类:
• 绘图上下文相关函数:wglCreateContext()、wglDeleteContext()、wglGetCurrentContent()、wglGetCurrentDC()、wglDeleteContent();
• 文字和文本处理函数:wglUseFontBitmaps()、wglUseFontOutlines();
• 覆盖层、地层和主平面层处理函数:wglCopyContext()、wglCreateLayerPlane()、wglDescribeLayerPlane()、wglReakizeLayerPlatte();
• 其他函数:wglShareLists()、wglGetProcAddress()。
6.Win32 API函数库
包含有6个函数,函数名无专用前缀,是win32扩展函数。这部分函数主要用于处理像素存储格式和双帧缓存;这6个函数将替换Windows GDI中原有的同样的函数。Win32API函数库只能用于Windows 95/98/NT环境中。
7.X窗口专用库
是针对Unix和Linux的扩展函数。包括渲染上下文、绘制图元、显示列表、纹理贴图等;
• 初始化:glXQueryExtension();
• 渲染上下文函数:glXCreateContext()、glXDestroyContext()、glXCopyContext()、glXMakeCurrent()、glXCreateGLXPixmap();
• 执行:glXWaitGL()、glXWaitX();
• 缓冲区和字体:glXSwapBuffers()、glXUseXFont()。
8.其他扩展库
这些函数可能是新的OpenGL函数,并没有在标准OpenGL库中实现,或者它们是用来扩展已存在的OpenGL函数的功能。和glu、glx和wgl一样,这些OpenGL扩展是由硬件厂商和厂商组织开发的。OpenGL扩展(OpenGL Extention)包含了大量的扩展API函数。
随着硬件的更新,硬件厂商首先向SGI申请登记新的扩展,编写规格说明书(specification)。然后按照说明书进行开发扩展程序。不同的OpenGL实现(OpenGL Implementation)支持的扩展可能不一样,只有随着某一扩展的推广与应用以及硬件技术的提高该扩展才会在所有的OpenGL实现中被给予支持,从而最终成为OpenGL标准库的一部分。扩展由SGI维护,在SGI网站上列出了目前公开的已注册的扩展及其官方说明书。扩展源由扩展函数的后缀来指明(或使用扩展常量后缀)。例如,后缀WIN表明一个符合Windows规范的扩展,EXT或ARB后缀表明该扩展由多个卖主定义。
下面给出OpenGL官方规定的命名规则:
• ARB – OpenGL Architecture Review Board正式核准的扩展,往往由厂商开发的扩展发展而来,如果同时存在厂商开发的扩展和ARB扩展,应该优先使用ARB扩展;
• EXT – 多家OpenGL厂商同意支持的扩展;
• HP – Hewlett-Packard 惠普;
• IBM – International Business Machines ;
• KTX – Kinetix, maker of 3D Studio Max ;
• INTEL – Intel 公司;
• NV – NVIDIA 公司;
• MESA – Brian Paul’s freeware portable OpenGL implementation ;
• SGI – Silicon Graphics公司开发的扩展;
• SGIX – Silicon Graphics (experimental) 公司开发的实验性扩展;
• SUN – Sun Microsystems;
• WIN – Microsoft 。
由于OpenGL扩展在针对不同平台和不同驱动,OpenGL不可能把所有的接口程序全部放到gl.h、glx.h、wgl.h中,而是将这些函数头放在了glext.h、glxext.h和wglext.h中。这些扩展被看作时OpenGL核心库规范的增加和修改。
转自:
http://www.eoeandroid.com/thread-53931-1-1.html
开发基于OpenGL的应用程序,必须先了解OpenGL的库函数。它采用C语言风格,提供大量的函数来进行图形的处理和显示。OpenGL库函数的命名方式非常有规律。所有OpenGL函数采用了以下格式:
<库前缀><根命令><可选的参数个数><可选的参数类型>
库前缀有gl、glu、aux、glut、wgl、glx、agl等等,分别表示该函数属于OpenGL那个开发库,从函数名后面中还可以看出需要多少个参数以及参数的类型。I代表int型,f代表float型,d代表double型,u代表无符号整型。例如glVertex3fv()表示了该函数属于gl库,参数是三个float型参数指针。我们用glVertex*()
来表示这一类函数。
OpenGL函数库相关的API有核心库(gl)、实用库(glu)、辅助库(aux)、实用工具库(glut)、窗口库(glx、agl、wgl)和扩展函数库等。从图可以看出,gl是核心,glu是对gl的部分封装。glx、agl、wgl 是针对不同窗口系统的函数。glut是为跨平台的OpenGL程序的工具包,比aux功能强大。扩展函数库是硬件厂商为实现硬件更新利用OpenGL的扩展机制开发的函数。下面逐一对这些库进行详细介绍。
1.OpenGL核心库
核心库包含有115个函数,函数名的前缀为gl。这部分函数用于常规的、核心的图形处理。此函数由gl.dll来负责解释执行。由于许多函数可以接收不同数以下几类。据类型的参数,因此派生出来的函数原形多达300多个。核心库中的函数主要可以分为以下几类函数:
• 绘制基本几何图元的函数:glBegain()、glEnd()、glNormal*()、glVertex*();
• 矩阵操作、几何变换和投影变换的函数:如矩阵入栈函数glPushMatrix(),矩阵出栈函数glPopMatrix(),装载矩阵函数glLoadMatrix(),矩阵相乘函数glMultMatrix(),当前矩阵函数glMatrixMode()和矩阵标准化函数glLoadIdentity(),几何变换函数glTranslate*()、glRotate*()和glScale*(),投影变换函数glOrtho()、glFrustum()和视口变换函数glViewport();
• 颜色、光照和材质的函数:如设置颜色模式函数glColor*()、glIndex*(),设置光照效果的函数glLight*() 、glLightModel*()和设置材质效果函数glMaterial();
• 显示列表函数:主要有创建、结束、生成、删除和调用显示列表的函数glNewList()、glEndList()、glGenLists()、glCallList()和glDeleteLists();
• 纹理映射函数:主要有一维纹理函数glTexImage1D()、二维纹理函数glTexImage2D()、设置纹理参数、纹理环境和纹理坐标的函数glTexParameter*()、glTexEnv*()和glTetCoord*();
• 特殊效果函数:融合函数glBlendFunc()、反走样函数glHint()和雾化效果glFog*();
• 光栅化、象素操作函数:如象素位置glRasterPos*()、线型宽度glLineWidth()、多边形绘制模式glPolygonMode(),读取象素glReadPixel()、复制象素glCopyPixel();
• 选择与反馈函数:主要有渲染模式glRenderMode()、选择缓冲区glSelectBuffer()和反馈缓冲区glFeedbackBuffer();
• 曲线与曲面的绘制函数:生成曲线或曲面的函数glMap*()、glMapGrid*(),求值器的函数glEvalCoord*() glEvalMesh*();
• 状态设置与查询函数:glGet*()、glEnable()、glGetError()。
2.OpenGL实用库The OpenGL Utility Library (GLU)
包含有43个函数,函数名的前缀为glu。OpenGL提供了强大的但是为数不多的绘图命令,所有较复杂的绘图都必须从点、线、面开始。Glu 为了减轻繁重的编程工作,封装了OpenGL函数,Glu函数通过调用核心库的函数,为开发者提供相对简单的用法,实现一些较为复杂的操作。此函数由glu.dll来负责解释执行。OpenGL中的核心库和实用库可以在所有的OpenGL平台上运行。主要包括了以下几种:
• 辅助纹理贴图函数:gluScaleImage() 、gluBuild1Dmipmaps()、gluBuild2Dmipmaps();
• 坐标转换和投影变换函数:定义投影方式函数gluPerspective()、gluOrtho2D() 、gluLookAt(),拾取投影视景体函数gluPickMatrix(),投影矩阵计算gluProject()和gluUnProject();
• 多边形镶嵌工具:gluNewTess()、gluDeleteTess()、gluTessCallback()、gluBeginPolygon()、gluTessVertex()、gluNextContour()、gluEndPolygon();
• 二次曲面绘制工具,主要有绘制球面、锥面、柱面、圆环面gluNewQuadric()、gluSphere()、gluCylinder()、gluDisk()、gluPartialDisk()、gluDeleteQuadric();
• 非均匀有理B样条绘制工具:主要用来定义和绘制Nurbs曲线和曲面,包括gluNewNurbsRenderer()、gluNurbsCurve()、gluBeginSurface()、gluEndSurface()、gluBeginCurve()、gluNurbsProperty();
• 错误反馈工具:获取出错信息的字符串gluErrorString()。
3.OpenGL辅助库
包含有31个函数,函数名前缀为aux。这部分函数提供窗口管理、输入输出处理以及绘制一些简单三维物体。此函数由glaux.dll来负责解释执行。创建aux库是为了学习和编写OpenGL程序,它更像是一个用于测试创意的预备基础接管。Aux库在windows实现有很多错误,因此很容易导致频繁的崩溃。在跨平台的编程实例和演示中,aux很大程度上已经被glut库取代。OpenGL中的辅助库不能在所有的OpenGL平台上运行。
辅助库函数主要包括以下几类:
• 窗口初始化和退出函数:auxInitDisplayMode()和auxInitPosition();
• 窗口处理和时间输入函数:auxReshapeFunc()、auxKeyFunc()和auxMouseFunc();
• 颜色索引装入函数:auxSetOneColor();
• 三维物体绘制函数:包括了两种形式网状体和实心体,如绘制立方体auxWireCube()和 auxSolidCube()。这里以网状体为例,长方体auxWireBox()、环形圆纹面auxWireTorus()、圆柱auxWireCylinder()、二十面体auxWireIcosahedron()、八面体auxWireOctahedron()、四面体auxWireTetrahedron()、十二面体auxWireDodecahedron()、圆锥体auxWireCone()和茶壶auxWireTeapot();
• 背景过程管理函数:auxIdleFunc();
• 程序运行函数:auxMainLoop()。
4.OpenGL工具库 OpenGL Utility Toolkit
包含大约30多个函数,函数名前缀为glut。glut是不依赖于窗口平台的OpenGL工具包,由Mark KLilgrad在SGI编写(现在在Nvidia),目的是隐藏不同窗口平台API的复杂度。 函数以glut开头,它们作为aux库功能更强的替代品,提供更为复杂的绘制功能,此函数由glut.dll来负责解释执行。由于glut中的窗口管理函数是不依赖于运行环境的,因此OpenGL中的工具库可以在X-Window, Windows NT, OS/2等系统下运行,特别适合于开发不需要复杂界面的OpenGL示例程序。对于有经验的程序员来说,一般先用glut理顺3D图形代码,然后再集成为完整的应用程序。
这部分函数主要包括:
• 窗口操作函数:窗口初始化、窗口大小、窗口位置函数等[glutInit()、glutInitDisplayMode()、glutInitWindowSize()、glutInitWindowPosition()];
• 回调函数:响应刷新消息、键盘消息、鼠标消息、定时器函数[GlutDisplayFunc()、glutPostRedisplay()、glutReshapeFunc()、glutTimerFunc()、glutKeyboardFunc()、glutMouseFunc()];
• 创建复杂的三维物体:这些和aux库的函数功能相同;
• 菜单函数:创建添加菜单的函数GlutCreateMenu()、glutSetMenu()、glutAddMenuEntry()、glutAddSubMenu()和glutAttachMenu();
• 程序运行函数:glutMainLoop()。
5.Windows专用库
针对windows平台的扩展,包含有16个函数,函数名前缀为wgl。这部分函数主要用于连接OpenGL和Windows ,以弥补OpenGL在文本方面的不足。 Windows专用库只能用于Windows环境中。
这类函数主要包括以下几类:
• 绘图上下文相关函数:wglCreateContext()、wglDeleteContext()、wglGetCurrentContent()、wglGetCurrentDC()、wglDeleteContent();
• 文字和文本处理函数:wglUseFontBitmaps()、wglUseFontOutlines();
• 覆盖层、地层和主平面层处理函数:wglCopyContext()、wglCreateLayerPlane()、wglDescribeLayerPlane()、wglReakizeLayerPlatte();
• 其他函数:wglShareLists()、wglGetProcAddress()。
6.Win32 API函数库
包含有6个函数,函数名无专用前缀,是win32扩展函数。这部分函数主要用于处理像素存储格式和双帧缓存;这6个函数将替换Windows GDI中原有的同样的函数。Win32API函数库只能用于Windows 95/98/NT环境中。
7.X窗口专用库
是针对Unix和Linux的扩展函数。包括渲染上下文、绘制图元、显示列表、纹理贴图等;
• 初始化:glXQueryExtension();
• 渲染上下文函数:glXCreateContext()、glXDestroyContext()、glXCopyContext()、glXMakeCurrent()、glXCreateGLXPixmap();
• 执行:glXWaitGL()、glXWaitX();
• 缓冲区和字体:glXSwapBuffers()、glXUseXFont()。
8.其他扩展库
这些函数可能是新的OpenGL函数,并没有在标准OpenGL库中实现,或者它们是用来扩展已存在的OpenGL函数的功能。和glu、glx和wgl一样,这些OpenGL扩展是由硬件厂商和厂商组织开发的。OpenGL扩展(OpenGL Extention)包含了大量的扩展API函数。
随着硬件的更新,硬件厂商首先向SGI申请登记新的扩展,编写规格说明书(specification)。然后按照说明书进行开发扩展程序。不同的OpenGL实现(OpenGL Implementation)支持的扩展可能不一样,只有随着某一扩展的推广与应用以及硬件技术的提高该扩展才会在所有的OpenGL实现中被给予支持,从而最终成为OpenGL标准库的一部分。扩展由SGI维护,在SGI网站上列出了目前公开的已注册的扩展及其官方说明书。扩展源由扩展函数的后缀来指明(或使用扩展常量后缀)。例如,后缀WIN表明一个符合Windows规范的扩展,EXT或ARB后缀表明该扩展由多个卖主定义。
下面给出OpenGL官方规定的命名规则:
• ARB – OpenGL Architecture Review Board正式核准的扩展,往往由厂商开发的扩展发展而来,如果同时存在厂商开发的扩展和ARB扩展,应该优先使用ARB扩展;
• EXT – 多家OpenGL厂商同意支持的扩展;
• HP – Hewlett-Packard 惠普;
• IBM – International Business Machines ;
• KTX – Kinetix, maker of 3D Studio Max ;
• INTEL – Intel 公司;
• NV – NVIDIA 公司;
• MESA – Brian Paul’s freeware portable OpenGL implementation ;
• SGI – Silicon Graphics公司开发的扩展;
• SGIX – Silicon Graphics (experimental) 公司开发的实验性扩展;
• SUN – Sun Microsystems;
• WIN – Microsoft 。
由于OpenGL扩展在针对不同平台和不同驱动,OpenGL不可能把所有的接口程序全部放到gl.h、glx.h、wgl.h中,而是将这些函数头放在了glext.h、glxext.h和wglext.h中。这些扩展被看作时OpenGL核心库规范的增加和修改。
最新技术文章: