(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.

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


origin x coordinate


origin y coordinate


perimeter x coordinate


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.

function drawImage(Imagick $im) {
header("Content-Type: image/" $im->getImageFormat());

// define red/green layer
$layer1 = new Imagick();

$red = new ImagickDraw();

$green = new ImagickDraw();


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

// define circle mask
$layer2 = new Imagick();

$circle = new ImagickDraw();


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

// use mask

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

// define background
$layer3 = new Imagick();


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

$ring1 = new ImagickDraw();


# 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)

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

// draw separator between red and green rectangle (now semi circles)
$line = new ImagickDraw();

// add our separator line


To understand how the COMPOSITE_* constants effect the image merging process, see here:
2009-06-23 09:31:47
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:

= 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:
->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

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