首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

三个js面顶点uv贴图三角形:如何仅缩放1个方向

三个js面顶点uv贴图三角形是指在Three.js中使用三个顶点和对应的UV贴图坐标来创建一个三角形。UV贴图是一种将2D纹理映射到3D模型表面的技术,它通过在模型表面的每个顶点上定义UV坐标来实现。

要实现仅缩放一个方向的效果,可以通过修改UV坐标来实现。UV坐标的范围通常是0到1,其中0表示纹理的起始位置,1表示纹理的结束位置。如果要在某个方向上进行缩放,只需将对应方向上的UV坐标进行调整即可。

具体实现步骤如下:

  1. 创建一个三角形的几何体(Geometry)对象。
  2. 在几何体对象中定义三个顶点的位置坐标。
  3. 在几何体对象中定义三个顶点的UV坐标,根据需要进行缩放调整。
  4. 创建一个材质(Material)对象,可以使用基本材质(MeshBasicMaterial)或其他类型的材质。
  5. 将几何体对象和材质对象传入网格(Mesh)对象中。
  6. 将网格对象添加到场景(Scene)中进行渲染。

以下是一个示例代码片段,展示了如何在Three.js中创建一个仅缩放一个方向的三角形:

代码语言:txt
复制
// 导入Three.js库
import * as THREE from 'three';

// 创建场景
const scene = new THREE.Scene();

// 创建几何体对象
const geometry = new THREE.Geometry();
geometry.vertices.push(
  new THREE.Vector3(-1, -1, 0),
  new THREE.Vector3(1, -1, 0),
  new THREE.Vector3(0, 1, 0)
);

// 定义UV坐标
geometry.faceVertexUvs[0].push([
  new THREE.Vector2(0, 0),
  new THREE.Vector2(1, 0),
  new THREE.Vector2(0.5, 1)
]);

// 创建材质对象
const material = new THREE.MeshBasicMaterial({
  map: new THREE.TextureLoader().load('texture.png')
});

// 创建网格对象
const mesh = new THREE.Mesh(geometry, material);

// 将网格对象添加到场景中
scene.add(mesh);

// 创建相机
const camera = new THREE.PerspectiveCamera(75, window.innerWidth / window.innerHeight, 0.1, 1000);
camera.position.z = 5;

// 创建渲染器
const renderer = new THREE.WebGLRenderer();
renderer.setSize(window.innerWidth, window.innerHeight);
document.body.appendChild(renderer.domElement);

// 渲染场景
function animate() {
  requestAnimationFrame(animate);
  mesh.rotation.x += 0.01;
  mesh.rotation.y += 0.01;
  renderer.render(scene, camera);
}
animate();

在上述代码中,我们创建了一个包含三个顶点和对应UV坐标的几何体对象,并使用基本材质进行渲染。UV坐标的缩放调整可以通过修改geometry.faceVertexUvs[0]中的UV坐标值来实现。

注意:以上示例代码仅为演示目的,实际应用中可能需要根据具体需求进行适当的修改和优化。

推荐的腾讯云相关产品和产品介绍链接地址:

  • 腾讯云云服务器(CVM):https://cloud.tencent.com/product/cvm
  • 腾讯云对象存储(COS):https://cloud.tencent.com/product/cos
  • 腾讯云人工智能(AI):https://cloud.tencent.com/product/ai
  • 腾讯云物联网(IoT):https://cloud.tencent.com/product/iot
  • 腾讯云区块链(BCB):https://cloud.tencent.com/product/bcb
  • 腾讯云云原生应用引擎(TKE):https://cloud.tencent.com/product/tke

请注意,以上链接仅供参考,具体产品选择应根据实际需求进行评估和决策。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

【带着canvas去流浪(12)】用Three.js制作简易的MARVEL片头动画(上)

3.2 纹理贴图的基本原理-UV映射 在Three.js中,几何体是通过点和面的特征构建起来的,如果将一个几何体实例对象在控制台打印出来,就可以看到存储端点坐标信息的vertexs和存储信息的faces...右图中白色三角形三个顶点在归一化坐标系中的坐标值已经列出,将[0.2,0.2],[0.2,0.8],[0.7,0.2]这三个坐标点信息填充到对应的UV映射数组中后,Three.js就会用这个三角形区域来对一个三角进行贴图...由于默认是三角,所以我们通过实例化3个THREE.Vector2(x,y)对象来表示从素材中截取的三角形区域,得到了素材后要如何将它与三角面的顶点坐标对应起来呢?...由于贴图素材是三个点,几何体某个三角也是有三个顶点,如果不限制索引,那么就可能存在很多种贴图结果: ?...为了保证贴图素材的方向,它们之间就有存在一个对应关系,否则最后渲染的纹理可能就是倒着的或者旋转90°的图像,所以UV映射矩阵中存储的依然是上例中右图的三个点,但默认索引和构成几何体指定面的三个顶点的索引相对应

3.1K51

基础渲染系列(六)——凹凸

但是,单个三角形的表面却始终是光滑的。它只能在三个法线向量之间插值。因此它不能代表粗糙或变化的表面。当放弃反照率纹理并使用纯色时,这会变得非常明显。 这种平直度的一个很好的例子是一个简单的四边形。...然后启用主方向光。在场景视图中找到一个好的视角,以便在四边形上可以有一些光差异。 ? ? (无环境光,只有主方向光) 我们如何使这个四边形看起来不平坦呢?...因此我们可以使用常量法线,而忽略顶点数据。现在暂时这样试试,稍后再考虑不同的方向。 ? 如何在其中包括高度数据? 最傻的方法是在标准化之前将高度用作法线的Y分量。 ? ?...(现在增加了反照率贴图) 无需为细节UV添加插值器,而是将主UV和细节UV手动打包到一个插值器中。主UV进入XY,细节UV进入ZW。 ? 添加所需的变量,然后将插值器填充到顶点程序中。 ?...(展示完整的切线空间) 你可以看到切线空间是不同的,但默认立方体的每个都是恒定的。在默认球体的情况下,每个顶点的切线空间不同。结果,切线空间将跨三角形插值,从而形成弯曲的空间。 ?

3.7K40
  • 3D 可视化入门:渲染管线原理与实践

    图元是基本可绘制单元,一般指 「点、线段 和 三角形」,其本质上是顶点的集合。比如线段就是两个顶点三角形就是三个顶点。...但要注意三角形顶点是有顺序的,三角形顶点顺序是顺时针(cw)还是逆时针(ccw),决定构成的整个三角是面朝相机还是背朝相机。这个信息很重要,后续步骤可以将背朝相机的剔除。...光照向物体后,被均匀地反射到所有方向,因此,不管观察者的角度如何,物体同一个位置的光照效果都是一样的。照亮效果与光照强度、物体漫反射系数和光照角度与物体表面法线的夹角有关。...着色有以下几种方法: 7.3.1 平面着色 - Flat Shading 一个三角形三个顶点,我们选择一个代表顶点(第一个顶点,或者三角面的法线和颜色均值),在给三角形着色时,针对这个顶点的颜色和法线计算光照效果...回顾一下,我们的光是局部光照模型,取决于物体表面本身的属性和直接光源的颜色,镜面高光也只是高光... 我真的想做一镜子,如果上不了光线追踪,应该怎么处理? 这就要请出环境贴图了。

    6.7K21

    科普:零基础了解3D游戏开发

    UV其实也是坐标, 完整的说应该是UVW(由于xyz已经被顶点坐标轴占用,所以另选三个字母表示), 这三个轴U是屏幕水平方向,V是屏幕垂直方向,W的方向是垂直于显示器表面的,到目前为止,一般游戏开发是用不上的...去掉了W,那UV坐标就是一个2D平面坐标,UV坐标可用于模型纹理贴图等(后面介绍纹理的时候还会提及)。 4-2.png UV坐标的贴图纹理向右和向下分别是U与V的坐标正方向。...要进一步了解模型,我们先从三角形平面(简称三角)开始,三角是由三个顶点构成,是显卡唯一能处理的基础多边形。...下图左侧为添加材质,而没有设置贴图的效果。下图右侧是对材质添加了纹理的已贴图效果。...其中,材质动画是以改变材质的颜色与贴图方式的动画。 刚体动画又称为变换动画,是指不改变模型顶点、材质的基础上,只对模型进行旋转、缩放、位移的动画,比如,脚底光环、刀光等。

    9.4K52

    基础渲染系列(二十)——视差(基础篇完结)

    我们可以在顶点程序中确定此向量,然后将其转换为片段向量。我们推迟归一化,在插值之后,我们得到正确的方向。然后,需将切线空间视图方向添加为新的插值器。 ? 我们有第九个插值器的空间吗?...不支持此功能的硬件通常功能不是很强大,因此无论如何你都不希望使用视差贴图。 使用原始顶点切线和网格数据中的法线向量在顶点程序中创建对象到切线的空间转换矩阵。...由于我们将其用于转换矢量(而不是位置),因此3×3矩阵就足够了。 ? 接下来,我们需要查看对象空间中顶点位置的方向,为此可以使用ObjSpaceViewDir函数。...(沿投影视图方向移动UV) 1.5 根据高度滑动 我们可以使表面看起来更高,但是仍然是均匀的位移。下一步是使用视差贴图缩放位移。...同样,两种方法的投影视图方向和偏移量的最终应用将相同。因此,将偏移量计算也放在自己的函数中。它需要原始UV坐标和已处理的视图方向作为参数。其结果是要应用的UV偏移。 ?

    3.1K20

    进阶渲染系列(七)——三向贴图(任意表面纹理化)【进阶篇完结】

    (Triplanar贴图材质,使用法线作为反照率) 2 三纹理化 当顶点UV坐标不可用时,我们如何执行纹理映射?唯一可行的方法是将世界位置(或许是对象空间位置)用作纹理映射的UV坐标的替代来源。...首选的贴图自然是最能与表面方向对齐的贴图,该贴图由表面法线表示。因此,我们可以使用法线来定义所有三个投影的权重。使用法线向量的绝对值,因为表面可以面向负方向。...(具有地图比例尺的材质) 添加贴图比例尺所需的变量,并在确定UV坐标时使用它缩放位置。 ? ?...(使用2倍贴图缩放) 4 调整混合权重 通过使用原始表面法线在三个贴图之间进行混合,可以找到最终的表面数据。到目前为止,我们直接使用法线,取其绝对值并对结果进行归一化,以使权重之和为1。...(只有贴图缩放) 5.3 贴图贴图部分创建一个标签,然后显示三个纹理属性,每个属性都在一行上。给MOHS映射一个工具提示,以解释每个通道应包含的内容。 ? ?

    2.4K30

    Unity3D学习笔记2——绘制一个带纹理的

    那么这里就将三角形扩展为一个矩形的,并且为这个贴上纹理。 2. 详论 2.1. 网格(Mesh) 前面说到网格是渲染物体的骨架,因此还是先要把渲染物体的架子搭好。...顶点 因为我们要创建一个矩形的,所以需要创建四个顶点。仍然是像之前创建三角面的顶点一样,赋予顶点的空间位置属性xyz坐标。同时,我们还给Mesh赋予了4个uv坐标,4个法向量normal。...位置(position/vertice)、纹理坐标(uv/texCoord)、法向量(normal)是经常用到了三个顶点属性,但是顶点属性也不仅仅只有三个,甚至可以根据需要自定义。 2.1.2....顶点索引 一个矩形确定了四个顶点,但是需要划分成两个三角形,每个三角形引用3个顶点索引,也就是6个顶点索引。当然我们也可以使用6个顶点,按照自然顺序来确定顶点索引。但是这样一来,就浪费了空间存储。...Unity3D新建的材质默认为标准,是一种PBR材质,由多种贴图混合而成。我们这里暂时只设置Albedo贴图,也就是基本颜色贴图

    1K40

    Unity Mesh基础系列(一)生成网格(程序生成)

    这是一个纹理贴图,用来表示一个材质球的基本颜色。纹理贴图只有长和宽2个维度,而mesh往往是一个三维物体,所以要达到这个目的,我们需要知道如何将这个纹理投射到mesh的三角形上。...但是我们还不能在游戏里看到它,因为我们还没有给它定义三角形三角形是通过一系列顶点索引来定义的。由于每个三角形三个点,三个连续的索引就描述了一个三角形。让我们从一个三角形开始。 ?...三角形的哪一边可见是由它的顶点顺序的时钟方向决定的。默认情况下,如果它们按顺时针方向排列,则三角形被认为是前向的和可见的,逆时针方向三角形会被丢弃。...当我们创建一个扁平的矩形平面的时候,我们只需要两个三角形就足够了。这是绝对没问题的。但更多更复杂的结构的由最基础的几何来定义才能更好的控制和表现。...4 生成附加顶点数据 我们目前实现的方案是在一种极端的情况下完成的,因为我们的mesh没有给出任何的法线。默认的法线方向是 (0, 0, 1) ,但这不一定是我们想要的。 法线是如何作用的?

    9.9K41

    【笔记】《计算机图形学》(11)——纹理映射

    为了解决对立方体的投影问题, 引入了立方体投影, 这种投影的本质就是对目标表面的每个方向进行一次平面投影然后再组合为一个立方体, 其映射函数比较复杂因为需要对三个轴对应的六个方向都进行一次处理. ?...在使用立方体投影时, 要注意是通过当前需要查找的值的xyz值来确定所要从中查找的, 取当前xyz中值最大的来计算 ? 插值坐标系 为了应对更加复杂的表面, 针对于三角形进行的插值坐标系被提出....插值坐标系的特点是其映射是通过对每个顶点提前指定其位于纹理空间中的坐标, 然后利用重心坐标系插值的方法插值出三角形内每个位置所对应的UV纹理坐标....如下图可以看到模型的三角都被提前展开对应在纹理空间中, 渲染的时候就利用三角形三个顶点使用前面2.7介绍的重心插值法得到所需的坐标. ?...前面第10章介绍表面着色的时候我们知道物体表面的光照效果是依赖于表面法线的方向的, 默认情况下表面法线和当前三角片的方向相同, 但是其实并没有规定说表面法线一定要与方向相同, 我们其实可以随意改变着色器中参与光照计算的表面法线的方向

    4.2K41

    unity3d:Shader知识点,矩阵,函数,坐标转换,Tags,半透明,阴影,深度,亮度,优化

    它由以下三个矩阵的乘积组成: Model Matrix(模型矩阵):将三维模型从其局部坐标系变换到世界坐标系中的位置、旋转和缩放。...我们将 _WorldSpaceLightPos0.xyz 转化为一个四维向量,并乘以 unity_WorldToObject 的逆转置矩阵,然后取结果的前三个分量,即可得到从模型指向方向光的方向。...然后我们可以利用这个像素大小进行一些像素级别的计算,比如将纹理UV坐标缩放到像素级别。...切线空间是一种以顶点切线、法线和切线叉积向量为基础的局部坐标系,常用于处理带有法线贴图的模型。在切线空间中,每个顶点都有一个与之相关联的切线空间坐标系,可以用来描述该顶点上纹理的方向和曲率。...ZTest Always //关闭了背面剔除,即不管三角形是正面还是背面,都会被绘制。这意味着场景中的所有三角形都会被渲染,不再考虑其朝向。

    32710

    Unity Shader常用函数,标签,指令,宏总结(持续更新)

    (i.worldPos.xyz); 前向渲染,世界空间顶点位置 ==》世界空间光源方向,多用于片元着色器,一般会顺带归一化(fixed3) UnityWorldSpaceViewDir(i.worldPos.xyz...rgb(xyz);基本光照模型需要有环境光,漫反射,高光等 基本纹理&法线贴图: TRANSFORM_TEX(v.uv, _MainTex); 基本纹理变换,用于顶点着色器,相当于v.uv*_MainTex_ST.xy...(albedo),反射率作为环境光和漫反射计算的因子 UnpackNormalWithScale(packedNormal, _BumpScale); 反映射法线贴图采样结果得到顶点空间中的法线方向,同时计算凹凸映射的缩放...;packedNormal为法线贴图直接采样结果,_BumpScale为凹凸缩放值;法线贴图必须进行导入设置为Normal Map UnityObjectToWorldDir(v.tangent.xyz...); 方向(切线):模型空间 ==》世界空间,多用于顶点着色器 cross(worldNormal, worldTangent)*v.tangent.w 计算副法线,cross(,)两个向量叉积,用于得知两个坐标轴求第三个坐标轴朝向

    1.9K10

    网格UV展开

    图1 ---- 什么样的网格可以做UV展开 那是不是所有的网格都可以做UV展开呢?答案是否定的。只有圆盘拓扑结构的网格才能展开到平面上,比如一个球,无论如何都不可能在不撕裂的情况下展开到平面。...下面用一个图来解释(这里考虑三角网格的情况,其余情况类似): 可以看出顶点坐标与纹理坐标其实没有直接联系,他们是用过三角片间接联系起来的。它们之间没有一一对应的关系。...---- 顶点纹理坐标和三角形纹理坐标 严格来讲,顶点并没有纹理坐标的概念,只有三角形有纹理坐标的概念。...网格UV展开到平面的时候,如果没有割缝产生,那么每个顶点在其相邻三角形内的纹理坐标都是一样的,故可简称为顶点的纹理坐标。如果有割缝产生,割缝处的顶点在不同三角形内的纹理坐标是不一样的。...好的割缝,一般有这些性质: 长度很短 割线光滑 沿着特征边 分布在视觉不明显的地方 在全自动UV展开应用里,割缝首先要能把网格割成一片一片的圆盘结构 ---- 纹理贴图应用 网格UV展开经常用于纹理贴图应用

    3K30

    Three.js - 走进3D的奇妙世界

    ,无数三角形就能够组成各种形状的几何体。...以创建一个简单的立方体为例,创建简单的立方体需要添加8个顶点和12个三角形,创建顶点时需要指定顶点在坐标系中的位置,添加面的时候需要指定构成面的三个顶点的序号,第一个添加的顶点序号为0,第二个添加的顶点序号为...通过下图可以看到,按照0,2,1添加顶点是顺时针方向的,而按0,1,2添加顶点则是逆时针方向的,通过添加顶点方向就可以判断当前看到的是正面还是反面,如果顶点是逆时针方向添加,当前看到的是正面,如果顶点是顺时针方向添加...下图所看到的就是反面。如果不好记,可以使用右手沿顶点添加的方向握住,大拇指所在的就是正面,很像我们上学时学的电磁感应定律。...五、材质 创建几何体时通过指定几何体的顶点三角形确定了几何体的形状,另外还需要给几何体添加皮肤才能实现物体的效果,材质就像物体的皮肤,决定了物体的质感。

    8.4K20

    基于 HTML5 的 WebGL 自定义 3D 摄像头监控模型

    锥体建模 3D 模型是由最基础的三角形拼接合成,例如 1 个矩形可以由 2 个三角形构成,1 个立方体由 6 个即 12 个三角形构成, 以此类推更复杂的模型可以由许多的小三角形组合合成。...因此 3D 模型定义即为对构造模型的所有三角形的描述, 而每个三角形三个顶点 vertex 构成, 每个顶点 vertex 由 x, y, z 三维空间坐标决定,HT 采用右手螺旋定则来确定三个顶点构造三角形面的正面...,is 表示索引数组,uv 表示贴图坐标数组,如果想要单独定义某个,可以通过***bottom_vs,bottom_is,bottom_uv,top_vs,top_is, top_uv*** 等来定义...通过 pointArr 记录当前五体的五个顶点坐标信息,代码中通过 from_vs, from_is, from_uv 单独构建五体底面,底面用于显示当前摄像头呈现的图像。...以下为定义贴图位置 from_uv 的代码: from_uv: [ 0, 0, 1, 0, 1, 1, 0, 1 ] from_uv 就是定义贴图的位置数组,根据上图的解释

    1.3K20

    Three.js - 走进3D的奇妙世界

    ,无数三角形就能够组成各种形状的几何体。...以创建一个简单的立方体为例,创建简单的立方体需要添加8个顶点和12个三角形,创建顶点时需要指定顶点在坐标系中的位置,添加面的时候需要指定构成面的三个顶点的序号,第一个添加的顶点序号为0,第二个添加的顶点序号为...通过下图可以看到,按照0,2,1添加顶点是顺时针方向的,而按0,1,2添加顶点则是逆时针方向的,通过添加顶点方向就可以判断当前看到的是正面还是反面,如果顶点是逆时针方向添加,当前看到的是正面,如果顶点是顺时针方向添加...下图所看到的就是反面。如果不好记,可以使用右手沿顶点添加的方向握住,大拇指所在的就是正面,很像我们上学时学的电磁感应定律。 ?...6.4 环境光 环境光是经过多次反射而来的光,环境光源放出的光线被认为来自任何方向,物体无论法向量如何,都将表现为同样的明暗程度。 ?

    9.9K41

    三维网格表示

    比如特征尖锐的区域,可以设置面点法线为法线;在光滑区域,设置面点法线为顶点法线。 纹理坐标:纹理坐标是一个典型的面点属性。严格来讲,顶点并没有纹理坐标的概念,只有三角形有纹理坐标的概念。...网格UV展开到平面的时候,如果没有割缝产生,那么每个顶点在其相邻三角形内的纹理坐标都是一样的,故可简称为顶点的纹理坐标。如果有割缝产生,割缝处的顶点在不同三角形内的纹理坐标是不一样的。...和UV展开的区别在于,UV展开的二维域是唯一的,而点像对应的二维域(图像),有可能有多个(多张图片)。这导致某些三角片的面点可能对应于不同的图像域。对于这类三角片的纹理贴图,一般采用面点颜色插值。...比如正方体的一个角点,它有三个垂直的相邻,面点法线可以取对应的法线,而顶点法线则明显区别于这类面点法线。面点法线不是很常用。 看似简单的法线计算,要得到稳定的计算结果,需要考虑一些退化的情况。...比如网格内有退化的时候,该如何处理呢? 有兴趣的读者,欢迎参考视频:三维网格表示 网格半边结构

    66531

    告别传统机房:3D 机房数据可视化实现智能化与VR技术的新碰撞

    二、锥体建模 3D 模型是由最基础的三角形拼接合成,例如 1 个矩形可以由 2 个三角形构成,1 个立方体由 6 个即 12 个三角形构成, 以此类推更复杂的模型可以由许多的小三角形组合合成。...因此 3D 模型定义即为对构造模型的所有三角形的描述, 而每个三角形三个顶点 vertex 构成, 每个顶点 vertex 由 x, y, z 三维空间坐标决定,HT 采用右手螺旋定则来确定三个顶点构造三角形面的正面...,is 表示索引数组,uv 表示贴图坐标数组,如果想要单独定义某个,可以通过 bottom_vs,bottom_is,bottom_uv,top_vs,top_is, top_uv 等来定义,之后便可以通过...通过 pointArr 记录当前五体的五个顶点坐标信息,代码中通过 from_vs, from_is, from_uv 单独构建五体底面,底面用于显示当前摄像头呈现的图像。...以下为定义贴图位置 from_uv 的代码: from_uv: [0, 0, 1, 0, 1, 1, 0, 1] from_uv 就是定义贴图的位置数组,根据上图的解释,可以将 2d 图像贴到 3d 模型的

    1.1K10

    DAPP丨NFT卡牌盲盒农场对战链游系统开发技术说明及详细源码

    1.基于片实现:   直接用一个Quat的mesh,加上一张贴图,简单直观的实现.   ...,这样一来是方便裁剪,二来是裁剪完成后可以将变换后的坐标值直接作为uv值使用.   3.得到相交的三角形片:   判断每个点是否在投影框内,如果三角形有任意一个点在框内,则认为三角形与投影框相交.当然这种方法会漏掉一些三角形...,比如这中情况:当然如果mesh较小以及要求不精细的话也没有太大问题.   4.将所有相交的三角形片,合并成新的IndexBuffer,使用新的decal的纹理重新渲染一次,UV可以直接取映射到框中的xy...值,当然要注意在shader中把uv 0~1之外的部分clip掉   5.如果你想的话,也可以对处在边界,不完全在框内部的三角形进行裁剪,最后整理顶点生成新的mesh.   4.基于Multi-Pass...GreatEqual,输出一个标志位到stencil buffer(或者任意其他可以标志像素点的方式),不需要输出颜色值   3.再次将投影框作为长方体渲染,打开Face Cull(只绘制长方形靠前的三个

    50430

    基于 HTML5 WebGL + VR 的 3D 机房数据中心可视化

    锥体建模 3D 模型是由最基础的三角形拼接合成,例如 1 个矩形可以由 2 个三角形构成,1 个立方体由 6 个即 12 个三角形构成, 以此类推更复杂的模型可以由许多的小三角形组合合成。...因此 3D 模型定义即为对构造模型的所有三角形的描述, 而每个三角形三个顶点 vertex 构成, 每个顶点 vertex 由 x, y, z 三维空间坐标决定,HT 采用右手螺旋定则来确定三个顶点构造三角形面的正面...,is 表示索引数组,uv 表示贴图坐标数组,如果想要单独定义某个,可以通过 bottom_vs,bottom_is,bottom_uv,top_vs,top_is, top_uv 等来定义,之后便可以通过...通过 pointArr 记录当前五体的五个顶点坐标信息,代码中通过 from_vs, from_is, from_uv 单独构建五体底面,底面用于显示当前摄像头呈现的图像。...以下为定义贴图位置 from_uv 的代码: 1 from_uv: [0, 0, 1, 0, 1, 1, 0, 1] from_uv 就是定义贴图的位置数组,根据上图的解释,可以将 2d 图像贴到

    1.3K40

    Android开发笔记(一百五十六)通过渲染纹理展示地球仪

    三维物体的骨架是通过三维坐标系表示的,每个点都有x、y、z三个方向上的数值大小。那么三维物体的纹理也需要通过纹理坐标系来表达,但纹理坐标并非三维形式而是二维形式,这是怎么回事呢?...坐标定义的大小(UV坐标为0,0到1,1),这时需要告诉OpenGL库如何去渲染这些不存在的Texture部分。...(x,y,z)构成,因此若要表达三个顶点的空间位置,就需要大小为3*3=9的浮点数组。...因为材质是一片一片的花色,所以调用glDrawArrays绘制方法时,要指定采取GL10.GL_TRIANGLE_STRIP方式,表示本次绘图画的是一个三角形的平面,这样从位图对象裁剪出来的花纹就贴图完成了...gl.glTexCoordPointer(2, GL10.GL_FLOAT, 0, mTextureCoords.get(i)); //GL_LINE_STRIP只绘制线条,GL_TRIANGLE_STRIP才是画三角形

    1K30
    领券