前些天记录了一篇《PHP生成汉字转Emoji的对照图片》,在此之前都是用PHP的GD扩展实现绘图,还只能做静态的图片出来,这些天在家闭关养伤,花了很多时间来进行“國語辭典系列網站全面升級”,这期间也摸索出来PHP利用Imagick扩展来绘制GIF格式动态图片的办法,现在记录如下。
Imagick 是用 ImageMagic API 来创建和修改图像的PHP官方扩展,详细介绍请看《Imagick官方文档》。
ImageMagick® 是用来创建,编辑,合并位图图像的一套组件。 它能够用于读取,转换,写入多种不同格式的图像。 包含 DPX, EXR, GIF, JPEG, JPEG-2000, PDF, PhotoCD, PNG, Postscript, SVG, 和 TIFF。
不能不说PHP的ImageMagick的图像处理功能非常强大👍,我也只是用到其中很少一部分。安装是同事搞定的,我主要用这个来把PNG图片整合为动态GIF图片,一个例子是把汉字笔顺的PNG图片转为动态的GIF图片,繁體的台灣的“灣”字筆順原始图片如下:
這個灣字有25畫,所以上面一幅PNG圖片中有25個小圖片,用PHP的Imagick讀取后計算坐標,將25個小圖片都分別讀入到一個frame中,再把這25個frame組合成一個新的GIF圖,設置每幀之間的延時,就可以形成一幅動態圖片如下:
這樣就把以後的4808個漢字筆順PNG圖片都可以轉爲GIF動圖,有興趣的朋友可以去這裏看:✍️筆順字典📘
在Drupal的自定义模块中的PHP参考代码如下:
//单字PNG笔顺图转GIF动态图片 function bishun_png_gif($text) { // Set the content-type header("Content-type: image/gif"); $png_path = SOME_PATH."/4808png"; $png_file_path = "$png_path/$text.png";//原始文件位置 if (file_exists($png_file_path)) { $im = new Imagick();//创建目标文件 $im->setFormat("gif"); $png_image = new Imagick();//创建原始文件 $png_image->readImage($png_file_path);//读取 $png_width = $png_image->getImageWidth(); $png_height = $png_image->getImageHeight(); //132x648(555) or 66x648(4145), 62x645(98), 132x645(10) if ($png_width > 100) { $cols = 2;//列数 1或者2 } else { $cols = 1; } $count = 17 * $cols;//方块计数,每列17个 $x_start = 14;//(66-38)/2 $y_start = 19;//(648-38*17)/2 $y_plus = 36.2; for ($i = 1; $i <= $count; $i++) {//逐个笔画处理 $frame = new Imagick();//创建新帧 $frame->readImage($png_file_path); $x = $x_start; if ($cols == 1) {//仅一列 $x = $x_start; $y = $y_start + ($i-1) * $y_plus; } elseif ($i <=17) {//两列的右列 $x = $x_start + 66; $y = $y_start + ($i-1) * $y_plus; } else {//两列的左列 $x = $x_start + (-4); $y = $y_start + ($i-1-17) * $y_plus; } $frame->extentImage(36,36,$x,$y);//在x,y的offset位置截取36x36大小 $colors = $frame->getImageColors();//获取颜色数量 if ($colors > 1) {//多种颜色,也就是有笔画 $frame->setImageDelay(66);//设置延时 $im->addImage($frame);//新帧加入GIF图片 } else {//单一颜色,也就是空白 break;//退出循环 } } echo $im->getImagesBlob();//显示GIF图片 } }
做了这个GIF动态图后,我又做了两种与汉字转Emoji相关的PNG转GIF图,如下:
PNG靜態圖
GIF動態圖
PNG靜態圖
GIF動態圖
这也都是用PHP Imagick进行转换生成的动态GIF图片,应该还有更多高级玩法,以后有空、有需要再摸。✌
评论