Editing User talk:Supermariofan67/Sandbox2
From the Super Mario Wiki, the Mario encyclopedia
Jump to navigationJump to search
The edit can be undone. Please check the comparison below to verify that this is what you want to do, and then publish the changes below to finish undoing the edit.
Latest revision | Your text | ||
Line 11: | Line 11: | ||
==Discussion== | ==Discussion== | ||
==Image color-correction documentation== | |||
*'''Suggestion: Use the term "color-correction metadata" rather than "gamma brightening," since gamma is technically only one of several pieces of metadata (ICC profiles seem to be the most common) that affect the color of the image and could be removed by optimizers.''' | |||
*'''Can someone with a Mac verify whether the below procedures work for ImageOptim?''' | |||
*Maybe someday when I have more time I'll build a better utility to implement pngout and zopflipng. It doesn't seem too difficult | |||
----- | |||
---Begin Actual Page--- | |||
'''Image optimization''' is a process by which images are processed to shrink their file size. By using a '''{{wp|lossless}}''' method of optimization, images can be compressed without compromising quality by removing unecessary metadata and (for images that are already lossless, such as PNGs) recompressing them with a more efficient algorithm. Compressing images before uploading them is beneficial because it can (often substantially) reduce load time for users on slow internet connections, potentially reduce server load, and sometimes reduce very large images below 10MB to allow them to be uploaded. We usually focus on optimization in the context of PNG images in particular, but it is possible to optimize other types of images. If possible, it is recommended to losslessly optimize images before uploading them. However, it is discouraged by [[MarioWiki:Image Use Policy|Image Use Policy]] to reupload existing images for the sole purpose of optimizing them if no other changes are made. | |||
===Color-correction metadata=== | |||
While most of the metadata removed by optimization is unnecessary and safe to remove, a few images contain metadata that determines how browsers display the colors in the images (see below for details). Images that were originally exported from the Adobe suite or other specialized software (usually artwork and press images) seem to be the most likely to contain color-correction metadata, while emulator screenshots likely do not contain such metadata. Most optimizing utilities (such as [[User:Wildgoosespeeder/PNG Monstrous|PNG Monstrous]]) remove this data by default, which can be problematic, since MarioWiki policy in most cases requires preserving the content of images as provided by the source. Therefore, if optimization produces a discernible difference in color as a result of removing this metadata, the optimized image should not be uploaded. If you want to optimize images with color-correction metadata, care must be taken to ensure this data is preserved. [https://imageoptim.com ImageOptim] on macOS should support this option if you disable <code>Strip PNG Metadata</code> and <code>Strip JPG Metadata</code> in Preferences. Otherwise, see below for instructions. If you are unsure how this works, do not optimize images with this type of metadata. | |||
===How/why=== | |||
*For PNGs, images are re-encoded with a slower, but more space-efficient compression process. Lossless compression algorithms tend to decrease in speed as level of compression increases. Usually, typical png encoding libraries such as <code>{{wp|libpng}}</code> favor creating files with reasonable speed over creating absolutely ideal file sizes. As a result, programs that export images, such as Dolphin, Photoshop, or GIMP, can export PNGs within only a few seconds even for large images, but with larger file sizes than ideal. Compressors re-encode the PNGs with a ''very'' slow, but more space-efficient algorithm. | |||
*Images are often saved with unnecessary metadata, such as Exif chunks with details about camera specifications. Since this information is usually not critical to displaying the image, optimizers can remove this data. | |||
===List of Image Optimization utilities=== | |||
Unfortunately, many of the existing GUI image optimization utilities, with the exception of ImageOptim, are very outdated. The tools either don't offer functionality to preserve color-changing metadata or don't offer <code>zopflipng</code>, the newest and most efficient optimization backend for PNGs. Tools that don't allow for preservation of color metadata are unsuitable for use on images that contain this data. | |||
{|border=1 cellspacing=0 cellpadding=3 style="border-collapse:collapse" | |||
!Tool | |||
!OSes supported | |||
!Formats supported | |||
!Can preserve color metadata | |||
!Supports zopflipng | |||
|- | |||
|[[User:Wildgoosespeeder/PNG Monstrous|PNG Monstrous]] | |||
|Windows* | |||
|PNG | |||
|[[File:X mark.svg|25px]] | |||
|[[File:Check mark.svg|25px]] | |||
|- | |||
|[https://imageoptim.com ImageOptim] | |||
|macOS | |||
|PNG, JPG, GIF, SVG | |||
|[[File:Check mark.svg|25px]] | |||
|[[File:Check mark.svg|25px]] | |||
|- | |||
|[https://trimage.org/ Trimage] | |||
|Linux | |||
|PNG, JPG | |||
|[[File:X mark.svg|25px]] | |||
|[[File:X mark.svg|25px]] | |||
|- | |||
|Running <code>pngout</code>, <code>zopflipng</code>, and/or <code>jpegoptim</code> from the command line | |||
|Windows, Mac, Linux | |||
|PNG, JPG | |||
|[[File:Check mark.svg|25px]] | |||
|[[File:Check mark.svg|25px]] | |||
|} | |||
<nowiki>*</nowiki> runs on macOS/Linux with [https://www.winehq.org/ WINE] | |||
===PNG chunks=== | |||
PNGs can contain four ancillary chunks with colorspace information<ref name=libpng>http://www.libpng.org/pub/png/spec/1.2/PNG-Chunks.html#C.Anc-color</ref>, which may affect the way software displays the colors in an image: | |||
*gAMA - determines color intensity | |||
*cHRM - determines color chromaticity | |||
*sRGB - colorspace rendering intent data (often serves the same purpose as gAMA + cHRM) | |||
*iCCP - colorspace data (often serves the same purpose as gAMA + cHRM) | |||
While most images do not contain this metatdata, when they are present, these chunks should be preserved to ensure that browsers display the image's colors as intended. | |||
Other notable chunks: | |||
*tRNS - (preserved by default in <code>zopflipng</code>) - stores transparency data when a full alpha channel is not needed. Removing it shouldn't affect image quality, but doing so can actually make an image larger. Note that both <code>pngout</code> and <code>zopflipng</code> will automatically preserve the original image if the new image is larger. | |||
*pHYS - defines non-standard pixel sizes/aspect ratios (rare) | |||
*sBIT - sample bit depth, generally only needed for editing in special cases ("allows decoders to recover the original data losslessly even if the data had a sample depth not directly supported by PNG"<ref name=libpng/>). Per <code>man zopflipng</code>, "it is advised to not keep sBIT for web images because web browsers do not use [this chunk]" | |||
===How to safely optimize images that contain color-correction metadata=== | |||
It is possible to keep certain metadata, such as the gamma chunk or embedded ICC profiles, while still optimizing the image. [https://imageoptim.com ImageOptim] on macOS should support this option if you disable <code>Strip PNG Metadata</code> and <code>Strip JPG Metadata</code> in Preferences. Otherwise (for Windows and Linux), If you are familiar with the command line and willing to use it, you can do this by manually running the actual PNG optimizer from the command line and passing the appropriate options. For the best compression, run <code>pngout</code> then <code>zopflipng</code>, but running only <code>zopflipng</code> should provide sufficient results in most cases. After optimizing, '''please verify that the colors of the new image remain the same.''' | |||
====Installing the command-line tools==== | |||
*Linux: Install <code>zopfli</code>, <code>pngout</code>, and/or <code>jpegoptim</code> with your package manager. | |||
*Windows: | |||
**[http://advsys.net/ken/utils.htm Download pngout for Windows] | |||
**[https://github.com/garyzyg/zopfli-windows/releases Download zopflipng for Windows] | |||
**[https://github.com/XhmikosR/jpegoptim-windows/releases Download jpegoptim for Windows] | |||
====Zopflipng==== | |||
Example command to preserve important chunks: | |||
<code>zopflipng --keepchunks=iCCP,gAMA,cHRM,sRGB input.png output.png</code> | |||
See [https://github.com/google/zopfli/issues/113 this page] for further explanation. | |||
====pngout==== | |||
Example command to preserve important chunks: | |||
<code>pngout -kiCCP,gAMA,cHRM,sRGB input.png output.png</code> | |||
====jpegoptim==== | |||
Lossless, and preserves important chunks by default: | |||
<code>jpegoptim image.jpg</code> | |||
{{br}} | |||
===trig gives suggestions=== | |||
I would suggest the writing of a paragraph or three for people like me that don't really know much into the technical aspect of it that broadly explains; That there's a thing called metadata and this one type of it changes color. The policy is that we do not change the colors from the source. If you are unuse of how to fix it, don't. Re-affirm that images shouldn't be re-optimized for the sake of optimizing them (per IUP), but if one is being re-uploaded because the source image is better or something then it should be optimized beforehand. | |||
{{br}} | |||
As of now, the design for the box has not changed [[User_talk:Supermariofan67#Continued_discussion_on_gamma-image/color_corrected|from this]], but the template will be titled <nowiki>{{color-corrected}}</nowiki>, a cateogry of Category:Color Corrected, and a page titled similarly. [[User:Trig Jegman|Trig]] - 16:13, February 22, 2020 (EST) | |||
::I think it looks fine, though you may want to check with someone else to see if it's too technical on the optimization aspect. It may be wise to have prople view it over, as the quality control or as a second layer just in case. - Trig - 18:07, February 24, 2020 (EST) | |||
==Pre-release image== | ==Pre-release image== |