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概述.
Oct 09 PHP
php session 错误
May 21 PHP
PHP number_format() 函数定义和用法
Jun 01 PHP
destoon后台网站设置变成空白的解决方法
Jun 21 PHP
CI框架入门示例之数据库取数据完整实现方法
Nov 05 PHP
基于PHP代码实现中奖概率算法可用于刮刮卡、大转盘等抽奖算法
Dec 20 PHP
thinkphp3.2.3 分页代码分享
Jul 28 PHP
使用php完成常见的文件上传功能(推荐)
Jan 13 PHP
PHP合并数组函数array_merge用法分析
Feb 17 PHP
thinkphp5.1 文件引入路径问题及注意事项
Jun 13 PHP
PHP如何防止用户重复提交表单
Dec 09 PHP
PHP实现chrome表单请求数据转换为接口使用的json数据
Mar 04 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
实现“上一页”和“下一页按钮
2006/10/09 PHP
服务器端解压缩zip的脚本
2006/12/22 PHP
PHP图片处理类 phpThumb参数用法介绍
2012/03/11 PHP
php导入导出excel实例
2013/10/25 PHP
php可生成缩略图的文件上传类实例
2014/12/17 PHP
php用ini_get获取php.ini里变量值的方法
2015/03/04 PHP
php 的反射详解及示例代码
2016/08/25 PHP
PHP自定义函数格式化json数据示例
2016/09/14 PHP
php读取和保存base64编码的图片内容
2017/04/22 PHP
PHP基于phpqrcode类生成二维码的方法详解
2018/03/14 PHP
23个超流行的jQuery相册插件整理分享
2011/04/25 Javascript
基于BootStrap Metronic开发框架经验小结【一】框架总览及菜单模块的处理
2016/05/12 Javascript
javascript运算符——逻辑运算符全面解析
2016/06/27 Javascript
Bootstrap模态框水平垂直居中与增加拖拽功能
2016/11/09 Javascript
详解Vue快速零配置的打包工具——parcel
2018/01/16 Javascript
Vuex mutitons和actions初使用详解
2019/03/04 Javascript
JavaScript实现多张图片放大镜效果示例【不限定图片尺寸,rem单位】
2019/05/14 Javascript
Vue 实现CLI 3.0 + momentjs + lodash打包时优化
2019/11/13 Javascript
vue实现评价星星功能
2020/06/30 Javascript
如何手动实现一个 JavaScript 模块执行器
2020/10/16 Javascript
JavaScript实现原型封装轮播图
2020/12/27 Javascript
Python 可爱的大小写
2008/09/06 Python
pymssql ntext字段调用问题解决方法
2008/12/17 Python
Python with用法实例
2015/04/14 Python
python requests更换代理适用于IP频率限制的方法
2019/08/21 Python
PYQT5开启多个线程和窗口,多线程与多窗口的交互实例
2019/12/13 Python
Myprotein俄罗斯官网:欧洲第一运动营养品牌
2019/05/05 全球购物
早餐连锁店计划书
2014/01/08 职场文书
致长跑运动员广播稿
2014/01/31 职场文书
班长竞选演讲稿
2014/04/24 职场文书
行政专员岗位职责说明书
2014/07/30 职场文书
见习报告格式范文
2014/11/08 职场文书
优秀校长事迹材料
2014/12/24 职场文书
2015年感恩节活动总结
2015/03/24 职场文书
动画「半妖的夜叉姬」新BD特典图公开
2022/03/22 日漫
vue打包时去掉所有的console.log
2022/04/10 Vue.js