页面载入中...

当前位置:首页 > 技术资料 > php相关 > php相关

php+js实现裁剪任意形状图片

温馨提示:本信息由会员搜集整理发布,您如有异议可以 举报 或者 版权申诉
最近做到相关的项目,由于项目使用html2canvas,但是不支持css mask属性,故,利用php后台来裁剪。准备两张图片,一张是镂空PNG图案,一张是任意纯色图片。便能够在纯色图片上裁剪出镂空的图案为PNG文件。见下图。首

本文实例为大家分享了php图片裁剪函数的具体代码,供大家参考,具体内容如下

/* * 图片裁剪工具 * 将指定文件裁剪成正方形 * 以中心为起始向四周裁剪 * @param $src_path string 源文件地址 * @param $des_path string 保存文件地址 * @param $des_w double 目标图片宽度 * */function img_cut_square($src_path,$des_path,$des_w=100){  $img_info = getimagesize($src_path);//获取原图像尺寸信息  $img_width = $img_info[0];//原图宽度  $img_height = $img_info[1];//原图高度  $img_type = $img_info[2];//图片类型 1 为 GIF 格式、 2 为 JPEG/JPG 格式、3 为 PNG 格式  if($img_type != 2 && $img_type != 3) return ;  /*计算缩放尺寸*/  if($img_height > $img_width){    $scale_width = $des_w;//缩放宽度    $scale_height = round($des_w / $img_width * $img_height);//缩放高度    $src_y = round(($scale_height - $des_w)/2);    $src_x = 0;  }else{    $scale_height = $des_w;    $scale_width = round($des_w / $img_height * $img_width);    $src_y = 0;    $src_x = round(($scale_width - $des_w)/2);  }  $dst_ims = imagecreatetruecolor($scale_width, $scale_height);//创建真彩画布  $white = imagecolorallocate($dst_ims, 255, 255, 255);  imagefill($dst_ims, 0, 0, $white);  if($img_type == 2){    $src_im = @imagecreatefromjpeg($src_path);//读取原图像  }else if($img_type == 3){    $src_im = @imagecreatefrompng($src_path);//读取原图像  }  imagecopyresized($dst_ims, $src_im, 0, 0 ,0, 0 , $scale_width , $scale_height , $img_width,$img_height);//缩放图片到指定尺寸  $dst_im = imagecreatetruecolor($des_w, $des_w);//  $white = imagecolorallocate($dst_im, 255, 255, 255);//  imagefill($dst_im, 0, 0, $white);  imagecopy($dst_im, $dst_ims, 0, 0, $src_x, $src_y, $des_w, $des_w);//开始裁剪图片为正方形// imagecopyresampled($dst_im, $src_im, $src_x, $src_y, 0, 0, $real_width, $real_width,$img_width,$img_height);  if($img_type == 2) {    imagejpeg($dst_im, $des_path);//保存到文件  }else if($img_type == 3){    imagepng($dst_im,$des_path);  }//  imagejpeg($dst_im);//输出到浏览器  imagedestroy($dst_im);  imagedestroy($dst_ims);  imagedestroy($src_im);}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持金聪精品

  

延伸阅读:

    无相关信息
  
 

php+js实现裁剪任意形状图片