php 图片剪切

 1 <?php
 2
 3 /**
 4  * 图像裁剪
 5  * @param $source_path 原图路径
 6  * @param $target_width 需要裁剪的宽
 7  * @param $target_height 需要裁剪的高
 8  * @return bool
 9  */
10 function imagecropper($source_path, $target_width, $target_height)
11 {
12     $source_info   = getimagesize($source_path);
13     $source_width  = $source_info[0];
14     $source_height = $source_info[1];
15     $source_mime   = $source_info[‘mime‘];
16     $source_ratio  = $source_height / $source_width;
17     $target_ratio  = $target_height / $target_width;
18
19     // 源图过高
20     if ($source_ratio > $target_ratio) {
21         $cropped_width  = $source_width;
22         $cropped_height = $source_width * $target_ratio;
23         $source_x       = 0;
24         $source_y       = ($source_height - $cropped_height) / 2;
25     } // 源图过宽
26     elseif ($source_ratio < $target_ratio) {
27         $cropped_width  = $source_height / $target_ratio;
28         $cropped_height = $source_height;
29         $source_x       = ($source_width - $cropped_width) / 2;
30         $source_y       = 0;
31     } // 源图适中
32     else {
33         $cropped_width  = $source_width;
34         $cropped_height = $source_height;
35         $source_x       = 0;
36         $source_y       = 0;
37     }
38     $funcList = array(
39         ‘image/gif‘  => array(
40             ‘create‘ => ‘imagecreatefromgif‘,
41             ‘make‘   => ‘imagegif‘,
42             ‘mime‘   => ‘.gif‘,
43         ),
44         ‘image/jpeg‘ => array(
45             ‘create‘ => ‘imagecreatefromjpeg‘,
46             ‘make‘   => ‘imagejpeg‘,
47             ‘mime‘   => ‘.jpg‘,
48         ),
49         ‘image/png‘  => array(
50             ‘create‘ => ‘imagecreatefrompng‘,
51             ‘make‘   => ‘imagepng‘,
52             ‘mime‘   => ‘.png‘,
53         ),
54     );
55     if (isset($funcList[$source_mime])) {
56         $curFunc = $funcList[$source_mime];
57     } else {
58         return FALSE;
59     }
60     $source_image = $curFunc[‘create‘]($source_path);
61
62     $target_image  = imagecreatetruecolor($target_width, $target_height);
63     $cropped_image = imagecreatetruecolor($cropped_width, $cropped_height);
64
65     // 裁剪
66     imagecopy($cropped_image, $source_image, 0, 0, $source_x, $source_y, $cropped_width, $cropped_height);
67     // 缩放
68     imagecopyresampled($target_image, $cropped_image, 0, 0, 0, 0, $target_width, $target_height, $cropped_width, $cropped_height);
69
70     //保存图片到本地(两者选一)
71     $randNumber = mt_rand(00000, 99999) . mt_rand(000, 999);
72     //$fileName   = substr(md5($randNumber), 8, 16) . ".png";
73     $fileName = time() . ‘_‘ . substr(md5($randNumber), 8, 16) . $curFunc[‘mime‘];
74     //imagepng($target_image, ‘./‘ . $fileName);
75     //imagepng($target_image, ‘./‘ . $fileName);
76     //$imgFunc2($target_image, ‘./‘ . $fileName);
77     $curFunc[‘make‘]($target_image, ‘./‘ . $fileName);
78     imagedestroy($target_image);
79
80     //直接在浏览器输出图片(两者选一)
81     /*header(‘Content-Type: image/jpeg‘);
82     imagepng($target_image);
83     imagedestroy($target_image);
84     imagejpeg($target_image);
85     imagedestroy($source_image);
86     imagedestroy($target_image);
87     imagedestroy($cropped_image);*/
88 }
89
90 //调用
91 //imagecropper(‘./img033.jpg‘,300,300);
92 imagecropper(‘./4.jpg‘, 140, 140);
93 //imagecropper(‘./img033.jpg‘,55,55);
94 ?>

<?php

/**
* 图像裁剪
* @param $source_path 原图路径
* @param $target_width 需要裁剪的宽
* @param $target_height 需要裁剪的高
* @return bool
*/
function imagecropper($source_path, $target_width, $target_height)
{
$source_info = getimagesize($source_path);
$source_width = $source_info[0];
$source_height = $source_info[1];
$source_mime = $source_info[‘mime‘];
$source_ratio = $source_height / $source_width;
$target_ratio = $target_height / $target_width;

// 源图过高
if ($source_ratio > $target_ratio) {
$cropped_width = $source_width;
$cropped_height = $source_width * $target_ratio;
$source_x = 0;
$source_y = ($source_height - $cropped_height) / 2;
} // 源图过宽
elseif ($source_ratio < $target_ratio) {
$cropped_width = $source_height / $target_ratio;
$cropped_height = $source_height;
$source_x = ($source_width - $cropped_width) / 2;
$source_y = 0;
} // 源图适中
else {
$cropped_width = $source_width;
$cropped_height = $source_height;
$source_x = 0;
$source_y = 0;
}
$funcList = array(
‘image/gif‘ => array(
‘create‘ => ‘imagecreatefromgif‘,
‘make‘ => ‘imagegif‘,
‘mime‘ => ‘.gif‘,
),
‘image/jpeg‘ => array(
‘create‘ => ‘imagecreatefromjpeg‘,
‘make‘ => ‘imagejpeg‘,
‘mime‘ => ‘.jpg‘,
),
‘image/png‘ => array(
‘create‘ => ‘imagecreatefrompng‘,
‘make‘ => ‘imagepng‘,
‘mime‘ => ‘.png‘,
),
);
if (isset($funcList[$source_mime])) {
$curFunc = $funcList[$source_mime];
} else {
return FALSE;
}
$source_image = $curFunc[‘create‘]($source_path);

$target_image = imagecreatetruecolor($target_width, $target_height);
$cropped_image = imagecreatetruecolor($cropped_width, $cropped_height);

// 裁剪
imagecopy($cropped_image, $source_image, 0, 0, $source_x, $source_y, $cropped_width, $cropped_height);
// 缩放
imagecopyresampled($target_image, $cropped_image, 0, 0, 0, 0, $target_width, $target_height, $cropped_width, $cropped_height);

//保存图片到本地(两者选一)
$randNumber = mt_rand(00000, 99999) . mt_rand(000, 999);
//$fileName = substr(md5($randNumber), 8, 16) . ".png";
$fileName = time() . ‘_‘ . substr(md5($randNumber), 8, 16) . $curFunc[‘mime‘];
//imagepng($target_image, ‘./‘ . $fileName);
//imagepng($target_image, ‘./‘ . $fileName);
//$imgFunc2($target_image, ‘./‘ . $fileName);
$curFunc[‘make‘]($target_image, ‘./‘ . $fileName);
imagedestroy($target_image);

//直接在浏览器输出图片(两者选一)
/*header(‘Content-Type: image/jpeg‘);
imagepng($target_image);
imagedestroy($target_image);
imagejpeg($target_image);
imagedestroy($source_image);
imagedestroy($target_image);
imagedestroy($cropped_image);*/
}

//调用
//imagecropper(‘./img033.jpg‘,300,300);
imagecropper(‘./4.jpg‘, 140, 140);
//imagecropper(‘./img033.jpg‘,55,55);
?>

时间: 2024-10-12 00:58:51

php 图片剪切的相关文章

图片上传,图片剪切jquery.imgareaselect

---恢复内容开始--- <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%><!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd&q

iOS开发UI篇—Quartz2D使用(图片剪切)

iOS开发UI篇-Quartz2D使用(图片剪切) 一.使用Quartz2D完成图片剪切 1.把图片显示在自定义的view中 先把图片绘制到view上.按照原始大小,把图片绘制到一个点上. 代码: 1 - (void)drawRect:(CGRect)rect 2 { 3 UIImage *image2=[UIImage imageNamed:@"me"]; 4 [image2 drawAtPoint:CGPointMake(100, 100)]; 5 } 显示: 2.剪切图片让图片圆

图片剪切效果

第一篇博文,把今天写的一个实现图片剪切效果的JS脚本发上来 基本思路: 三层结构,第一层为透明度是0.7的图片,第二层为正常的图片,第三层使用一个DIV作为选取框,采用CSS中的绝对定位进行覆盖 HTML代码 <div id="box"> <img id="img-1" src="imgs/cat-1.jpg"/> <img id="img-2" src="imgs/cat-2.jpg&

在iOS开发的Quartz2D使用中实现图片剪切和截屏功能

原文  http://www.jb51.net/article/75671.htm 图片剪切一.使用Quartz2D完成图片剪切1.把图片显示在自定义的view中先把图片绘制到view上.按照原始大小,把图片绘制到一个点上.代码: 复制代码代码如下: - (void)drawRect:(CGRect)rect{    UIImage *image2=[UIImage imageNamed:@"me"];    [image2 drawAtPoint:CGPointMake(100, 1

Jcrop图片剪切实例

一.创建一个弹出窗 1.html代码 <div id="BgDiv"></div> <div id="imgEditArea" style="display:none;top:0;"> <h2><fmt:message key="productDetail.lbl.editImg"/><a href="#" id="btnClose

android——拍照,相册图片剪切其实就这么简单

接触android这么久了.还没有真正的浩浩看看android拍照,相册图片剪切到底是怎么回事,每次都是从别人的代码一扣,就过来了.其实,谷歌提供的API已经很强大.只需要用的好,就那么几句就可以搞定神秘的拍照和剪切图片.废话不多少,直接看源码 package com.example.testcamera; import java.io.FileNotFoundException; import android.app.Activity; import android.content.Inten

【iOS】Quartz2D图片剪切

一.使用Quartz2D完成图片剪切1.把图片显示在自定义的view中 先把图片绘制到view上.按照原始大小,把图片绘制到一个点上. 代码: 1 - (void)drawRect:(CGRect)rect 2 { 3 UIImage *image2=[UIImage imageNamed:@"me"]; 4 [image2 drawAtPoint:CGPointMake(100, 100)]; 5 } 显示: 2.剪切图片让图片圆形展示 思路:先画一个圆,让图片显示在圆的内部,超出的

图片剪切之Croppic插件

前几天做图片上传时需要进行图片的剪切和缩放,上网查找时找到了这个插件.样式很好看,功能也很OK.但是网上都是php进行后台处理图片的例子,然后只好慢慢琢磨C#的处理.插件地址是:http://www.croppic.net/; 首先下载好插件,放入程序文件中.新建页面,引入croppic.js,croppic.min.js,croppic.css文件,同时不要忘记引入jquery文件,我用的是1.8.2的版本.之前没引入1.8.2的版本,而是使用的下载下来的demo中的https://code.

Quartz2D使用(图片剪切)

Quartz2D使用(图片剪切) 一.使用Quartz2D完成图片剪切 1.把图片显示在自定义的view中 先把图片绘制到view上.按照原始大小,把图片绘制到一个点上. 代码: 1 - (void)drawRect:(CGRect)rect 2 { 3 UIImage *image2=[UIImage imageNamed:@"me"]; 4 [image2 drawAtPoint:CGPointMake(100, 100)]; 5 } 显示: 2.剪切图片让图片圆形展示 思路:先画

iOS给一张矩形图片剪切成圆形图片

随着APP发展,个人账户的注册和登陆,都有头像的设置,圆形头像也越来越多,此方法正是对剪切圆头像的封装. //****************************************************************************************************************// //******************************************************************************