-
Notifications
You must be signed in to change notification settings - Fork 0
image_files
If you have read the previous tutorials on Resources and FileSystem, at this point you know that regular image files (.png, .jpg, etc) are treated as regular resources in Godot.
Unlike texture resources (.tex files), image files contain no extra information on tiling (texture repeat), mipamps or filtering. Editing this information and saving the texture back will have not any effect, since such formats can't contain that information.
Loading of images is done by the image loader. The behavior of the loader for all image files can be changed in the Project Settings dialog (Scene -> Project Settings). There is a section with values that correspond to the every image file when loaded:
Filter is used when the image is stretched more than it's original size, so a texel in the image is bigger than a pixel on the screen. Turning off the fiter produces a retro-like look:
Repeat is mainly used for 3D textures, so it's off by default (textures are imported with the scenes and usually are not in the project as image files). When using UV coordinates (something not as common in 2D), and the UV value goes beyond the 0,0,1,1 rect, the texture repeats instead of clamping to the edge.
When the mipmaps option is enabled, Godot will generate mip-maps. Mipmaps are versions of the image shrunk by half in both axis, recursively, until the image is 1 pixel of size. When the 3D hardware needs to shrink the image, it finds the largest mipmap it can scale from, and scales from there. This improves performance and image quality.
When Mip-Maps are disabled, images start distorting badly when shrunk excessively:
The blending equation used by applications like Photoshop is too complex for real-time. There are better approximations such as pre-multiplied alpha, but they impose more stress in the asset pipeline. In the end, we are left with textures that have artifacts in the edges, because apps such as Photoshop store white pixels in completely transparent areas. Such white pixels end up showing thanks to the texture filter (when active).
Godot has an option to fix the edges of the image (by painting invisible pixels the same color as the visible neighbours):
To do this, open the image from the resources tab, or edit it from the property editor from another node or resource, then go to the object options and select "Fix Border Alpha", then save it.
Since fixing this in so many images can be a little annoying, both Texture Import and Image Export can also perform this operation.
Sometimes, it might be desired to change the above settings per image. Unfortunately, the image loader settings are global. Texture flags also can't be saved in a regular .png or .jpg file.
For such cases, the image can be imported as a texture (.tex), where the individual flags can be changed. Godot also keeps track of the original file and will re-import if it changes.
Importing also allows conversion to other formats (WebP, or RAM compression) which might be of use in some cases. . More information on the Texture Import page.
It is also possible to convert images to other formats (WebP or RAM compression) on export, as well as instructing the exporter to create an Atlas for a set of images. It is also possible to ask the exporter to scale all images (or selected groups).
More information on the Image Export page.
(c) Juan Linietsky, Ariel Manzur, Distributed under the terms of the CC By license.