SunshinePHP Developer Conference 2015

imagelayereffect

(PHP 4 >= 4.3.0, PHP 5)

imagelayereffectPHP ile gelen libgd'nin katmanlama etkisini kullanmak için alfa harmanlama seçeneğini ayarlar

Açıklama

bool imagelayereffect ( resource $image , int $etki )

PHP ile gelen libgd'nin katmanlama etkisini kullanmak için alfa harmanlama seçeneğini ayarlar.

Değiştirgeler

resim

imagecreatetruecolor() gibi bir resim oluşturma işlevinden dönen bir resim verisi.

etki

Şu sabitlerden biri olabilir:

IMG_EFFECT_REPLACE
Piksel değiştirme etkisi kullanılır (imagealphablending() işlevine TRUE aktarmaya eşdeğerdir).
IMG_EFFECT_ALPHABLEND
Normal piksel harmanlaması kullanılır(imagealphablending() işlevine FALSE aktarmaya eşdeğerdir).
IMG_EFFECT_NORMAL
IMG_EFFECT_ALPHABLEND ile aynı.
IMG_EFFECT_OVERLAY
Siyah pikseller siyah, beyaz pikseller beyaz olarak kalırken gri artalan pikselleri önalan pikselinin rengini alırlar.

Dönen Değerler

Başarı durumunda TRUE, başarısızlık durumunda FALSE döner.

Örnekler

Örnek 1 - imagelayereffect() örneği

<?php
// Resim taslağını oluşturalım
$im imagecreatetruecolor(100100);

// Artalanı griye boyayalım
imagefilledrectangle($im00100100imagecolorallocate($im220220220));

// Artalan renk değiştirme etkisini etkin kılalım
imagelayereffect($imIMG_EFFECT_OVERLAY);

// Gri zemine iki elips çizelim
imagefilledellipse($im50504040imagecolorallocate($im100255100));
imagefilledellipse($im50505080imagecolorallocate($im100100255));
imagefilledellipse($im50508050imagecolorallocate($im255100100));

// Resmi çıktılayalım
header('Content-type: image/png');

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

Yukarıdaki örnek şuna benzer bir çıktı üretir:

imagelayereffect.png

Notlar

Bilginize: Bu işlev sadece, PHP, PHP paketinde bulunan GD kütüphanesi ile derlenmişse kullanılabilir.

Bilginize: Bu işlev GD'nin 2.0.1 veya sonraki sürümlerini gerektirir (2.0.28 veya sonraki sürümler önerilir).

add a note add a note

User Contributed Notes 5 notes

up
0
rx
28 days ago
IMG_EFFECT_OVERLAY doesn't work in PHP 5.6.0 with GD version: 2.1.0-alpha.
up
0
andrew at iwebsolutions dot co dot uk
6 years ago
I have been getting a fatal error:

Fatal error: Call to undefined function imagelayereffect()

This doesn't work with Ubuntu server (8.04 lts) and the php5-gd package.  If you need this you will have to recompile PHP with GD built-in.
up
0
[myname] at mac dot com
6 years ago
^^ my name is coreyward ^^

imagelayereffect needs to be applied to the destination image, not the source image. As noted, the only useful "effect" as of this time is IMG_EFFECT_OVERLAY since the others are merely another way of setting the alpha blending flag.

You can also use imagecopymerge with a lower pct argument to blend two images with more control over the opacity at which the top image is blended.

<?

// overlays $im_src onto $im_dst properly (assuming same dims)

imagelayereffect($im_dst, IMG_EFFECT_OVERLAY);
imagecopy($im_dst, $im_src, 0, 0, 0, 0, $im_dst_x, $im_dst_y);

?>
up
0
Remon
6 years ago
I found the following example on a Chinese site and translated and adjusted it. It creates a portrait from the sample picture.

<?php

// Portrait image
$im = imagecreatefromjpeg( "sample.jpg");

// Get width and height
$w = imagesx($im);
$h = imagesy($im);

// Non-through
$c_visible = 0x007F7F7F;
// Background (black)
$c_bg = 0x00000000;

// Create mask
$im_mask = imagecreatetruecolor($w,$h);
imageFilledRectangle($im_mask, 0,0, $w,$h, $c_bg);
imageFilledEllipse ($im_mask, $w/2,$h/2, $w*.9,$h*.9, $c_visible);

// Only overlay seems to something useful
imagelayereffect($im_mask, IMG_EFFECT_OVERLAY);

imagecopy($im_mask, $im, 0,0, 0,0, $w,$h);
imagedestroy($im);

imagepng($im_mask);
imagedestroy($im_mask);

?>

Try removing the 'create mask' code and just add another image with 'createimagefromjpeg' to see 'normal' overlay. It blends the colors like different layers in Photoshop.
up
0
Anonymous
9 years ago
I assume, that the specific effects are similiar to those used in Adobe Photoshop for blending layers.
There might be things like IMG_EFFECT_MULTIPLY resulting of that.
To Top