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


Posted in PHP onOctober 31, 2018

最近做到相关的项目,由于项目使用html2canvas,但是不支持css mask属性,故,利用php后台来裁剪。

准备两张图片,一张是镂空PNG图案,一张是任意纯色图片。

便能够在纯色图片上裁剪出镂空的图案为PNG文件。

见下图。

首先两张PNG图片:

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

生成图片

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

 JS片段:

html2canvas($(".head1pic"), {
     onrendered: function(canvas) { 
     url = canvas.toDataURL("image/png", 1.0);
       sourcePic = "assets/images/demo.png";
       maskPic = "assets/images/jinmao.png";
          cropPicName = "cropDog1";
          // ajax php截图
          $.ajax({
          type: 'post',
           url: 'getpicture',
          data: {
            "sourcePic": sourcePic,
            "maskPic": maskPic,
            "cropPicName": cropPicName
            },
         success: function(data) {
             $(".page2Bg")[0].setAttribute("src", "assets/images/crop/cropDog1.png"); 
            },
         error: function(data) {
              console.log(data)
              }
            });
       }
 });

PHP的片段:

public function actionGetpicture()
  {  
     $request = Yii::$app->request;
    $sourcePic=$request->post('sourcePic');
    $maskPic=$request->post('maskPic'); 
    $cropPicName=$request->post('cropPicName'); 
 
    // $sourcePic="http://bings.local.com/bi_ngs2_2/assets/images/yinpian1/page2Bg4.png";
    // $maskPic="http://bings.local.com/bi_ngs2_2/assets/images/jinmao.png";
    $source = imagecreatefrompng( $sourcePic );
    $mask = imagecreatefrompng( $maskPic); 
    // Apply mask to source
    // imagealphamask( $source, $mask );
    $this->imagealphamask ($source, $mask );
    // Output
    header( "Content-type: image/png"); 
    // 生成截取后的图片并保存在本地
    imagepng( $source,"assets/images/crop/".$cropPicName.".png" );
    //销毁图片内存
    imagedestroy($source);
      
  }
 
  public function imagealphamask( &$picture, $mask ) {
    // Get sizes and set up new picture
    $xSize = imagesx( $picture );
    $ySize = imagesy( $picture );
    $newPicture = imagecreatetruecolor( $xSize, $ySize );
    imagesavealpha( $newPicture, true );
    imagefill( $newPicture, 0, 0, imagecolorallocatealpha( $newPicture, 100, 100, 0, 127 ) );
 
    // Resize mask if necessary
    // if( $xSize != imagesx( $mask ) || $ySize != imagesy( $mask ) ) {
    //   $tempPic = imagecreatetruecolor( $xSize, $ySize );
    //   imagecopyresampled( $tempPic, $mask, 0, 0, 0, 0, $xSize, $ySize, imagesx( $mask ), imagesy( $mask ) );
    //   imagedestroy( $mask );
    //   $mask = $tempPic;
    // }
 
    // Perform pixel-based alpha map application
    for( $x = 0; $x < $xSize; $x++ ) {
      for( $y = 0; $y < $ySize; $y++ ) {
        $alpha = imagecolorsforindex( $mask, imagecolorat( $mask, $x, $y ) );
        //small mod to extract alpha, if using a black(transparent) and white
        //mask file instead change the following line back to Jules's original:
        // $alpha = 127 - floor($alpha['black'] / 2);
        //or a white(transparent) and black mask file:
        // $alpha = floor($alpha['black'] / 2);
        $alpha = $alpha['alpha'];
        $color = imagecolorsforindex( $picture, imagecolorat( $picture, $x, $y ) );
        //preserve alpha by comparing the two values
        if ($color['alpha'] > $alpha)
          $alpha = $color['alpha'];
        //kill data for fully transparent pixels
        if ($alpha == 127) {
          $color['red'] = 0;
          $color['blue'] = 0;
          $color['green'] = 0;
        }
        imagesetpixel( $newPicture, $x, $y, imagecolorallocatealpha( $newPicture, $color[ 'red' ], $color[ 'green' ], $color[ 'blue' ], $alpha ) );
      }
    }
 
    // Copy back to original picture
    imagedestroy( $picture );
    $picture = $newPicture;
  }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
php empty() 检查一个变量是否为空
Nov 10 PHP
php变量范围介绍
Oct 15 PHP
解析PHP中ob_start()函数的用法
Jun 24 PHP
PHP goto语句简介和使用实例
Mar 11 PHP
PHP中array_slice函数用法实例详解
Nov 25 PHP
ecshop实现smtp发送邮件
Feb 03 PHP
PHP判断是否为空的几个函数对比
Apr 21 PHP
如何解决PHP使用mysql_query查询超大结果集超内存问题
Mar 14 PHP
php仿微信红包分配算法的实现方法
May 13 PHP
php实现的顺序线性表示例
May 04 PHP
PHP实现限制域名访问的实现代码(本地验证)
Sep 13 PHP
PHP 技巧 * SVG 保存为图片(分享图生成)
Apr 02 PHP
workerman结合laravel开发在线聊天应用的示例代码
Oct 30 #PHP
golang实现php里的serialize()和unserialize()序列和反序列方法详解
Oct 30 #PHP
swoole_process实现进程池的方法示例
Oct 29 #PHP
PHP大文件分片上传的实现方法
Oct 28 #PHP
PHP array_reduce()函数的应用解析
Oct 28 #PHP
php 中phar包的使用教程详解
Oct 26 #PHP
Linux基于php-fpm模式的lamp搭建phpmyadmin的方法
Oct 25 #PHP
You might like
用PHP来写记数器(详细介绍)
2006/10/09 PHP
php常用字符串处理函数实例分析
2014/11/22 PHP
php绘制一条直线的方法
2015/01/24 PHP
php对数组内元素进行随机调换的方法
2015/05/12 PHP
PHP进行批量任务处理不超时的解决方法
2016/07/11 PHP
jquery选择器之层级过滤选择器详解
2014/01/27 Javascript
jQuery中的val()示例应用
2014/02/26 Javascript
angularjs的一些优化小技巧
2014/12/06 Javascript
JQuery中基础过滤选择器用法实例分析
2015/05/18 Javascript
JQuery EasyUI的使用
2016/02/24 Javascript
深入理解JavaScript程序中内存泄漏
2016/03/17 Javascript
jQuery实现移动端手机商城购物车功能
2016/09/24 Javascript
JS常见疑难点分析之match,charAt,charCodeAt,map,search用法分析
2016/12/25 Javascript
jQuery的$.extend 浅拷贝与深拷贝
2017/03/08 Javascript
js图片放大镜效果实现方法详解
2020/10/28 Javascript
详解关于react-redux中的connect用法介绍及原理解析
2017/09/11 Javascript
利用百度地图API获取当前位置信息的实例
2017/11/06 Javascript
nodejs实现截取上传视频中一帧作为预览图片
2017/12/10 NodeJs
用node-webkit把web应用打包成桌面应用(windows环境)
2018/02/01 Javascript
详解在React.js中使用PureComponent的重要性和使用方式
2018/07/10 Javascript
基于layui数据表格以及传数据的方式
2018/08/19 Javascript
Layui 数据表格批量删除和多条件搜索的实例
2019/09/04 Javascript
Python常用的日期时间处理方法示例
2015/02/08 Python
在Gnumeric下使用Python脚本操作表格的教程
2015/04/14 Python
从源码解析Python的Flask框架中request对象的用法
2016/06/02 Python
python实现八大排序算法(2)
2017/09/14 Python
Python字符串格式化%s%d%f详解
2018/02/02 Python
HTML5的postMessage的使用手册
2018/12/19 HTML / CSS
驴妈妈旅游网:中国新型的B2C旅游电子商务网站
2016/08/16 全球购物
司机岗位职责
2013/11/15 职场文书
普通院校学生的自荐信
2013/11/27 职场文书
高三体育教学反思
2014/01/29 职场文书
计算机售后服务承诺书
2014/05/30 职场文书
传承焦裕禄精神思想汇报2014
2014/09/10 职场文书
北京英语导游词
2015/02/12 职场文书
使用JS前端技术实现静态图片局部流动效果
2022/08/05 Javascript