10.4 图像缩放和裁剪技术

最后更新于:2022-04-02 00:21:30

上一章我们学习了图片的水印技术,水印技术和我们这一章要学习到的缩放、裁剪技术基本一致,只不过使用的函数发生了一点点变化。 常用的两个函数如下: | 函数名 | 函数说明 | | -- | -- | | imagecopyresampled | 重采样拷贝部分图像并调整大小 | | imagecopyresized | 拷贝部分图像并调整大小 | 我们来看看这两个函数,这两个函数用起来不难。就是参数略有些复杂。并且来完成图像的缩放或者裁剪: > bool imagecopyresampled ( resource $目标图 , resource $来源图 , int $目标开始的x位置 , int $目标开始的y位置 , int $来源开始的x位置 , int $来源开始的y位置 , int $目标图片的宽 , int $目标图片的高, int $来源图片的宽 , int $来源图片的高 ) 请注意,上下两个图片的参数都是一样的。 > bool imagecopyresized ( resource $目标图 , resource $来源图 , int $目标开始的x位置 , int $目标开始的y位置 , int $来源开始的x位置 , int $来源开始的y位置 , int $目标图片的宽 , int $目标图片的高, int $来源图片的宽 , int $来源图片的高 ) 图片缩放和裁剪的方法都是一样的,不同的是拷贝时拷贝的是整张图片还是部份部片。 操作方式说明: 从来源图片的开始点(x,y)起,指定的宽高的大小图片。放至到目标图片的起点(x,y),指定宽高大小的图片中。 ##一、缩放图片,我们将操作步骤化: 1. 打开来源图片 2. 设置图片缩放百分比(缩放) 3. 获得来源图片,按比调整大小 4. 新建一个指定大小的图片为目标图 5. 将来源图调整后的大小放到目标中 6. 销毁资源 我们将范冰冰进行缩放: ![document/2015-09-22/5600d61ee6dfc](http://box.kancloud.cn/document_2015-09-22_5600d61ee6dfc.png) ~~~ ~~~ 我们来看看缩放后的最终的结果: ![document/2015-09-22/560108ae9ec72](http://box.kancloud.cn/document_2015-09-22_560108ae9ec72.png) ##二、裁剪图片,我们将操作步骤化: 1. 打开来源图片和目标图片 2. 截取来源图片中的点,设置宽高。放至到目标图片中。(裁剪) 3. 保存图片输入 4. 销毁资源 我们将下图中的“度”字裁减出来放至到哈士奇的脸上: 百度logo: ![document/2015-09-22/56010df4559d3](http://box.kancloud.cn/document_2015-09-22_56010df4559d3.png) 哈士奇图片: ![document/2015-09-22/56010e592e7d8](http://box.kancloud.cn/document_2015-09-22_56010e592e7d8.png) 我们来梳理一下思路: 1. 度的开始的坐标x,y轴为:407,154 2. 度这个字从x,y坐标开始的宽、高为:80,89 3. 图片中哈士奇脸的位置的x,y轴位置为:281,71 4. 图片中哈士奇脸的x,y坐标宽、高为:132,160 坐标和宽高我们都清楚了我们开始按照函数的用法来,使用代码来操作图片: 我们来看看实验效果: ![document/2015-09-22/56011105316ee](http://box.kancloud.cn/document_2015-09-22_56011105316ee.png)
';