ImagickDraw::circle

(PECL imagick 2.0.0)

ImagickDraw::circleDraws a circle

Описание

bool ImagickDraw::circle ( float $ox , float $oy , float $px , float $py )
Внимание

К настоящему времени эта функция еще не была документирована; для ознакомления доступен только список аргументов.

Draws a circle on the image.

Список параметров

ox

origin x coordinate

oy

origin y coordinate

px

perimeter x coordinate

py

perimeter y coordinate

Возвращаемые значения

Эта функция не возвращает значения после выполнения.

Коментарии

This example creates a circle, one part green, one part red using kind of masks for transparency, which you might know from Photoshop. drawImage() is a quick helper for debug output (see code comments) to help you reproduce the process.

<?php
function drawImage(Imagick $im) {
   
$im->setCompressionQuality(100);
   
$im->setImageFormat("jpg");
   
header("Content-Type: image/" $im->getImageFormat());
    echo 
$im;
    exit;
}

// define red/green layer
$layer1 = new Imagick();
$layer1->newImage(100100"none");

$red = new ImagickDraw();
$red->setFillColor("#FF0000");
$red->rectangle(0050100);

$green = new ImagickDraw();
$green->setFillColor("#00FF00");
$green->rectangle(500100100);

$layer1->drawImage($red);
$layer1->drawImage($green);

# debug output: two rectangles
# drawImage($layer1);

// define circle mask
$layer2 = new Imagick();
$layer2->newImage(100100"none");

$circle = new ImagickDraw();
$circle->setFillColor("#FFFFFF");
$circle->circle(50504898);

$layer2->drawImage($circle);

# debug output: the mask
# drawImage($layer2);

// use mask
$layer1->compositeImage($layer2Imagick::COMPOSITE_DSTIN00);

# debug output: the result of our mask usage
# drawImage($layer1);

// define background
$layer3 = new Imagick();
$layer3->newImage(100100"none");

$layer3->compositeImage($layer1Imagick::COMPOSITE_DEFAULT00);

// define ring as background
$layer4 = new Imagick();
$layer4->newImage(100100"white"); // this is our background

$ring1 = new ImagickDraw();
$ring1->setFillColor("black");
$ring1->circle(50505099);

$layer4->drawImage($ring1);

# debug output: this is a black circle (not our mask, which is similar, but a little bit smaller)
# drawImage($layer4);

// use black circle as background (this creates our circle border)
$layer4->compositeImage($layer3Imagick::COMPOSITE_DEFAULT00);

# debug output: here we go with our circle border
# drawImage($layer4);

// draw separator between red and green rectangle (now semi circles)
$line = new ImagickDraw();
$line->setStrokeWidth(1);
$line->setStrokeColor("black");
$line->line(5015099);

// add our separator line
$layer4->drawImage($line);

drawImage($layer4);
?>

To understand how the COMPOSITE_* constants effect the image merging process, see here:
http://www.imagemagick.org/Usage/compose/#duff-porter
2009-06-23 09:31:47
http://php5.kiev.ua/manual/ru/imagickdraw.circle.html
Автор:
The four values required here are a bit confusing. After all, a circle is defined by three values: the x, y coordinates of the centre, and the radius, r.

The fourth value is redundant, but has to be given, otherwise the function fails. One way of coping with this redundancy is:

<?php
$draw 
= new ImagickDraw ();
//given that $x and $y are the coordinates of the centre, and $r the radius:
$draw->circle ($x$y$x $r$y);
?>

There are any number of actions which are synonymous with the last, including:
<?php
$draw
->circle ($x$y$x$y $r);
$draw->circle ($x$y$x $r$y);
$draw->circle ($x$y$x$y $r);
// etc, etc.
?>

Hope this helps.
2014-01-27 23:26:08
http://php5.kiev.ua/manual/ru/imagickdraw.circle.html

    Поддержать сайт на родительском проекте КГБ