ImagickDraw::circle
(PECL imagick 2, PECL imagick 3)
ImagickDraw::circle — 円を描画する
説明
警告
この関数は、 現在のところ詳細な情報はありません。引数のリストのみが 記述されています。
画像上に円を描画します。
パラメータ
ox
-
原点の x 座標。
oy
-
原点の y 座標。
px
-
周囲の x 座標。
py
-
周囲の y 座標。
戻り値
値を返しません。
例
例1 ImagickDraw::circle() の例
<?php
function circle($strokeColor, $fillColor, $backgroundColor, $originX, $originY, $endX, $endY) {
//Create a ImagickDraw object to draw into.
$draw = new \ImagickDraw();
$strokeColor = new \ImagickPixel($strokeColor);
$fillColor = new \ImagickPixel($fillColor);
$draw->setStrokeOpacity(1);
$draw->setStrokeColor($strokeColor);
$draw->setFillColor($fillColor);
$draw->setStrokeWidth(2);
$draw->setFontSize(72);
$draw->circle($originX, $originY, $endX, $endY);
$imagick = new \Imagick();
$imagick->newImage(500, 500, $backgroundColor);
$imagick->setImageFormat("png");
$imagick->drawImage($draw);
header("Content-Type: image/png");
echo $imagick->getImageBlob();
}
?>
+add a note
User Contributed Notes 1 note
SkepticaLee ¶
10 years ago
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.