Masking Images with Imager
Sometimes you want to do something fancy with images in a completely automated way. So for example, maybe you want to turn the image on the left into the image on the right:
data:image/s3,"s3://crabby-images/cfa71/cfa713822d550979d59f4ef47c412fa667b65fa7" alt="image"
It turns out this is a pretty simple process using Imager.
Step 1 - Create a blank image.
use Imager;
my $tile = Imager->new(xsize => 450, ysize => 450, channels => 4);
Step 2 - Create a mask. This is just a PNG file that is black where you want transparency, and white or transparent where you want things to show through. In my case I created this mask.
data:image/s3,"s3://crabby-images/873c4/873c4b9ba92dcc85b1673df31793a1c3dc429d21" alt="image"
Step 3 - Use combine your mask with the image you want to mask.
my $mask = Imager->new(file => 'mask.png');
my $craftsman = Imager->new(file => ‘craftsman.png’);
$tile->compose(src => $craftsman, mask => $mask);
Step 4 - For extra flare, add a bevel.
data:image/s3,"s3://crabby-images/13bff/13bff763b55ac0909fb6825735905940b55543e7" alt="image"
my $bevel = Imager->new(file => ‘bevel.png’);
$tile->compose(src => $bevel, opacity => 0.8);
Note: Technically, the bevel is being created in some extra software like Photoshop or Gimp, and we’re just applying it here.
Step 5 - Save the file.
$tile->write(file => ‘tile.png’);
data:image/s3,"s3://crabby-images/0ad3a/0ad3a47f53f05f1e00ffffab57de5cba9ac817f6" alt="image"
As you can see, it’s pretty easy to do some pretty cool effects in Imager. Enjoy.
[From my blog.]
I just wanted to say this is a very cool post. As an old hex-based board gamer that image is really cool. The Perl module GD::Simple won't install on my Mac so I was researching Imager. Thanks for providing this excellent example!
I'm glad you found it useful.