这些是 map 的字母
R = 红色
G = 绿色
B = 蓝色
A = alpha(0 为透明)
O = alpha(0 为不透明)
C = 青色
Y = 黄色
M = 品红色
K = 黑色
I = 强度(用于灰度)
P = 填充
(PECL imagick 2 >=2.3.0, PECL imagick 3)
Imagick::exportImagePixels — 导出原始图像像素
$x
,$y
,$width
,$height
,$map
,$STORAGE
将图像像素导出到数组中。map 定义导出像素的顺序。返回数组的大小为 width * height * strlen(map)
。如果 Imagick 已针对 ImageMagick 6.4.7 或更高版本编译,则可以使用此方法。
x
导出区域的 X 坐标
y
导出区域的 Y 坐标
width
导出区域的宽度
height
导出区域的高度
map
导出像素的顺序。例如 "RGB"
。map 的有效字符为 R、G、B、A、O、C、Y、M、K、I 和 P。
STORAGE
请参阅此 像素类型常量列表
返回一个包含像素值的数组。
在发生错误时抛出 ImagickException。
示例 #1 使用 Imagick::exportImagePixels()
将图像像素导出到数组中
<?php
/* 创建新对象 */
$im = new Imagick();
/* 创建新图像 */
$im->newPseudoImage(0, 0, "magick:rose");
/* 导出图像像素 */
$pixels = $im->exportImagePixels(10, 10, 2, 2, "RGB", Imagick::PIXEL_CHAR);
/* 输出 */
var_dump($pixels);
?>
以上示例将输出
array(12) { [0]=> int(72) [1]=> int(64) [2]=> int(57) [3]=> int(69) [4]=> int(59) [5]=> int(43) [6]=> int(124) [7]=> int(120) [8]=> int(-96) [9]=> int(91) [10]=> int(84) [11]=> int(111) }