imagesetinterpolation

(PHP 5 >= 5.5.0, PHP 7, PHP 8)

imagesetinterpolationAra değerleme yöntemini tanımlar

Açıklama

imagesetinterpolation(GdImage $görüntü, int $yöntem = IMG_BILINEAR_FIXED): bool

Ara değerleme yöntemini tanımlar. Atanan ara değerleme yöntemi imagerotate() gibi çeşitli GD işlevlerini etkiler.

Bağımsız Değişkenler

görüntü

imagecreatetruecolor() gibi bir görüntü oluşturma işlevinden dönen bir GdImage nesnesi.

yöntem

Ara değerleme yöntemi şunlaredan biri olabilir:

  • IMG_BELL: Çan süzgeci.
  • IMG_BESSEL: Bessel süzgeci.
  • IMG_BICUBIC: Çift kübik ara değerlemesi.
  • IMG_BICUBIC_FIXED: Çift kübik ara değerlemesinin sabit nokta uygulaması.
  • IMG_BILINEAR_FIXED: Çift doğrusal ara değerlemesinin sabit nokta uygulaması. (öntanımlıdır (ayrıca görüntü oluşturmada)).
  • IMG_BLACKMAN: Blackman pencere işlevi.
  • IMG_BOX: Kutu bulanıklığı süzgeci.
  • IMG_BSPLINE: Yivli ara değerleme.
  • IMG_CATMULLROM: Kübik Hermit yivli ara değerleme.
  • IMG_GAUSSIAN: Gauss işlevi.
  • IMG_GENERALIZED_CUBIC: Genelleştirilmiş kübik yivli fraktal ara değerlemesi.
  • IMG_HERMITE: Hermit ara değerlemesi.
  • IMG_HAMMING: Abartma süzgeci.
  • IMG_HANNING: Hanning süzgeci.
  • IMG_MITCHELL: Mitchell süzgeci.
  • IMG_POWER: Güç ara değerlemesi.
  • IMG_QUADRATIC: İkinci dereceden ters ara değerleme.
  • IMG_SINC: Sinc işlevi.
  • IMG_NEAREST_NEIGHBOUR: En yakın komşu ara değerlemesi.
  • IMG_WEIGHTED4: Ağırlıklandırma süzgeci.
  • IMG_TRIANGLE: Üçgen ara değerlemesi.

Dönen Değerler

Başarı durumunda true, başarısızlık durumunda false döner.

Sürüm Bilgisi

Sürüm: Açıklama
8.0.0 görüntü bağımsız değişkeninde artık bir GdImage nesnesi aktarmak gerekiyor; evvelce resource türünde geçerli bir gd değeri gerekirdi.

Örnekler

Örnek 1 - imagesetinterpolation() örneği

<?php
// Görüntüyü yükle
$görüntü = imagecreate(500, 500);

// Öntanımlı ara değerleme: IMG_BILINEAR_FIXED
// 'Mitchell' süzgecine geç:
imagesetinterpolation($görüntü, IMG_MITCHELL);

// $görüntü ile çalışmaya devam...
?>

Notlar

Ara değerleme yöntemini değiştirmek, işlem sırasında aşağıdaki işlevleri etkiler:

Ayrıca Bakınız

add a note add a note

User Contributed Notes 1 note

up
-1
shaun at slickdesign dot com dot au
7 years ago
Setting the interpolation does not carry through to any images created by imageaffine() or imagerotate(). It defaults to IMG_BILINEAR_FIXED and would need to be set on each generated image as required.

<?php
imagesetinterpolation
( $image, IMG_NEAREST_NEIGHBOUR );

// Rotated using IMG_NEAREST_NEIGHBOUR
$rotated = imagerotate( $image, 45, $transparent );

// Rotated using IMG_BILINEAR_FIXED
$rotated_again = imagerotate( $rotated, 45, $transparent );
?>

Setting the interpolation to IMG_NEAREST_NEIGHBOUR can help to preserve details and prevent sampling issues when rotating an image at 90 degree increments, including when rotating clockwise.

<?php
// Rotated image can appear blurred and on a slight angle.
$rotated = imagerotate( $image, -360, $transparent );

// Similar to starting Image although it may still show a background or be on a slight angle.
imagesetinterpolation( $image, IMG_NEAREST_NEIGHBOUR );
$rotated = imagerotate( $image, -360, $transparent );
?>
To Top