Golang语言情怀--第117期 全栈小游戏开发:第8节:资源工作流

2023-11-21 15:33:06 浏览数 (1)

图像资源又经常被称作贴图、图片,是游戏中绝大部分图像渲染的数据源。图像资源一般由图像处理软件(比如 Photoshop、Windows 上自带的画图)制作而成并输出成 Cocos Creator 可以使用的文件格式,目前支持 JPG、PNG、BMP、TGA、HDR 格式。

导入图像资源

将图像资源直接拖拽到 资源管理器 即可将其导入到项目中,之后我们就可以在 资源管理器 中看到如下图所示的图像资源:

属性检查器 中图像资源的相关属性说明如下:

属性

说明

Type

用于设置图像资源的类型,包括 raw、texture(默认)、normal map、sprite-frame、texture cube,具体说明可参考下文 图像资源类型 部分的内容。

Flip Vertical

是否沿 X 轴垂直翻转导入的贴图。

useComponentTexture

是否使用压缩纹理,详情请参考 压缩纹理。

图像资源的类型

在 资源管理器 面板选中导入的图像资源,在 属性检查器 面板中便可根据需要设置图像资源的使用类型,目前支持以下几种:

  • raw:原始图片类型,无作用,用户不需要关心。
  • texture:图像资源类型,也是导入的图像资源的默认类型,详情可参考 纹理贴图资源。
  • normal map:法线贴图类型,常用于渲染 3D 模型,可在模型材质中勾选 USE NORMAL MAP 属性使用。需要注意的是,如果材质中没有定义 USE NORMAL MAP 就没有该属性。
  • sprite-frame:精灵帧资源,用于 UI 制作上,详情可参考 SpriteFrame。
  • texture cube:立方贴图类型,使用在全景图上,常用于制作天空盒。详情可参考 立方体贴图。

子资源

每个图像资源导入后或者设置图像资源类型后,编辑器便会自动在其下方创建相应类型的子资源。在 资源管理器 中点击图像资源左侧的三角图标,即可展开查看图像资源的子资源。

下图以 texture 类型的图像资源为例:

子资源的详细属性说明请参考对应资源类型的文档说明。normal map 的子资源属性与 texture 一致,可参考如下

纹理贴图资源(Texture)

纹理贴图资源是一种用于程序采样的资源,如模型上的贴图、精灵上的 UI。当程序渲染 UI 或者模型时,会使用纹理坐标获取纹理颜色,然后填充在模型网格上,再加上光照等等一系列处理便渲染出了整个场景。

纹理贴图资源可由图像资源(ImageAsset)转换而来,图像资源包括一些通用的图像转换格式如 PNG、JPEG 等等。

Texture2D

Texture2D 是纹理贴图资源的一种,通常用于 3D 模型的渲染,如模型材质中的反射贴图、环境光遮罩贴图等等。

在将图像资源 导入 到 Creator 后,即可在 属性检查器 面板将其设置为 texture 类型,texture 类型便是 Texture2D 纹理资源。

Texture2D 属性

当导入图像资源时,编辑器默认将其设置为 texture 类型,并且在导入的图像资源下会自动创建一个或多个子资源,点击 资源管理器 中图像资源左侧的三角图标即可展开查看所有的子资源,如下图所示:

选中生成的 Texture2D 子资源后可以在 属性检查器 设置相关属性:

属性

说明

Anisotropy

各向异性值,应用各向异性过滤算法的最大阈值

Min/Mag Filter

缩小或者放大贴图时采用的纹理过滤方式,可选项包括 nearest(默认)和 linear。详情请参考下文 过滤方式 部分的内容

Mip Filter

多级纹理过滤算法,可选项包括 none、nearest 和 linear,当设置为 nearest 或者 linear 时,便会自动生成 mipmap。详情请参考下文 genMipmaps 部分的内容

Wrap Mode S/T

设置 S(U)/ T(V)方向上的纹理寻址模式,也就是像素对纹理在 S(U)或者 T(V)方向上的映射模式。可选项包括 repeat(默认)、clamp-to-edge 和 mirrored-repeat。详情请参考下文 寻址模式 部分的内容

注意:由于默认的 Wrap Mode 在渲染图像的透明边缘时可能会出现黑边,所以在将图像资源类型设置为 sprite-frame 时,Creator 会自动将 texture 资源的 Wrap Mode S 和 Wrap Mode T 属性自动调整为 clamp-to-edge。如有特殊需要,开发者可以自行修改。

接下来我们对部分属性进行简单的说明。

过滤方式

当 Texture2D 的原始大小与屏幕映射的纹理图像尺寸不一致时,通过不同的纹理过滤方式进行纹理单元到像素的映射会产生不同的效果。

Texture2D 中的 Min Filter 和 Mag Filter 属性,分别用于设置在缩小或者放大贴图时采用的纹理过滤方式:

  1. 邻近过滤(nearest) 邻近过滤是 默认 使用的纹理过滤方式。使用中心位置距离采样点最近的纹理单元颜色值作为该采样点的颜色值,不考虑其他相邻像素的影响。 需要注意的是使用临近过滤方式可能会出现边缘不平滑,锯齿较为明显的情况。
  2. 线性过滤(linear) 线性过滤使用距离采样点最近的 2 x 2 的纹理单元矩阵进行采样,取四个纹理单元颜色值的平均值作为采样点的颜色,像素之间的颜色值过渡会更加平滑。 需要注意的是使用线性过滤方式可能会出现边缘黑边的情况,如果是像素类游戏,可能会出现模糊情况。

genMipmaps

为了加快 3D 场景渲染速度和减少图像锯齿,贴图被处理成由一系列被预先计算和优化过的图片组成的序列,这样的贴图被称为 mipmap。mipmap 中每一个层级的小图都是原图的一个特定比例的缩小细节的复制品,当贴图被缩小或者只需要从远距离观看时,mipmap 就会转换到适当的层级。

当 Texture2D 的 Mip Filter 属性设置为 nearest 或者 linear 时,会在两个相近的层级之间插值,自动生成 mipmap(仅对非压缩格式生效)。因为渲染远距离物体时,mipmap 贴图比原图小,提高了显卡采样过程中的缓存命中率,所以渲染的速度得到了提升。同时因为 mipmap 的小图精度较低,从而减少了摩尔纹现象,可以减少画面上的锯齿。另外因为额外生成了一些小图,所以 mipmap 需要额外占用约三分之一的内存空间。

寻址模式

一般来说,纹理坐标在水平轴(U)和垂直轴(V)的取值范围为 [0,1],当传递的顶点数据中的纹理坐标取值超出 [0,1] 范围时,就可以通过不同的寻址模式来控制超出范围的纹理坐标如何进行纹理映射。

Texture2D 中的 Wrap Mode S 和 Wrap Mode T 属性便是分别用于设置纹理在 UV 方向上的寻址模式:

  1. 重复寻址模式(repeat) 重复寻址模式是默认使用的纹理寻址模式。对于超出 [0,1] 范围的纹理坐标,使用 [0,1] 内的纹理坐标内容不断重复,也就是在超出纹理坐标范围外的地方重复放置纹理贴图。 注意:在 WebGL1.0 平台,当贴图宽高不是二次幂时,repeat 寻址模式是无效的。运行时会自动将其切换为 clamp-to-edge 寻址模式,这将会使材质的 tilingOffset 等属性失效。 当 Texture2D 的 Wrap Mode S 和 Wrap Mode T 属性都设置为 repeat 时,效果图如下:
  1. 钳位寻址模式(clamp-to-edge) 将纹理坐标约束在 0 到 1 之间,只复制一遍 [0,1] 的纹理坐标。对于 [0,1] 之外的部分,将使用边缘的纹理坐标内容进行延伸,产生类似边缘被拉伸的效果。 当两个属性都设置为 clamp-to-edge 时,效果图如下:
  1. 镜像寻址模式(mirrored-repeat) 类似重复寻址模式,只不过贴图是镜像重复放置的。 当两个属性都设置为 mirrored-repeat 时,效果图如下:

使用 Texture2D

Texture2D 是使用范围非常广泛的资源,在 Creator 中的使用方式主要包括在编辑器中使用和动态获取使用:

在编辑器的 属性检查器 面板中,任何标记为 Texture2D 类型的属性,都可以将 Texture2D 资源拖拽到属性框中使用。例如设置材质资源的 Texture2D 类型资源:

注意:如果材质中没有定义 USE TEXTURE 就没有该属性。

动态使用时,需要先获取图像资源(ImageAsset),然后根据获取到的 ImageAsset 实例化出 Texture2D 资源。

代码语言:javascript复制
resources.load("testAssets/image/texture", Texture2D, (err: any, texture: Texture2D) => {
  const spriteFrame = new SpriteFrame();
  spriteFrame.texture = texture;
  this.node.getComponent(Sprite).spriteFrame = spriteFrame;
});

详情请参考 资源加载。

本期就到这里,下期再见。

0 人点赞