Thread Rating:
  • 1 Vote(s) - 5 Average
  • 1
  • 2
  • 3
  • 4
  • 5
Background removal or replacement on text, logos and other computer grahpics
On CGI (logos, text), the smooth edges are produced with anti-aliasing pixels. These pixels have a color which is a mix of the background color and the subject color.

The usual (and suboptimal) technique

When you use the color selector or the fuzzy selector, these anti-aliasing pixels are either selected fully or not at all, depending on threshold. If you then bluntly Delete, you either get a halo with the color of the removed background (Threshold 15) or a jagged edge (Threshold 100) or both:


A better solution

A much better solution is to replace the background color by transparency, in proportion of its contribution to the color mix. In Gimp there are two ways to achieve this:
  • Colors>Color to alpha
  • Color erase mode, as a paint tool mode, or since Gimp 2.10 as a layer blend mode.

Both methods replace the pixel by the most transparent pixel, which, put over the removed color, re-produces the initial color:
  • If you remove red from purple, you get a semi transparent blue, because semi-transparent blue over red produces purple.
  • If you remove white from gray, you get a very transparent black pixel and not a not-so-transparent dark gray pixel, because among several solutions Gimp picks the most transparent one.
For instance, using Color-to-alpha to remove the red gives this:


You will notice that in the 2.8 results, there are darker pixels that are due to Gimp 2.8 working on gamma-corrected values (the result is still vastly better than the jagged edges you get with simpler methods). Gimp 2.10 works in "linear light" and has no such problems.


In the general case, the subject may have parts that are close to the color of the background. So if you apply the technique above these parts become transparent (or partially transparent). Avoiding this is simple:
  • Use the wand to select the background. The usual threshold (15) is fine.
  • Select>Growthe selection so that it covers the anti-aliasing pixels. On a clean image (PNG, with no JPG history) you don't need to grow by more than one pixel. If the image is dirty (JPEG artifacts), growing the selection by two or three pixels can be necessary.
  • Apply color-to-alpha. The pixels inside the subject, being excluded from the selection, won't be altered. Color to alpha will be applied to the background and the edge pixels, where it matters.

Output file types
  • JPEG doesn't support transparency
  • GIF supports binary transparency (all opaque or all transparent) so your semi-transparent edge pixels are going to be altered. You can use Layer>Transparency>Semi-flatten to fill the transparency of these edge pixels with a new color (the color of the background on which the GIF will be used).
  • PNG has full support for partial transparency and is currently the preferred format.
  • WEBP is a new Google-sponsored format that can be lossy or lossless, and supports partial transparency. Gimp 2.10 supports it, but you have to ensure that it is supported where you want to use it (it won't be supported in older browsers, for instance).

Replacing the background

Replacing the background is as easy as removing the old one as above, and then painting a new one, isn't it? Of course, the devil is in the details. How do we paint the partially transparent anti-aliasing pixels, or more accurately, how do we recreate the appropriate color mix in each of them?

A first solution lies in the definition of what color-to-alpha does: once you have removed the background you can recreate the initial image by putting behind it a layer filled with the removed color. So replacing the background is merely using another background layer.

A second solution that doesn't involve an extra layer is to pain using the Behind mode. As its name indicates, if you consider layers as sheets of glass, this is equivalent to painting the underside of your layer: you don't see that color where the top side of the layer is opaque, you only see it through the (partially) transparent pixels. In other words, it does the opposite of Color erase: it replace transparency with a color, in proportion to the transparency. The nice things is that you usually won't need a selection to apply it, since it will only apply where necessary, which is where Color-to-alpha created the transparency.

Forum Jump: