图像居中裁减的大致思路:

1.首先将图像进行缩放,使得缩放后的图像能够恰好覆盖裁减区域.(imagecopyresampled ― 重采样拷贝部分图像并调整大小)

2.将缩放后的图像放置在裁减区域中间.(imagecopy ― 拷贝图像的一部分)

3.裁减图像并保存.(imagejpeg | imagepng | imagegif ― 输出图象到浏览器或文件)

具体代码:

  1. <?php
  2.  
  3. //==================缩放裁剪函数====================
  4. /**
  5. * 居中裁剪图片
  6. * @param string $source [原图路径]
  7. * @param int $width [设置宽度]
  8. * @param int $height [设置高度]
  9. * @param string $target [目标路径]
  10. * @return bool [裁剪结果]
  11. */
  12. function image_center_crop($source, $width, $height, $target)
  13. {
  14. if (!file_exists($source)) return false;
  15. /* 根据类型载入图像 */
  16. switch (exif_imagetype($source)) {
  17. case IMAGETYPE_JPEG:
  18. $image = imagecreatefromjpeg($source);
  19. break;
  20. case IMAGETYPE_PNG:
  21. $image = imagecreatefrompng($source);
  22. break;
  23. case IMAGETYPE_GIF:
  24. $image = imagecreatefromgif($source);
  25. break;
  26. }
  27. if (!isset($image)) return false;
  28. /* 获取图像尺寸信息 */
  29. $target_w = $width;
  30. $target_h = $height;
  31. $source_w = imagesx($image);
  32. $source_h = imagesy($image);
  33. /* 计算裁剪宽度和高度 */
  34. $judge = (($source_w / $source_h) > ($target_w / $target_h));
  35. $resize_w = $judge ? ($source_w * $target_h) / $source_h : $target_w;
  36. $resize_h = !$judge ? ($source_h * $target_w) / $source_w : $target_h;
  37. $start_x = $judge ? ($resize_w - $target_w) / 2 : 0;
  38. $start_y = !$judge ? ($resize_h - $target_h) / 2 : 0;
  39. /* 绘制居中缩放图像 */
  40. $resize_img = imagecreatetruecolor($resize_w, $resize_h);
  41. imagecopyresampled($resize_img, $image, 0, 0, 0, 0, $resize_w, $resize_h, $source_w, $source_h);
  42. $target_img = imagecreatetruecolor($target_w, $target_h);
  43. imagecopy($target_img, $resize_img, 0, 0, $start_x, $start_y, $resize_w, $resize_h);
  44. /* 将图片保存至文件 */
  45. if (!file_exists(dirname($target))) mkdir(dirname($target), 0777, true);
  46. switch (exif_imagetype($source)) {
  47. case IMAGETYPE_JPEG:
  48. imagejpeg($target_img, $target);
  49. break;
  50. case IMAGETYPE_PNG:
  51. imagepng($target_img, $target);
  52. break;
  53. case IMAGETYPE_GIF:
  54. imagegif($target_img, $target);
  55. break;
  56. }
  57. // return boolval(file_exists($target));//PHP5.5以上可用boolval()函数获取返回的布尔值
  58. return file_exists($target)?true:false;//兼容低版本PHP写法
  59. }
  60.  
  61. //==================函数使用方式====================
  62. // 原始图片的路径
  63. $source = 'photoClip.jpg';
  64. $width = 480; // 裁剪后的宽度
  65. $height = 480;// 裁剪后的高度
  66. // 裁剪后的图片存放目录
  67. $target = 'dd111.jpg';
  68. // 裁剪后保存到目标文件夹
  69. if (image_center_crop($source, $width, $height, $target)) {
  70. echo "原图1440*900为:<img src='$source'>";
  71. echo "<hr>";
  72. echo "修改后图片480*480为:<img src='$target'>";
  73. }

附:代码测试中遇到的问题

报错:call an undefined function exif_imagetype()

解决方法:

打开扩展 extension=php_exif.dll

并将extension=php_mbstring.dll ,放到extension=php_exif.dll前边

另:boolval()函数为PHP5.5版本以上才能使用的函数,本文测试代码中为兼容低版本,使用如下语句代替

  1. return file_exists($target)?true:false;

PHP实现的自定义图像居中裁剪函数示例的更多相关文章

  1. PHP 图像居中裁剪函数

    图像居中裁减的大致思路: 1.首先将图像进行缩放,使得缩放后的图像能够恰好覆盖裁减区域.(imagecopyresampled — 重采样拷贝部分图像并调整大小) 2.将缩放后的图像放置在裁减区域中间 ...

  2. PHP图片裁剪函数(图像不变形)

    PHP图片裁剪函数(图像不变形) <? *exif_imagetype -- 判断一个图像的类型 *说明:函数功能是把一个图像裁剪为任意大小的图像,图像不变形 * 参数说明:输入 需要处理图片的 ...

  3. PHP 载入图像 imagecreatefrom_gif_jpeg_png 系列函数

    imagecreatefrom 系列函数用于从文件或 URL 载入一幅图像. 载入图像 imagecreatefrom 系列函数用于从文件或 URL 载入一幅图像,成功返回图像资源,失败则返回一个空字 ...

  4. thinkphp图像的裁剪、缩放、加水印

    ThinkPHP 图片处理函数,需要文字水印字体,可在windows下 控制面板 > 大图标(右上角) > 字体 找到需要的字体 1 2 3 4 5 6 7 8 9 10 11 12 13 ...

  5. Qt之自定义信号和槽函数

    自定义信号和槽函数: 1.类的声明和实现分别放在.h和.cpp文件中: 2.类声明包含Q_OBJECT宏: 3.信号只要声明不要设计其的实现函数 4.发射信号用emit关键字 5.自定义槽的实现与普通 ...

  6. phpcms v9 自定义伪静态的分页函数

    因为.这个页面还没做好..等做好了..再给大家演示...... 调用方法:$page_attr=pages_open($num[0]['cun'],$get_page,$max_page,'http: ...

  7. [图形学] Chp14 GLU曲面裁剪函数程序示例及样条表示遗留问题

    样条表示这章已经看完,最后的GLU曲面裁剪函数,打算按书中的示例实现一下,其中遇到了几个问题. 先介绍一下GLU曲面裁剪函数的使用方法. 1 裁剪函数是成对出现的: gluBeginTrim和gluE ...

  8. js面向对象自定义MyString()的构造器函数,实现内建String()属性和方法:

    js面向对象自定义MyString()的构造器函数,实现内建String()属性和方法: var s = new MyString('hello'); s.length; s[0]; // " ...

  9. CSS 图像居中对齐

    CSS  图像居中对齐 我们在<CSS 内外边距>学过内容居中,它的原理是将外边左右设置为auto.图像居中也是这个原理. 示例 <!DOCTYPE html> <htm ...

随机推荐

  1. 创建vue项目的时候遇到:PhantomJS not found on PATH

    1.提示找不到PhantomJS需要进行下载,如果网速允许的话可以直接 npm install -g phantomjs 如果网速不给力的话,那就先进行淘宝镜像安装 npm install -g cn ...

  2. 2019.04.09 电商24 订单模快 ORM

    前面三个模块已近结束,现在看是订单模块的.想一下淘宝上的订单,在购物车中选中,提交,跳转到订单界面. 获取传过来的信息,那也要建立一个订单表,当我支付的时候,也要获取一些数据,将这些数据放到这个表中 ...

  3. [Java in NetBeans] Lesson 09. Switch / If-Else Ladder

    这个课程的参考视频和图片来自youtube. 主要学到的知识点有: 1. Nested If-else statement (if-else ladder) /** * 90 and above == ...

  4. easyui combobox 动态加载数据C#

    <script type="text/javascript" src="Scripts/jquery-1.8.2.min.js"></scri ...

  5. centos7及服务器端安装python2.7.13, setuptools, pip

    1. 安装python2.7.13 因为涉及到安装到服务器,所以可能不能直接在usr/bin及usr/local/bin下安装,所以本文详解安装在自定义目录下. 下载安装包: $ wget https ...

  6. ACM-彩票

    题目描述 OMeGa 兄弟最近赢了巨奖!但当他们在分彩票奖金的时候却遇到了一些问题.他们两兄弟对一切偶数都痴迷不已,以至于在分奖金的时候,他们两个都希望自己分到的钱是偶数(即便两人分的钱不一样也没关系 ...

  7. HTML5特效收录-不定时更新

    在工作中,我们可能会用到各种交互效果.而这些效果在平常翻看文章的时候碰到很多,但是一时半会又想不起来在哪,所以养成知识整理的习惯是很有必要的.希望能给大大家启发,并且学习. HTML5 Canvas粒 ...

  8. Git常用的命令

    常用 Git 命令清单   作者: 阮一峰 日期: 2015年12月 9日 原文地址:http://www.ruanyifeng.com/blog/2015/12/git-cheat-sheet.ht ...

  9. [14]Windows内核情景分析 --- 文件系统

    文件系统 一台机器上可以安装很多物理介质来存放资料(如磁盘.光盘.软盘.U盘等).各种物理介质千差万别,都配备有各自的驱动程序,为了统一地访问这些物理介质,windows设计了文件系统机制.应用程序要 ...

  10. MySQL练习题之参考答案

    1.创建表结构和数据 /* Navicat Premium Data Transfer Source Server : localhost Source Server Type : MySQL Sou ...