96SEO 2026-02-23 11:13 2
ES里#xff0c;三角形是一个基础图形#xff0c;其他的图形都可以使用三角形拼接而成#xff0c;所以我们就的案例就基于这个开始。

ES里三角形是一个基础图形其他的图形都可以使用三角形拼接而成所以我们就的案例就基于这个开始。
在Android系统中提供给上层应用的View都是通过Canvas的接口来绘制虽然底层最终也是通过OpenGL
ES来实现的但是由于上层被封装了我们无法通过这个来实现我们想要实现的demo我们需要使用GLSurfaceView来实现。
GLSurfaceView继承自SurfaceView我们知道SurfaceView和一般的View不同会有自己的Surface而GLSurfaceView则在SurfaceView的基础上会初始化EGL的上下文环境。
其实我们直接使用SurfaceView也是可以使用OpenGL
ES的只不过GLSurfaceView给我们提供了一些生命周期管理的辅助在大多数场景使用起来更加方便。
GLSurfaceView提供的是EGL环境我们想要绘制一个三角形所需要做的事如下
创建一个GLSurfaceView配置EGL其实GLSurfaceView帮助我们做了大多数的事使用OpenGL
本节主要是实现demo对OpenGL渲染大体流程有个感知一些api的细节可以不需要关注后续会对每个点会有更详细的介绍。
xmlns:androidhttp://schemas.android.com/apk/res/android
xmlns:toolshttp://schemas.android.com/toolsuses-feature
android:requiredtrue/application//
GLSurfaceView通过setRenderer暴露一个RendererRenderer有三个接口onSurfaceCreated/onSurfaceChanged/onDrawFrame。
GLSurfaceView处理了EGL环境相关的逻辑onDrawFrame则会控制VSync在需要渲染的时候调用。
onSurfaceChanged是Surface变化的情况下会调用而onSurfaceCreated则是Surface创建时回调onDrawFrame和我们自定义View时候的onDraw有一些类似。
设置版本setEGLContextClientVersion(3);Renderer
设定视口类似相机相机移动则渲染的图像相对位置变化。
GLES30.glViewport(0,
由于我们只是要画一个固定的三角形顶点缓冲区里的数据都是固定的所以我们在onSurfaceCreated填充只需要一次即可。
glGenBuffers是创建一个顶点缓冲区Buffer第二个参数是一个int数组创建的顶点缓冲区id会通过这个数组返回后续使用这个id来使用这个buffer。
我们需要先调用glBindBuffer绑定buffer然后再通过glBufferData将数据传到缓冲区中。
GLES30.glBindBuffer(GLES30.GL_ARRAY_BUFFER,
0)则是用来清除Buffer的绑定操作的OpenGL的接口设计像是一个状态机bind上一个Buffer才能对这个Buffer进行操作如果需要操作其他Buffer则需要bind其他Buffer。
vertexArray有三个节点是三个顶点的x,y,z坐标。
OpenGL的坐标系是x,y,z都是(-1,1)。
清除背景颜色GLES30.glClearColor(0.0f,
ByteBuffer.allocateDirect(vertexArray.length
4).order(ByteOrder.nativeOrder()).asFloatBuffer();vertexBuffer.put(vertexArray);vertexBuffer.position(0);GLES30.glBindBuffer(GLES30.GL_ARRAY_BUFFER,
顶点缓冲区数据填充GLES30.glBufferData(GLES30.GL_ARRAY_BUFFER,vertexArray.length
4,vertexBuffer,GLES30.GL_STATIC_DRAW);GLES30.glBindBuffer(GLES30.GL_ARRAY_BUFFER,
initShaderProgram(vertexShaderCode,
着色器是一段给GPU执行的程序所以其实就是一段代码我们需要调用对应接口来编译链接。
GLES30.glCreateShader创建一个Shader参数表示着色器的类型GL_VERTEX_SHADER为顶点着色器GL_FRAGMENT_SHADER为片段着色器。
vertexShaderCode字符串是我们配置的顶点着色器gl_Position是出参这里是直接做了透传。
fragmentShaderCode是片段着色器gl_FragColor是出参是颜色而uniform
vColor是统一变量我们设置统一变量直接作为片段着色器的出参。
通过api编译连接后我们会将它关联到一个Program上initShaderProgram返回到就是program到id。
GLES30.glCreateShader(GLES30.GL_VERTEX_SHADER);GLES30.glShaderSource(vertexShader,
vertexShaderCode);GLES30.glCompileShader(vertexShader);//
GLES30.glCreateShader(GLES30.GL_FRAGMENT_SHADER);GLES30.glShaderSource(fragmentShader,
fragmentShaderCode);GLES30.glCompileShader(fragmentShader);//
GLES30.glCreateProgram();GLES30.glAttachShader(program,
vertexShader);GLES30.glAttachShader(program,
fragmentShader);GLES30.glLinkProgram(program);return
使用编译好的着色器GLES30.glUseProgram(shaderProgramId);//
首先我们需要调用glClear清空屏幕glUseProgram配置着色器程序glBindBuffer绑定之前填充的Buffer。
属性需要通过glEnableVertexAttribArray使能才可使用我们这里需要使能vPosition属性。
后续会使用glVertexAttribPointer告诉GPU顶点缓冲区布局情况顶点缓冲区本质就是一段内存不过没有glVertexAttribPointerGPU并不知道怎么使用这个数据。
后面配置vColor作为颜色(1,1,1,1)分别为RGBA白色。
清除屏幕GLES30.glClear(GLES30.GL_COLOR_BUFFER_BIT);//
使能着色器程序GLES30.glUseProgram(shaderProgramId);//
绑定BufferGLES30.glBindBuffer(GLES30.GL_ARRAY_BUFFER,
GLES30.glGetAttribLocation(shaderProgramId,
属性需要使能才可使用GLES30.glEnableVertexAttribArray(positionLocation);//
这是CPU向GPU传数据的一种方式我们这里是告诉GPU我们前面bind的顶点缓冲区是什么数据。
//
第一个参数是attr的id第二个参数表示每一个顶点有几个数第三个参数为数据类型第四个是参数是否需要归一化//
第五个参数是步长表示每个顶点占用了多少字节0表示顶点都是紧凑的GPU会通过计算来计算步长最后一个参数表示offset。
GLES30.glVertexAttribPointer(positionLocation,
GLES30.glGetUniformLocation(shaderProgramId,
vColor);GLES30.glUniform4f(colorLocation,
调用DrawCall绘制三角形GLES30.glDrawArrays(GLES30.GL_TRIANGLES,
清除配置GLES30.glDisableVertexAttribArray(positionLocation);GLES30.glBindBuffer(GLES30.GL_ARRAY_BUFFER,
ES实现了一个三角形的渲染对于每个接口使用只做了一个简单的介绍想必首次学习OpenGL的同学会有很多疑问比如怎么渲染多个目标怎么实现渐变颜色等我们的后续会对每一个点做更细节的学习这一节主要是了解一下OpenGL的总体渲染流程大概知道OpenGL接口是怎么工作的即可后续的介绍也会基于本章的demo。
作为专业的SEO优化服务提供商,我们致力于通过科学、系统的搜索引擎优化策略,帮助企业在百度、Google等搜索引擎中获得更高的排名和流量。我们的服务涵盖网站结构优化、内容优化、技术SEO和链接建设等多个维度。
| 服务项目 | 基础套餐 | 标准套餐 | 高级定制 |
|---|---|---|---|
| 关键词优化数量 | 10-20个核心词 | 30-50个核心词+长尾词 | 80-150个全方位覆盖 |
| 内容优化 | 基础页面优化 | 全站内容优化+每月5篇原创 | 个性化内容策略+每月15篇原创 |
| 技术SEO | 基本技术检查 | 全面技术优化+移动适配 | 深度技术重构+性能优化 |
| 外链建设 | 每月5-10条 | 每月20-30条高质量外链 | 每月50+条多渠道外链 |
| 数据报告 | 月度基础报告 | 双周详细报告+分析 | 每周深度报告+策略调整 |
| 效果保障 | 3-6个月见效 | 2-4个月见效 | 1-3个月快速见效 |
我们的SEO优化服务遵循科学严谨的流程,确保每一步都基于数据分析和行业最佳实践:
全面检测网站技术问题、内容质量、竞争对手情况,制定个性化优化方案。
基于用户搜索意图和商业目标,制定全面的关键词矩阵和布局策略。
解决网站技术问题,优化网站结构,提升页面速度和移动端体验。
创作高质量原创内容,优化现有页面,建立内容更新机制。
获取高质量外部链接,建立品牌在线影响力,提升网站权威度。
持续监控排名、流量和转化数据,根据效果调整优化策略。
基于我们服务的客户数据统计,平均优化效果如下:
我们坚信,真正的SEO优化不仅仅是追求排名,而是通过提供优质内容、优化用户体验、建立网站权威,最终实现可持续的业务增长。我们的目标是与客户建立长期合作关系,共同成长。
Demand feedback