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 相关文章推荐
操作Oracle的php类
Oct 09 PHP
php 正则表达式小结
Aug 31 PHP
php is_file()和is_dir()用于遍历目录时用法注意事项
Mar 02 PHP
PHP学习之字符串比较和查找
Apr 17 PHP
测试PHP连接MYSQL成功与否的代码
Aug 16 PHP
PHP文件大小格式化函数合集
Mar 10 PHP
PHP中echo,print_r与var_dump区别分析
Sep 29 PHP
php对文件进行hash运算的方法
Apr 03 PHP
php三元运算符知识汇总
Jul 02 PHP
php 三大特点:封装,继承,多态
Feb 19 PHP
利用PHPStorm如何开发Laravel应用详解
Aug 30 PHP
PHP用swoole+websocket和redis实现web一对一聊天
Nov 05 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判断变量的函数
2012/04/24 PHP
php类中的各种拦截器用法分析
2014/11/03 PHP
Zend Framework实现具有基本功能的留言本(附demo源码下载)
2016/03/22 PHP
PHP获取网站中各文章的第一张图片的代码示例
2016/05/20 PHP
PHP自定义函数获取汉字首字母的方法
2016/12/01 PHP
利用php-cli和任务计划实现订单同步功能的方法
2017/05/03 PHP
PHP CURL与java http使用方法详解
2018/01/26 PHP
php判断某个方法是否存在函数function_exists (),method_exists()与is_callable()区别与用法解析
2020/04/20 PHP
深入解析PHP底层机制及相关原理
2020/12/11 PHP
谈谈关于JavaScript 中的 MVC 模式
2013/04/11 Javascript
textarea焦点的用法实现获取焦点清空失去焦点提示效果
2014/05/19 Javascript
JS实现进入页面时渐变背景色的方法
2015/02/25 Javascript
jQuery定义背景动态切换效果的方法
2015/03/23 Javascript
JavaScript数组和循环详解
2015/04/27 Javascript
第三章之Bootstrap 表格与按钮功能
2016/04/25 Javascript
详解XMLHttpRequest(二)响应属性、二进制数据、监测上传下载进度
2016/09/14 Javascript
JavaScript 函数的定义-调用、注意事项
2017/04/16 Javascript
浅谈Node.js轻量级Web框架Express4.x使用指南
2017/05/03 Javascript
vue2.0获取鼠标位置的方法
2018/09/13 Javascript
Windows上node.js的多版本管理工具用法实例分析
2019/11/06 Javascript
微信小程序实现多张图片上传功能
2020/11/18 Javascript
vscode自定义vue模板的实现
2021/01/27 Vue.js
Python通过正则表达式选取callback的方法
2015/07/18 Python
django反向解析URL和URL命名空间的方法
2018/06/05 Python
Python实现按逗号分隔列表的方法
2018/10/23 Python
对Xpath 获取子标签下所有文本的方法详解
2019/01/02 Python
对PyQt5基本窗口控件 QMainWindow的使用详解
2019/06/19 Python
PyCharm Anaconda配置PyQt5开发环境及创建项目的教程详解
2020/03/24 Python
Python预测2020高考分数和录取情况
2020/07/08 Python
全球在线商店:BerryLook
2019/04/14 全球购物
会计专业自荐信范文
2013/12/02 职场文书
城建学院毕业生自荐信
2014/01/31 职场文书
20年同学聚会感言
2014/02/03 职场文书
组工干部对照检查材料
2014/08/25 职场文书
2014年大学生党员自我评议
2014/09/22 职场文书
2014年仓管员工作总结
2014/11/18 职场文书