归一化对于保持图像平衡是必要的(否则任何滤镜都可能很快使图像几乎完全变黑或变白)。
这里有一个简短易用的类,可以自动处理归一化并使 3x3 矩阵的输入更容易
代码遵循用于与 imageconvolution() 函数一起使用的“包含三个数组的数组”语法,并自动计算用于归一化的必要除数。
<?php
class ConvolutionFilter {
public $matrix;
public $div;
public function computeDiv() {
$this->div = array_sum ($this->matrix[0]) + array_sum ($this->matrix[1]) + array_sum ($this->matrix[2]);
}
function __construct() {
$matrix = func_get_args();
$this->matrix = array( array($matrix[0], $matrix[1], $matrix[2]),
array($matrix[3], $matrix[4], $matrix[5]),
array($matrix[6], $matrix[7], $matrix[8])
);
$this->computeDiv();
}
}
?>
示例用法
<?php
$gaussianFilter = new ConvolutionFilter( 1.0, 2.0, 1.0,
2.0, 3.0, 2.0,
1.0, 2.0, 1.0 );
imageconvolution($image, $gaussianFilter->matrix, $gaussianFilter->div, 0);
?>
一些常见的过滤器
<?php
$identityFilter = new ConvolutionFilter( 0.0, 0.0, 0.0,
0.0, 1.0, 0.0,
0.0, 0.0, 0.0 );
$sharpenFilter = new ConvolutionFilter( 0.0, -1.0, 0.0,
-1.0, 5.0, -1.0,
0.0, -1.0, 0.0 );
$edgeFilter = new ConvolutionFilter( 0.0, 1.0, 0.0,
1.0, -4.0, 1.0,
0.0, 1.0, 0.0 );
$findEdgesFilter = new ConvolutionFilter( -1.0, -1.0, -1.0,
-2.0, 8.0, -1.0,
-1.0, -1.0, -1.0 );
?>
记住,你可以使用 imagefilter() 来满足这些基本需求,但是当你想创建自己的过滤器时,上面的类会让你的工作更容易。