getQuantumRange() can be handy here:
<?php
$i = new Imagick($imageFile);
$max = $i->getQuantumRange();
$max = $max["quantumRangeLong"];
$i->thresholdImage(0.77 * $max);
?>
PHP - Manual: Imagick::thresholdImage
2025-01-20
(PECL imagick 2, PECL imagick 3)
Imagick::thresholdImage — Changes the value of individual pixels based on a threshold
$threshold
, int $channel
= Imagick::CHANNEL_DEFAULT): boolChanges the value of individual pixels based on the intensity of each pixel compared to threshold. The result is a high-contrast, two color image.
threshold
channel
成功时返回 true
。
示例 #1 Imagick::thresholdImage()
<?php
function thresholdimage($imagePath, $threshold, $channel) {
$imagick = new \Imagick(realpath($imagePath));
$imagick->thresholdimage($threshold * \Imagick::getQuantum(), $channel);
header("Content-Type: image/jpg");
echo $imagick->getImageBlob();
}
?>
getQuantumRange() can be handy here:
<?php
$i = new Imagick($imageFile);
$max = $i->getQuantumRange();
$max = $max["quantumRangeLong"];
$i->thresholdImage(0.77 * $max);
?>
官方地址:https://www.php.net/manual/en/imagick.thresholdimage.php