I found Imagick::clipPathImage and Imagic::clipImage did not work as I had expected. I thought they would just clip the path and throw away the extra data and you are done. Not the case.
Here is how I was able to use a clipping path:
<?php
$img = new Imagick("/Path/To/Test/Image.psd");
$geometry = $img->getImageGeometry();
// Uses the first path as the clipping path
$img->clipPathImage("#1", false);
// Fill the clipped part with a color
$draw = new ImagickDraw();
$draw->setFillColor("#000000");
$draw->color(0,0, imagick::PAINT_RESET);
$img->drawImage($draw);
// Composite the clipped image with the old image. Set the color of the composite to any color you want to be the outside part.
$composite = new Imagick($path);
$composite->newImage( $geometry['width'], $geometry['height'], new ImagickPixel("white"), 'png');
$composite->compositeImage($img, imagick::COMPOSITE_COPY, 0, 0);
?>
Then doing any resizing or creating thumbnails from the resulting image disregarded all the previous commands so I "saved" it and started with a new Imagick object
<?php
// Copy the image so clip is "saved"
$clipped = new Imagick();
$clipped->readImageBlob($composite->getImageBlob());
?>
I'm sure there is a simpler way, but this took me awhile to get right and there were some hurdles to cross so I hope it is able to help someone on the way.
This is all the convert equivalent of:
$ convert Test.psd -fill white -colorspace rgb -draw "color 0 0 reset" -clip -colorspace rgb -draw "Image Copy 0,0 0,0 'Test.psd'" OutputFile.pngImagick::clipPathImage
Почист и полокален преглед на PHP референцата, со задржана структура од PHP.net и подобра читливост за примери, секции и белешки.
Imagick::clipPathImage
Референца за `imagick.clippathimage.php` со подобрена типографија и навигација.
Imagick::clipPathImage
(PECL imagick 2, PECL imagick 3)
Imagick::clipPathImage — Исечоци по именуваните патеки од 8BIM профилот
= NULL
Исечоци по именуваните патеки од 8BIM профилот, ако постојат. Подоцнежните операции се одвиваат внатре во патеката. Може да биде број ако му претходи #, за да се работи на нумерирана патека, на пр. "#1" за користење на првата патека.
Параметри
pathname-
Името на патеката
inside-
Враќа
trueподоцнежните операции се одвиваат внатре во патеката за сечење. Инаку подоцнежните операции се одвиваат надвор од патеката за сечење.
Вратени вредности
Патеката до PHP скриптата што треба да се провери. true на успешен исход.
Errors/Exceptions
Фрла ImagickException при грешка.