首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    OpenGL ES(三) 纹理

    纹理是一种应用到OpenGL绘图场景中三角形上的图像数据,它通过经过过滤纹理单元填充到实心区域。...下面是OpenGL ES载入一个简单纹理的例子 -(void)setupGL{ // 创建设备上下文,用OpenGL ES 2.0的API GLKView *view = (GLKView...GLKVector4Make(1.0f, 1.0f, 1.0f, 1.0f);// 设置三角形颜色(注:如果开启光照,这里的颜色将会失效) // 顶点数据(前3列是顶点数据,一共6个顶点构成一个矩形,后2列是纹理坐标...,这里需要注意纹理坐标原点和OpenGL ES的绘图坐标的原点是不一样的 // OpenGL ES的绘图坐标的原点在屏幕中间 // 纹理坐标分为两种情况:在使用GLKit时,纹理坐标在右上角...self.baseEffect.texture2d0.name = textureInfo.name; self.baseEffect.texture2d0.target = textureInfo.target; // 变换(OpenGL

    56550

    OpenGL ES 绘制纹理

    OpenGL ES中绘制一张图片需要使用到纹理(texture),绘制纹理步骤如下: 编写shader 绘制纹理的shader需要顶点数据、纹理顶点数据和纹理。...v_TexCoord:Vertex Shader传递过来的纹理顶点数据,texture2D是OpenGL ES内置函数,称之为采样器,获取纹理上指定位置的颜色值。...创建program并获取参数句柄 创建program的过程在《OpenGL ES for Android 环境搭建》中详细介绍,这里不在介绍,直接使用封装好的工具类,代码如下: private fun...90度,通过此方法可以旋转、镜像纹理,但我们一般不会使用此方法旋转、镜像纹理,可以通过OpenGL ES中著名的MVP矩阵进行此操作。...纹理创建成功后返回纹理id,将Bitmap传递给此纹理,代码如下: import android.opengl.GLUtils GLUtils.texImage2D(GLES20.GL_TEXTURE_

    1.1K20

    Android OpenGL ES 纹理

    Rouse 读完需要 14 分钟 速读仅需 5 分钟 之前我们一直都是在绘制简单的图形与颜色,如果是一张图片该如何通过OpenGL ES进行渲染出来呢?...OpenGL ES的渲染方式是通过纹理来绘制出图片,通过纹理将图片像素值传递到对应位置,最终渲染出来。...下面我们将纹理坐标扩大5倍看下两种方式的处理效果。 填充与绑定纹理 我们通过加载本地的一种图片,将其通过OpenGL 进行渲染出来。 首先我们将本地的图片转化成Bitmap。...纹理处理的方式也并不难,相信一路走下来的同学都有所体会 这也进一步说明OpenGL ES也没有很难,只是我们开始对它的使用方式不熟悉,因为它与我们正常的展示一张图片的方式完全不同,但明白它的处理方式之后...也希望能够帮助大家对OpenGL ES有一个全面的了解。 OpenGL ES 系列 Android OpenGL ES 基础原理 Android OpenGL ES 渲染模式

    1.1K10

    OpenGL 学习系列 --- 纹理

    基本原理 要注意到,OpenGL 绘制的物体是 3D 的,而纹理是 2D 的,那么纹理映射就是将 2D 的纹理映射到 3D 的物体上,可以想象成用一张纸裹着一个物体一样,不过要按照一定规律来。...OpenGL 中绘制的物体是有坐标系的,每个点都对应 x、y、z 坐标,而纹理也有着它的坐标,只要 3D 物体中的每个点都对应了 2D 纹理中的某个点,那么就可以把纹理映射到 3D 物体上去了。...和要创建一个 OpenGL ProgramId 类似,使用纹理也需要创建一个纹理 ID。...OpenGL,读入 Bitmap 定义的位图数据,并把它复制到当前绑定的纹理对象 32 // 当前绑定的纹理对象就会被附加上纹理图像。...当一个纹理被绑定时,在绑定的目标上的 OpenGL 操作将作用到绑定的纹理上,并且,对绑定的目标的查询也将返回其上绑定的纹理的状态。

    1.5K10

    OpenGL ES纹理详解

    使用前面学过的技术已经可以利用OpenGL ES构建立体图形,并通过顶点着色器和片元着色器对其进行各种变化呢和光照等效果使得三维效果更加真实,实际上我看看到很多的3D游戏漂亮多了,那是因为有各种各样的漂亮的图像带给人很多视觉盛宴...纹理概念 纹理用来表示图像照片或者说一系列的数据,使用纹理可以使物体用用更多的细节。OpenGL ES 2.0 中有两种贴图:二维纹理和立方体纹理。...在OpenGL中规定纹理图像的左下角由stst坐标(0.0,0.0)指定,右上角由stst坐标(1.0,1.0)指定,不过超过1.0的坐标也是允许的,在该区间之外的纹理在读取时的时候由纹理拉伸模式决定。...OpenGL ES 2.0不必是正方形,但是每个维度都应该是2的幂 在Android中使用的OpenGL ES的纹理坐标系跟官方的纹理坐标系统不一样,在Android中使用官方的纹理坐标系统,得到的结果是相反的...,targetTexture2D,targetTexture3D,targetTextureCube…),OpenGL ES 2.0貌似只支持了targetTexture2D和targetTextureCube

    1.8K40

    OpenGL ES 2.0 (iOS):基础纹理

    Texture 纹理,就是一堆被精心排列过的像素; 因为 OpenGL 就是图像处理库,所以 Texture 在 OpenGL 里面有多重要,可想而知; 其中间接地鉴明了一点,图片本身可以有多大变化,OpenGL...; 【有没有注意到,CubeMap 里面就是直接拷贝顶点数据到纹理坐标上,就行了。...,它的核心知识在 Fragment Shader【重点】 + OpenGL ES 提供的基础混合模式【滤波 + Blend】,放在下一篇文章专门讲; 粒子系统:Texture + Point Sprites...;】 【MipMapping 发挥作用的地方就是在缩小的时候,OpenGL 会自动选择合适大小的像素数据】 如果纹理像素在 x、y 方向上是做同一个动作【拉伸或压缩】,则需要放大或缩小像素;如果纹理像素在...x、y 方向上是做不同的动作,则需要放大或者缩小,不确定【由 OpenGL 自己选择】; WRAP_S / WRAP_T ?

    2K43

    理解 OpenGL ES 混合

    OpenGL ES 混合 OpenGL ES 混合本质上是将 2 个片元的颜色进行调和,产生一个新的颜色。...OpenGL ES 混合发生在片元通过各项测试之后,准备进入帧缓冲区的片元和原有的片元按照特定比例加权计算出最终片元的颜色值,不再是新(源)片元直接覆盖缓冲区中的(目标)片元。...OpenGLES 混合方程: Cresult=Csource∗Fsource + Cdestination∗Fdestination 其中: Csource:源颜色向量,来自纹理的颜色向量; Cdestination...启用 OpenGL ES 混合使用 glEnable(GL_BLEND);。 然后通过 glBlendFunc;设置混合的方式,其中 sfactor 表示源因子,dfactor 表示目标因子。...: 混合结果颜色 RGB 向量 = 源颜色 RGB 向量 × alpha + 目标颜色 RGB 向量 × (1- alpha); 混合结果颜色 alpha = 源颜色 alpha × 1 + 目标颜色

    1.2K20

    OpenGLES(七)-GLSL案例:纹理颜色混合OpenGLES(七)-GLSL案例:纹理颜色混合

    OpenGLES(七)-GLSL案例:纹理颜色混合 首先放出效果 效果图 原图: 原图 通过对比可以看出纹理和颜色进行了混合效果,下面就放出实现过程. vsh attribute vec4 position...varyingTexCoord = textureCoord; gl_Position = position; } 由于片元着色器无法接受外部的顶点数据和顶点颜色,当然可以通过uniform关键词,直接将混合颜色传入片元着色器...如果纹理和颜色都是不透明的,则无法进行混合,只会进行覆盖.所以我们自定义了一个透明度。...这里的计算公式是根据OpenGL中的颜色混合参数得到的:glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA),如果对这个公式陌生可以看看这篇文章:OpenGL...(七)- 渲染技巧:颜色混合 content、layer、renderbuffer、framebuffer、shader初始化,图片加载都与这篇文章一致.传送门 render放出最核心的代码

    62230

    OpenGL 从入门到成魔-第7章-纹理纹理坐标

    注:参考自bilibili系列视频,OpenGL 从入门到成魔-第7章-纹理纹理坐标,更详细的内容可以从视频获取https://www.bilibili.com/video/BV1bZ4y1W7tX...第二个参数为纹理指定多级渐远纹理的级别,如果你希望单独手动设置每个多级渐远纹理的级别的话。这里我们填0,也就是基本级别。 第三个参数告诉OpenGL我们希望把纹理储存为何种格式。...一个shader中,最多处理32个纹理单元,openGL es,最多处理16个。 纹理坐标 ?...image.png GLSL内建的texture函数来采样纹理的颜色,它第一个参数是纹理采样器,第二个参数是对应的纹理坐标。texture函数的返回值就是,在该纹理坐标上的rgba值(vec4)。...这是因为OpenGL要求y轴0.0坐标是在图片的底部的,但是图片的y轴0.0坐标通常在顶部。

    2.3K20

    OpenGL ES实践教程(九)OpenGL与视频混合

    Mirror OpenGL ES实践教程4-Demo04-VR全景视频播放 OpenGL ES实践教程5-Demo05-多重纹理实现图像混合 OpenGL ES实践教程6-Demo06-全景视频获取焦点...OpenGL ES实践教程7-Demo07-多滤镜叠加处理 OpenGL ES实践教程8-Demo08-blend混合与shader混合 其他教程请移步OpenGL ES文集。...核心思路 用AVFoundation处理视频合并的时间轴关系(混合规则),用OpenGL ES处理两个视频图像混合。...2、配置OpenGL ES渲染到纹理 通过CVOpenGLESTextureCacheCreateTextureFromImage方法,创建目标纹理destTextureRef,并且用glFramebufferTexture2D...总结 这里的视频混合,为了节省开发时间,OpenGL ES的上下文管理用的GLKit,视频混合部分用的顶点来简单区分,如果要深入开发,需要用自己的shader来处理视频混合的规则。

    3K70

    OpenGL(七)- 渲染技巧:颜色混合OpenGL(七)- 渲染技巧:颜色混合

    OpenGL(七)- 渲染技巧:颜色混合 我们都知道颜色缓存区和深度缓冲区原理一致,在同一个位置上只能保存一个值。那么我们常见的透明图层相互之间的影响又是为什么呢?...现在要做的就是需要将两个颜色进行混合才为更为合理,但计算机并没有那么智能需要开发者来进行混合后颜色的计算。...当然OpenGL也考虑到了这一点: void RenderScene(void){ //1.清空颜色缓存区 glClear(GL_COLOR_BUFFER_BIT) //2.开启混合...D表示: 目标混合因子 对应上方公式开发者能操作的其实只有S、D这两个混合因子,下图是API中两个参数的参数表。 ?...开启混合后这种情况依旧会进行混合计算。所以颜色混合一般用在:一个半透明/不透明的物体前面绘制一个半透明的物体。

    98330

    OpenGL进行立方体表面纹理贴图

    一、目的 掌握OpenGL纹理对象的创建、绑定与使用方法。...); // 纹理和四边形的左上 // 后面 glTexCoord2f(1.0f, 0.0f); glVertex3f(-1.0f, -1.0f, -1.0f); // 纹理和四边形的右下...glutInitWindowSize(600, 600); //显示框的大小 glutInitWindowPosition(100, 100); //确定显示框左上角的位置 glutCreateWindow("OpenGL...放置需要贴纹理的位图文件 五、总结 这是我在学校做的图形学纹理贴图实验,放暑假了一直忙着准备考研,今天突然想起应该把以前做的实验整理一下,于是找到了这个实验。...纹理贴图是一个很有趣的实验,它就像一层嫁衣,为你所创建的目标对象披上一件外衣,让别人看着赏心悦目,当然我目前所学的只是对规则物体进行纹理贴图,以后还会遇到不规则的物体等。

    2.2K40
    领券