PHP 7.3.14 Released

imageopenpolygon

(PHP 7 >= 7.2.0)

imageopenpolygonオープンポリゴンを描画する

説明

imageopenpolygon ( resource $image , array $points , int $num_points , int $color ) : bool

imageopenpolygon() 関数は、 与えられた image のオープンポリゴンを描画します。 imagepolygon() とは異なり、 始点と終点の間の線は描かれません。

パラメータ

image

imagecreatetruecolor() のような画像作成関数が返す画像リソース。

points

ポリゴンの点を含む配列:

points[0] = x0
points[1] = y0
points[2] = x1
points[3] = y1

num_points

全ての点の数。少なくとも3以上である必要があります。

color

imagecolorallocate() で作成された色識別子。

返り値

成功した場合に TRUE を、失敗した場合に FALSE を返します。

例1 imageopenpolygon() の例

<?php
// 空の画像を生成します。
$image imagecreatetruecolor(400300);

// 色をポリゴンに割り当てます。
$col_poly imagecolorallocate($image255255255);

// ポリゴンを描画します。
imageopenpolygon($image, array(
        
0,   0,
        
100200,
        
300200
    
),
    
3,
    
$col_poly);

// 画像をブラウザに出力します。
header('Content-type: image/png');

imagepng($image);
imagedestroy($image);
?>

上の例の出力は、 たとえば以下のようになります。

imageopenpolygon() の出力例

参考

add a note add a note

User Contributed Notes 1 note

up
-1
marco at oostende dot nl
1 year ago
In case you want to use an open polygon but are stuck with a PHP version prior to 7.2, a solution may be to 'backplot' your array to its original start. Say you have an array of pixels (below seperated by commas)

<?php
$arr
= array();
for (
$i = 0; $i < count($pixels); $i++) {
   
$pixel = explode(',', $pixels[$i]);
    if ((
$pixel[0] > 0) && ($pixel[1] > 0)) {
       
$arr[] = $pixel[0];
       
$arr[] = $pixel[1];
    }
}
imagepolygon($im, $arr, (count($arr) / 2), $otcolor);
?>

you can replace this by something like

<?php
$arr
= array();
for (
$i = 0; $i < count($pixels); $i++) {
   
$pixel = explode(',', $pixels[$i]);
   
$arr[] = $pixel[0];
   
$arr[] = $pixel[1];
}
// imageopenpolygon($im, $arr, (count($arr) / 2), $otcolor) is not possible, so...
for ($i = (count($pixels)-1); $i >= 0; $i--) {
   
$pixel = explode(',', $pixels[$i]);
   
$arr[] = $pixel[0];
   
$arr[] = $pixel[1];
}
imagepolygon($im, $arr, (count($arr) / 2), $otcolor);
?>
To Top