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 相关文章推荐
在WIN98下以apache模块方式安装php
Oct 09 PHP
php设计模式 Command(命令模式)
Jun 26 PHP
PHP警告Cannot use a scalar value as an array的解决方法
Jan 11 PHP
深入Nginx + PHP 缓存详解
Jul 11 PHP
PHP连接MySQL查询结果中文显示乱码解决方法
Oct 25 PHP
ThinkPHP调用百度翻译类实现在线翻译
Jun 26 PHP
PHP封装的Twitter访问类实例
Jul 18 PHP
php similar_text()函数的定义和用法
May 12 PHP
比较完整的微信开发php代码
Aug 02 PHP
PHP快速推送微信模板消息
Apr 14 PHP
PHP时间日期增减操作示例【date strtotime实现加一天、加一月等操作】
Dec 21 PHP
PHP保留两位小数的几种方法
Jul 24 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 date函数常用时间处理方法
2015/05/11 PHP
PHP实现图片的等比缩放和Logo水印功能示例
2017/05/04 PHP
PHP 进程池与轮询调度算法实现多任务的示例代码
2019/11/26 PHP
PHP如何开启Opcache功能提升程序处理效率
2020/04/27 PHP
JavaScript实现关键字高亮功能
2014/11/12 Javascript
JavaScript 学习笔记之操作符(续)
2015/01/14 Javascript
小议JavaScript中Generator和Iterator的使用
2015/07/29 Javascript
jquery实现表单验证简单实例演示
2015/11/23 Javascript
超赞的jQuery图片滑块动画特效代码汇总
2016/01/25 Javascript
详解jquery事件delegate()的使用方法
2016/01/25 Javascript
javascript获取网页各种高宽及位置的方法总结
2016/07/27 Javascript
JavaScript实现邮箱后缀提示功能的示例代码
2018/12/13 Javascript
vue项目中全局引入1个.scss文件的问题解决
2019/08/01 Javascript
小程序实现层叠卡片滑动效果
2019/08/26 Javascript
JS实现星星海特效
2019/12/24 Javascript
[46:44]DOTA2-DPC中国联赛 正赛 Ehome vs PSG.LGD BO3 第二场 3月7日
2021/03/11 DOTA
Python遍历文件夹 处理json文件的方法
2019/01/22 Python
Django 内置权限扩展案例详解
2019/03/04 Python
python仿evething的文件搜索器实例代码
2019/05/13 Python
Python中@property的理解和使用示例
2019/06/11 Python
django的聚合函数和aggregate、annotate方法使用详解
2019/07/23 Python
tensorflow之变量初始化(tf.Variable)使用详解
2020/02/06 Python
Python描述数据结构学习之哈夫曼树篇
2020/09/07 Python
5分钟让你掌握css3阴影、倒影、渐变小技巧(小编推荐)
2016/08/15 HTML / CSS
网易微博Web App用HTML5开发的过程介绍
2012/06/13 HTML / CSS
Html5页面获取微信公众号的openid的方法
2020/05/12 HTML / CSS
Alba Moda瑞士网上商店:独家意大利时尚女装销售
2016/11/28 全球购物
爱奇艺VIP会员:大剧抢先看
2018/07/11 全球购物
如何找出EMP表里面SALARY第N高的employee
2013/12/05 面试题
行政部工作岗位职责范本
2014/03/05 职场文书
房屋租赁合同解除协议书
2014/10/11 职场文书
本科毕业论文导师评语
2014/12/31 职场文书
2015年党务工作者个人工作总结
2015/10/22 职场文书
高考升学宴主持词
2019/06/21 职场文书
javascript实现计算器功能详解流程
2021/11/01 Javascript
Python 数据可视化之Seaborn详解
2021/11/02 Python