(PECL imagick 2 >= 2.3.0, PECL imagick 3)

Imagick::writeImageGörüntüyü belirtilen dosyaya yazar


public Imagick::writeImage(string $dosya = null): bool

Görüntüyü belirtilen dosyaya yazar. dosya olarak null verilmişse görüntü, Imagick::ReadImage() veya Imagick::SetImageFilename() ile belirlenen dosyaya yazılır.

Bağımsız Değişkenler


Görüntünün yazılacağı dosyanın yolu. Dosya uzantısı görüntünün türünü belirler. Dosya uzantısına bakılmaksızın görüntü türü "jpg:test.png" biçemine benzer şekilde belirtilebilir.

Dönen Değerler

Başarı durumunda true döner.

add a note

User Contributed Notes 4 notes

10 years ago
When running Imagick as packaged with the Abyss Web Server, neither this method nor writeImages () works. Instead the format has to be declared and the file saved by using another method or procedure, e.g.:

= new Imagick ();
$im->newImage (300, 225, "blue");
$im->writeImage ("test_0.jpg"); // fails with no error message
$im->setImageFormat ("jpeg");
file_put_contents ("test_1.jpg", $im); // works, or:
$im->imageWriteFile (fopen ("test_2.jpg", "wb")); //also works
icinagle at gmail dot com
13 years ago
If you are trying to manipulate a uploaded file and then save the file all in the same request with Apache + mod_dav this will fail.
mod_dav puts a lock on the file during the request where the file is uploaded so trying to save the smallest file, e.g. 1kb will fail with a "Failed to allocate memory" error.
pfz at pfzone dot org
11 years ago
With Imagick 3.1.0RC2, PHP4.8
If you plan to overwrite the file you're working on, before doing writeImage, consider clearing the file buffer before the write statement :

= new Imagick($your_file);
/* some processing */

// or
It happened to me that the resulting file size was wrong. This could lead to truncation, as the file is not expanded.
This happened while working on JPEG, and PNG.

this line worked for me without this hack.
($your_file, $image);

Do not rely on getImageLength() for sending your image, especially when keepalive is ON. Content length is then relevant, and must be set. If the wrong size is given, your image will be truncated.
Use filesize($your_file_) once written or strlen($image) instead (which renders your image and updates getImageLength() result).
9 years ago
I opened image with Imagick::readImageBlob. When I wanted to save resized image Imagick::writeImage did not work, but Imagick::writeImageFile did.

$image = new Imagick();
// $image->writeImage($fileDst) did not work
if($f=fopen($fileDst, "w")){
To Top