importing_images.rst 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223
  1. .. _doc_import_images:
  2. Importing images
  3. ================
  4. Supported image formats
  5. -----------------------
  6. Godot can import the following image formats:
  7. - BMP (``.bmp``)
  8. - No support for 16-bit per pixel images. Only 1-bit, 4-bit, 8-bit, 24-bit, and 32-bit per pixel images are supported.
  9. - DirectDraw Surface (``.dds``)
  10. - If mipmaps are present in the texture, they will be loaded directly.
  11. This can be used to achieve effects using custom mipmaps.
  12. - OpenEXR (``.exr``)
  13. - Supports HDR (highly recommended for panorama skies).
  14. - Radiance HDR (``.hdr``)
  15. - Supports HDR (highly recommended for panorama skies).
  16. - JPEG (``.jpg``, ``.jpeg``)
  17. - Doesn't support transparency per the format's limitations.
  18. - PNG (``.png``)
  19. - Precision is limited to 8 bits per channel upon importing (no HDR images).
  20. - Truevision Targa (``.tga``)
  21. - SVG (``.svg``, ``.svgz``)
  22. - SVGs are rasterized using `NanoSVG <https://github.com/memononen/nanosvg>`__
  23. when importing them. Support is limited; complex vectors may not render correctly.
  24. For complex vectors, rendering them to PNGs using Inkscape is often a better solution.
  25. This can be automated thanks to its `command-line interface <https://wiki.inkscape.org/wiki/index.php/Using_the_Command_Line#Export_files>`__.
  26. - WebP (``.webp``)
  27. - WebP files support transparency and can be compressed lossily or losslessly.
  28. The precision is limited to 8 bits per channel.
  29. .. note::
  30. If you've compiled the Godot editor from source with specific modules disabled,
  31. some formats may not be available.
  32. Importing textures
  33. ------------------
  34. The default action in Godot is to import images as textures. Textures are stored
  35. in video memory and can't be accessed directly. This is what makes drawing them
  36. efficient.
  37. Import options are vast:
  38. .. image:: img/image_import1.png
  39. Detect 3D
  40. ~~~~~~~~~
  41. This option makes Godot be aware of when a texture (which is imported for 2D as default) is used in 3D. If this happens, setting are changed so the texture flags
  42. are friendlier to 3D (mipmaps, filter and repeat become enabled and compression is changed to VRAM). Texture is also reimported automatically.
  43. Compression
  44. -----------
  45. Images are one of the largest assets in a game. To handle them efficiently, they need to be compressed.
  46. Godot offers several compression methods, depending on the use case.
  47. Compress Mode
  48. ~~~~~~~~~~~~~
  49. - **VRAM Compression:** This is the most common compression mode for 3D assets.
  50. Size on disk is reduced and video memory usage is also decreased considerably
  51. (usually by a factor between 4 and 6). This mode should be avoided for 2D as it
  52. exhibits noticeable artifacts.
  53. - **Lossless Compression:** This is the most common compression mode for 2D assets.
  54. It shows assets without any kind of artifacting, and disk compression is
  55. decent. It will use considerably more amount of video memory than
  56. VRAM Compression, though. This is also the recommended setting for pixel art.
  57. - **Lossy Compression:** This is a good choice for large 2D assets. It has some
  58. artifacts, but less than VRAM and the file size is several times lower
  59. compared to Lossless or Uncompressed. Video memory usage isn't decreased by
  60. this mode; it's the same as with Lossless Compression or Uncompressed.
  61. - **Uncompressed:** Only useful for formats that can't be compressed (such as
  62. raw float images).
  63. In this table, each of the four options are described together with their
  64. advantages and disadvantages (|good| = best, |bad| = worst):
  65. +----------------+------------------------+-------------------------------+-------------------------+------------------------------------------------------+
  66. | | Uncompressed | Compress Lossless | Compress Lossy | Compress VRAM |
  67. +================+========================+===============================+=========================+======================================================+
  68. | Description | Stored as raw pixels | Stored as Lossless WebP / PNG | Stored as Lossy WebP | Stored as S3TC/BC or PVRTC/ETC depending on platform |
  69. +----------------+------------------------+-------------------------------+-------------------------+------------------------------------------------------+
  70. | Size on Disk | |bad| Large | |regular| Small | |good| Very Small | |regular| Small |
  71. +----------------+------------------------+-------------------------------+-------------------------+------------------------------------------------------+
  72. | Memory Usage | |bad| Large | |bad| Large | |bad| Large | |good| Small |
  73. +----------------+------------------------+-------------------------------+-------------------------+------------------------------------------------------+
  74. | Performance | |regular| Normal | |regular| Normal | |regular| Normal | |good| Fast |
  75. +----------------+------------------------+-------------------------------+-------------------------+------------------------------------------------------+
  76. | Quality Loss | |good| None | |good| None | |regular| Slight | |bad| Moderate |
  77. +----------------+------------------------+-------------------------------+-------------------------+------------------------------------------------------+
  78. | Load Time | |regular| Normal | |bad| Slow | |bad| Slow | |good| Fast |
  79. +----------------+------------------------+-------------------------------+-------------------------+------------------------------------------------------+
  80. .. |bad| image:: img/bad.png
  81. .. |good| image:: img/good.png
  82. .. |regular| image:: img/regular.png
  83. HDR Mode
  84. ~~~~~~~~
  85. Godot supports high dynamic range textures (as .HDR or .EXR). These are mostly useful as high dynamic range equirectangular panorama skies (the internet
  86. has plenty if you search for them), which replace Cubemaps in Godot 2.x. Modern PCs support the BC6H VRAM format, but there are still plenty that do not.
  87. If you want Godot to ensure full compatibility in terms of the kind of textures, enable the "Force RGBE" option.
  88. Normal Map
  89. ~~~~~~~~~~
  90. When using a texture as normal map, only the red and green channels are required. Given regular texture compression algorithms produce artifacts that don't
  91. look that nice in normal maps, the RGTC compression format is the best fit for this data. Forcing this option to "Enabled" will make Godot import the
  92. image as RGTC compressed. By default, it's set to "Detect", which means that if the texture is ever used as a normal map, it will be changed to "Enabled" and
  93. reimported automatically.
  94. Note that RGTC compression affects the resulting normal map image. You will have to adjust custom shaders that use the normal map to take this into account.
  95. .. note::
  96. Godot requires the normal map to use the X+, Y+ and Z+ coordinates, this is
  97. known as OpenGL style. If you've imported a material made to be used with
  98. another engine it may be DirectX style, in which case the normal map needs to
  99. be converted so its Y axis is flipped.
  100. More information about normal maps (including a coordinate order table for
  101. popular engines) can be found
  102. `here <http://wiki.polycount.com/wiki/Normal_Map_Technical_Details>`__.
  103. Flags
  104. -----
  105. There are plenty of settings that can be toggled when importing an image as a texture, depending on the use case.
  106. Repeat
  107. ~~~~~~
  108. This setting is most commonly used in 3D, and is therefore generally disabled in 2D. It sets UV coordinates going beyond the 0,0 - 1,1 range to "loop".
  109. Repeating can optionally be set to mirrored mode.
  110. Filter
  111. ~~~~~~
  112. When pixels become larger than the screen pixels, this option enables linear interpolation for them. The result is a smoother (less blocky) texture. This setting can be commonly used in 2D and 3D, but it's usually disabled when making pixel perfect games.
  113. Mipmaps
  114. ~~~~~~~
  115. When pixels become smaller than the screen, mipmaps kick in. This helps reduce the grainy effect when shrinking the textures. Keep in mind that, in older hardware
  116. (GLES2, mainly mobile), there are some requirements to use mipmaps:
  117. * Texture width and height must be powers of 2
  118. * Repeat must be enabled
  119. Keep in mind the above when making phone games and applications, want to aim for full compatibility, and need mipmaps.
  120. When doing 3D, mipmap should be turned on, as this also improves performance (smaller versions of the texture are used for objects further away).
  121. Anisotropic
  122. ~~~~~~~~~~~
  123. When textures are near parallel to the view (like floors), this option makes them have more detail by reducing blurriness.
  124. sRGB
  125. ~~~~
  126. Godot uses Linear colorspace when rendering 3D. Textures mapped to albedo or detail channels need to have this option turned on in order for colors to look correct.
  127. When set to **Detect** mode, the texture will be marked as sRGB when used in albedo channels.
  128. .. warning::
  129. Since the texture will have its data modified when sRGB is enabled, this
  130. means using the same texture in both 2D and 3D will make the texture
  131. display with incorrect colors in either 2D or 3D.
  132. To work around this, make a copy of the texture on the filesystem and enable
  133. sRGB on one of the copies only. Use the copy with sRGB enabled in 3D, and
  134. the copy with sRGB disabled in 2D.
  135. Process
  136. -------
  137. Some special processes can be applied to images when imported as textures.
  138. Fix Alpha Border
  139. ~~~~~~~~~~~~~~~~
  140. This puts pixels of the same surrounding color in transition from transparency to non transparency. It helps mitigate the outline effect when exporting images
  141. from Photoshop and the like.
  142. .. image:: img/fixedborder.png
  143. It's a good idea to leave it on by default, unless specific values are needed.
  144. Premultiplied Alpha
  145. ~~~~~~~~~~~~~~~~~~~
  146. An alternative to fix darkened borders is to use premultiplied alpha. By enabling this option, the texture will be converted to this format.
  147. Keep in mind that a material will need to be created that uses the PREMULT ALPHA blend mode on canvas items that need it.
  148. HDR as sRGB
  149. ~~~~~~~~~~~
  150. A few HDR files are broken and contain sRGB color data. It is advised not to use them, but, in the worst-case scenario, toggling this option on will make them look right.
  151. Invert Color
  152. ~~~~~~~~~~~~
  153. Reverses the image's color. This is useful, for example, to convert a height map generated by external programs to depth map to use with :ref:`doc_spatial_material`.
  154. Svg
  155. ---
  156. Scale
  157. ~~~~~
  158. This option only applies to SVG files. It controls the scale of the SVG image. The default scale (1.0) will make the imported SVG match its original design scale.