Version: 2022.3
言語: 日本語
テクスチャ形式
ミップマップ

推奨、デフォルト、およびサポートされているテクスチャ形式 (プラットフォーム別)

このページには以下の情報が含まれています。

This page doesn’t contain information about console platforms. For information about console platforms, see the platform-specific documentation.

For an overview of texture formats, see Texture formats. For information about texture import settings and how to set per-texture platform-specific overrides, see Texture import settings. Some texture import settings can also be overridden globally in Build Settings, mostly to speed up iteration time during development.

用語

このページでは、以下の用語を使用しています。

  • ビット毎ピクセル (bpp) は、1 つのテクスチャピクセルに必要なストレージの量です。bpp 値が低いテクスチャは、ディスク上およびメモリ上のサイズが小さくなります。また、bpp 値が低いほど、GPU はより多くのピクセルをキャッシュに保存することができ、結果としてテクスチャアクセスが速くなります。
  • LDR (ローダイナミックレンジ) とは、色が概念的に 0.0 (黒) と 1.0 (白) の間の値にある、ほとんどの一般的な画像を指します。多くの画像ファイル (PNG や JPG など) はローダイナミックレンジです。
  • HDR (ハイダイナミックレンジ) とは、色が 0 から 1 よりも高い範囲を持つ特殊な画像とテクスチャ形式を指します。.exr や .hdr といった画像ファイル形式は、しばしば HDR 画像データに使用されます。ランタイムや GPU 上では、いくつかの HDR 形式があり、それぞれ、精度、範囲、メモリ使用量などの長所短所があります。
  • RGB は、赤、緑、青の 3 色を組み合わせて色の配列を再現するカラーモデルです。
  • RGBA はアルファチャンネルを持つ RGB の一種で、ブレンドと透明度の変更が可能です。
  • 可変ビットレート (VBR) は、ピクセルあたりのビット数が固定値ではなく、実際のコンテンツに依存することを意味します。VBR は Crunch 圧縮 にのみ、そしてディスク上のテクスチャサイズにのみ適用されます。メモリ内のサイズは、基礎となるテクスチャ形式を使用する場合と同じです (例えば、RGB Crunched DXT1 のための RGB Compressed DXT1)。

推奨テクスチャ形式 (プラットフォーム別)

デスクトップ

DirectX 11 以上のクラスの GPU を搭載し、BC7 および BC6H 形式のサポートが確実に利用できるデバイスの場合、推奨される圧縮形式の選択は以下のとおりです。 RGB テクスチャ - 4 ビット/ピクセルの DXT1。RGBAテクスチャ - BC7 (高品質、圧縮が遅い) または DXT5 (圧縮が速い)、両方とも 8 ビット/ピクセル。 HDR テクスチャ - 8 ビット/ピクセルの BC6H。 PC で DirectX 10 クラス GPU (2010 より前の NVIDIA GPU、2009 より前の AMD、2012 より前の Intel) をサポートする必要がある場合、これらの GPU は BC7 も BC6H もサポートしないため、BC7 ではなく DXT5 が推奨されます。

サポートされるすべての形式の詳細については、サポートされるテクスチャ形式リファレンス表 を参照してください。

iOS と tvOS

A8 チップ (2014) 以降を使用する Apple デバイスの場合、ATSC は RGB および RGBA テクスチャに推奨されるテクスチャ圧縮形式です。この形式を使うと、8 ビット/ピクセル (4x4 ブロックサイズ) から 0.89 ビット/ピクセル (12x12 ブロックサイズ) まで、きめ細かいレベルでテクスチャの品質とサイズを選択できます。 古いデバイスのサポートが必要な場合、または追加の Crunch 圧縮が必要な場合、Apple デバイスは A7 チップ (2013) 以降の ETC/ETC2 形式をサポートします。さらに古いデバイスの場合、PVRTC を使用できます。iOS では、プレーヤー設定 でデフォルトのテクスチャ形式を設定できます。PVRTC は可能な限り幅広い互換性を提供します。ASTC が推奨されますが、A7 デバイス (最初の Metal 対応デバイス) ではサポートされておらず、ランタイムに解凍されます。

サポートされるすべての形式の詳細については、サポートされるテクスチャ形式リファレンス表 を参照してください。

Android

Android のテクスチャ形式のサポートは複雑です。異なる サブターゲット を使って、複数のアプリケーションバージョンをビルドする必要があるかもしれません。

デフォルトのフォーマットは Player Settings で選択することができます。選択肢は、ASTC、ETC2、ETC (RGB では ETC1、RGBA では ETC2)です。各設定の動作の詳細については、テクスチャ圧縮設定 を参照してください。

LDR、RGB、RGBA テクスチャについては、OpenGL ES 3.1 または Vulkan をサポートする最新のAndroid GPU のほとんどが ASTC 形式もサポートしており、以下のようなものがあります。 Qualcomm GPU Adreno 4xx / Snapdragon 415 (2015) 以降、ARM GPU Mali T624 (2012) 以降、NVIDIA GPU Tegra K1 (2014) 以降、PowerVR GPUs since GX6250 (2014) 以降。

古いデバイスのサポートが必要な場合、または追加の Crunch 圧縮が必要な場合は、Vulkan、Metal、または OpenGL ES 3.0 を実行するすべての GPU は ETC2 形式をサポートします。 結果として得られる画質は非常に高く、1 - 4 コンポーネントのテクスチャデータをサポートします。OpenGL ES 2 デバイスは ETC2 形式をサポートしないため、Unity はランタイムにテクスチャ ETC2 フォールバック が指定する形式に解凍します。 さらに古いデバイスの場合、通常は ETC 形式のみが使用可能です。欠点は、直接アルファチャネルがサポートされていないことです。スプライトの場合、Unity は、テクスチャを 2 つの ETC1 テクスチャに分割することで ETC1 圧縮を使用するオプションを提供します。1 つは RGB 用、もう 1 つはアルファ用です。これを有効にするには、スプライトアトラス をインポートするときに、テクスチャに対して Android 専用の Split Alpha Channel オプションを有効にします。スプライトシェーダーは両方のテクスチャをサンプリングし、それらを組み合わせて最終結果を作成します。

For HDR textures, ASTC HDR is the only compressed format available on Android devices. ASTC HDR requires Vulkan or GL_KHR_texture_compression_astc_hdr support. ASTC is the most flexible format. If a device doesn’t support ASTC HDR the texture is decompressed at runtime to RGB9e5 or RGBA Half, depending on alpha channel usage.

ASTC HDR に対応していないデバイスでは、Vulkan、Metal、OpenGL ES 3.0 を搭載したすべてのデバイスが RGB9e5 に対応しており、アルファチャンネルのないテクスチャに適しています。アルファチャンネルやさらに広い範囲のサポートが必要な場合は、RGBA Half を使用します。これは、RGB9e5 の 2 倍のメモリを必要とします。

See the Supported texture formats reference table for detailed information about all supported formats.

デフォルトのテクスチャ形式 (プラットフォーム別)

以下は各プラットフォームで使用されるデフォルト形式を表しています。

プラットフォーム カラーモデル 圧縮なし 標準品質 (デフォルト) 高品質 低品質 (高パフォーマンス)
Windows、Linux、macOS RGB RGB 24 bit RGB Compressed DXT1 RGB(A) Compressed BC7 RGB Compressed DXT1
RGBA RGBA 32 bit RGBA Compressed DXT5 RGB(A) Compressed BC7 RGBA Compressed DXT5
HDR RGBA Half RGB Compressed BC6H RGB Compressed BC6H RGB Compressed BC6H
WebGL (configurable) RGB RGB 24 bit RGB Compressed DXT1 RGB Compressed DXT1 RGB Compressed DXT1
RGBA RGBA 32 bit RGBA Compressed DXT5 RGBA Compressed DXT5 RGBA Compressed DXT5
Android (configurable) RGB RGB 24 bit RGBA Compressed ASTC 6x6 block
RGB Compressed ETC2
RGB Compressed ETC
RGBA Compressed ASTC 4x4 block
RGB Compressed ETC2
RGB Compressed ETC
RGBA Compressed ASTC 8x8 block
RGB Compressed ETC2
RGB Compressed ETC
RGBA RGBA 32 bit RGBA Compressed ASTC 6x6 block
RGBA Compressed ETC2
RGBA Compressed ASTC 4x4 block
RGBA Compressed ETC2
RGBA Compressed ASTC 8x8 block
RGBA Compressed ETC2
iOS (configurable) RGB RGB 24 bit RGBA Compressed ASTC 6x6 block
RGB Compressed PVRTC 4 bits
RGBA Compressed ASTC 4x4 block
RGB Compressed PVRTC 4 bits
RGBA Compressed ASTC 8x8 block
RGB Compressed PVRTC 2 bits
RGBA RGBA 32 bit RGBA Compressed ASTC 6x6 block
RGBA Compressed PVRTC 4 bits
RGBA Compressed ASTC 4x4 block
RGBA Compressed PVRTC 4 bits
RGBA Compressed ASTC 8x8 block
RGBA Compressed PVRTC 2 bits
tvOS RGB RGB 24 bit RGBA Compressed ASTC 6x6 block RGBA Compressed ASTC 4x4 block RGBA Compressed ASTC 8x8 block
RGBA RGBA 32 bit RGBA Compressed ASTC 6x6 block RGBA Compressed ASTC 4x4 block RGBA Compressed ASTC 8x8 block
デフォルト RGBA RGBA 32 bit RGBA 16 bit RGBA 16 bit RGBA 16 bit

テクスチャーフォーマット (品質別)

下の表は、Unity で利用可能な各形式と、その品質の詳細を示しています。

テクスチャ形式 説明  チャンネル 品質 ビット/ピクセル 1024x1024 テクスチャのサイズ (単位:MB)
RGB(A) Compressed BC7 圧縮された RGB か RGBA RGB か RGBA 8 1
RGBA Crunched DXT5 圧縮された RGBA、追加のディスク上 Crunch 圧縮あり RGBA 低 - 中 可変 可変
RGBA 64 bit 非圧縮の RGBA、非常に高い精度 RGBA 非常に高い 64 8
RGBA 32 bit 非圧縮の RGBA RGBA 32 4
RGBA 16 bit 量子化された RGBA RGBA 16 2
RGB Compressed DXT1 圧縮された RGB (BC1 とも呼ばれる) RGB 4 0.5
RGB Crunched DXT1 圧縮された RGB、追加のディスク上 Crunch 圧縮あり RGB 低 - 中 可変 可変
RGB 48 bit 非圧縮の RGB、非常に高い精度。GPU 用に RGBA 64 bit に変換されています。 RGB 非常に高い 48 ディスク、64 GPU 6 ディスク、8 GPU
RGB 24 bit 非圧縮の RGB。GPU 用に RGBA 32 bit に変換されています。 RGB 24 ディスク、32 GPU 3 ディスク、4 GPU
RGB 16 bit 量子化された RGB RGB 16 2
RG Compressed BC5 圧縮 2 チャンネル (RG) RG 8 1
RG 32 bit 非圧縮 2 チャンネル (RG)、非常に高い精度 RG 非常に高い 32 4
R Compressed BC4 圧縮されたシングルチャンネル (R) R 4 0.5
R 8 非圧縮シングルチャンネル (R) R 8 1
R 16 bit 非圧縮シングルチャンネル (R)、非常に高い精度 R 非常に高い 16 2
Alpha 8 非圧縮シングルチャンネル (A) A 8 1
RGBA Half HDR、半精度 (FP16) RGBA、–64k から +64k の範囲 RGBA 64 8
RGB Compressed BC6H HDR、圧縮 RGB、0 から +64k の範囲 RGB 8 1
RGB9e5 32 Bit Shared Exponent Float HDR、量子化された RGB、0 から +64k の範囲 RGB 32 4
RGB(A) Compressed ASTC 圧縮された RGB か RGBA、サイズと品質はブロックサイズに基づく RGB か RGBA 低 - 中 12x12: 0.89, 10x10: 1.28, 8x8: 2, 6x6: 3.56, 5x5: 5.12, 4x4: 8 12x12: 0.11, 10x10: 0.16, 8x8: 0.25, 6x6: 0.45, 5x5: 0.64, 4x4: 1.0
RGBA Compressed ETC2 圧縮された RGBA RGBA 8 1
RGBA Crunched ETC2 圧縮された RGBA、追加のディスク上 Crunch 圧縮あり RGBA 低 - 中 可変 可変
RGB + 1-bit Alpha Compressed ETC2 4 bits 圧縮された RGBA。アルファ値が完全に不透明または完全に透明。 RGBA 4 0.5
RGBA Compressed PVRTC 4 bits 圧縮されたRGBA。テクスチャは正方形であることが必要。 RGBA 4 0.5
RGBA Compressed PVRTC 2 bits 圧縮されたRGBA。テクスチャは正方形であることが必要。 RGBA 2 0.25
RGB Compressed ETC2 圧縮された RGB RGB 4 0.5
RGB Compressed ETC 圧縮された RGB RGB 4 0.5
RGB Crunched ETC 圧縮された RGB、追加のディスク上 Crunch 圧縮あり RGB 可変 可変
RGB Compressed PVRTC 4 bits 圧縮された RGB、テクスチャは正方形であることが必要。 RGB 4 0.5
RGB Compressed PVRTC 2 bits 圧縮された RGB、テクスチャは正方形であることが必要。 RGB 2 0.25
RG Compressed EAC 8 bit 圧縮 2 チャンネル (RG) RG 8 1
R Compressed EAC 4 bit 圧縮されたシングルチャンネル (R) R 4 0.5
RGB(A) Compressed ASTC HDR HDR、圧縮された RGB、または RGBA。サイズと品質はブロックサイズに基づく。 RGB か RGBA 低 - 高 12x12: 0.89, 10x10: 1.28, 8x8: 2, 6x6: 3.56, 5x5: 5.12, 4x4: 8 12x12: 0.11, 10x10: 0.16, 8x8: 0.25, 6x6: 0.45, 5x5: 0.64, 4x4: 1.0

サポートされるテクスチャ形式 (プラットフォーム別)

下の表は、Unity で利用可能な各テクスチャ形式と、それをサポートするプラットフォームを示しています。

テクスチャ形式 Windows macOS Linux Android iOS & tvOS WebGL (デスクトップブラウザー) WebGL (iOS、Android ブラウザー)
RGB(A) Compressed BC7 可 (1) 可 (1) 不可 不可 可 (1) 不可
RGBA Compressed DXT5 不可 (3) 不可 一部可 (2) 不可
RGBA Crunched DXT5 不可 (3) 不可 一部可 (2) 不可
RGBA 64 bit 一部可 (6) 不可 不可
RGBA 32 bit
RGBA 16 bit
RGB Compressed DXT1 不可 (3) 不可 一部可 (2) 不可
RGB Crunched DXT1 不可 (3) 不可 一部可 (2) 不可
RGB 48 bit 一部可 (6) 不可 不可
RGB 24 bit
RGB 16 bit
RG Compressed BC5 不可 不可 不可
RG 32 bit 一部可 (6) 不可 不可
R Compressed BC4 不可 不可 不可
R 8 一部可 (5) 一部可 (5) 一部可 (5)
R 16 bit 一部可 (6) 一部可 (6) 可 (14) 可 (14)
Alpha 8
RGBA Half 一部可 (7) 一部可 (7) 一部可 (7)
RGB Compressed BC6H 可 (1) 可 (1) 不可 不可 可 (1) 不可
RGB9e5 32 Bit Shared Exponent Float 一部可 (4) 一部可 (4) 一部可 (4)
RGB(A) Compressed ASTC 不可 不可 不可 一部可 (9) 可 (10) 不可 可 (13 & 10)
RGBA Compressed ETC2 不可 不可 不可 一部可 (9) 不可
RGBA Crunched ETC2 不可 不可 不可 一部可 (9) 不可
RGB + 1-bit Alpha Compressed ETC2 4 bits 不可 不可 不可 一部可 (9) 不可
RGBA Compressed PVRTC 4 bits 不可 不可 不可 不可 (12) 不可 不可
RGBA Compressed PVRTC 2 bits 不可 不可 不可 不可 (12) 不可 不可
RGB Compressed ETC2 不可 不可 不可 一部可 (9) 不可
RGB Compressed ETC 不可 不可 不可 不可
RGB Crunched ETC 不可 不可 不可 不可
RGB Compressed PVRTC 4 bits 不可 不可 不可 不可 (12) 不可 不可
RGB Compressed PVRTC 2 bits 不可 不可 不可 不可 (12) 不可 不可
RG Compressed EAC 8 bit 不可 不可 不可 一部可 (9) 不可
R Compressed EAC 4 bit 不可 不可 不可 一部可 (9) 不可
RGB(A) Compressed ASTC HDR 不可 不可 不可 一部可 (11) 一部可 (11) 不可 一部可 (11)

ノート:

  1. ただし、DX11 レベル以前の GPU、または WebGL か OpenGL を使用する macOS の場合は除きます。サポートされていない場合、ロード時に BC6H テクスチャは RGBA ハーフに、BC7 は RGBA32 に解凍されます。
  2. With linear rendering on web browsers that don’t support sRGB DXT, textures are decompressed to RGBA32 at load time.
  3. ただし、NVIDIA Tegra GPU を搭載した Android デバイスでは、DXT/BC 形式に対応しています。
  4. OpenGL ES 2.0 / WebGL 1. を除く。
  5. OpenGL ES 2.0 / WebGL 1 の場合、GL_EXT_texture_rg 拡張サポートが必要です。
  6. Android では、GL_EXT_texture_norm16 か、対応する Vulkan の能力が必要です。
  7. OpenGL ES 2.0 / WebGL 1 の場合、OES_texture_half_float 拡張サポートが必要です。
  8. Vulkan または GL_KHR_texture_compression_astc_ldr OpenGL ES 拡張が必要です。
  9. OpenGL ES 2.0 の場合を除き、ETC2 テクスチャは Android Build Settings または Android タブの プラットフォーム専用オーバーライド で指定された ETC2 fallback 形式に解凍されます。
  10. Apple A7 チップ搭載デバイス (2013 年) を除く。
  11. Android ではGL_KHR_texture_compression_astc_hdr 拡張が必要です。iOS では、A13 (2019) 以降のチップが必要です。WebGL では、WEBGL_compressed_texture_astc 拡張と HDR profile が必要です。サポートされていない場合は、テクスチャは RGB9E5 形式に解凍され、アルファチャンネルを失います。
  12. ただし、Imagination PowerVR GPU を搭載する Android デバイスでは、PVRTC 形式をサポートします。
  13. WEBGL_compressed_texture_astc 拡張が必要です。
  14. EXT_texture_norm16 拡張と WebGL 2 が必要です。

Supported texture formats in WebGL

The following table provides the supported texture formats for WebGL.

Format Descritpion
ASTC Adaptive Scalable Texture Compression (ASTC) is an advanced lossy texture compression format. Widely used for mobile browsers / devices.
DXT Also known as S3 Texture Compression (S3TC), DXT is mainly used for desktop browsers and devices.
ETC2 Ericsson Texture Compression (ETC) is an older lossy texture compression format, lower quality than ASTC, used for mobile browsers / devices.

その他の参考資料

TextureImporterOverride

テクスチャ形式
ミップマップ