广告位联系
返回顶部
分享到

PHP+js实现裁剪任意形状图片的教程

php 来源:互联网搜集 作者:秩名 发布时间:2018-11-04 16:04:34 人浏览
摘要

今天小编给大家介绍PHP+js实现裁剪任意形状图片的教程。 一些项目使用html2canvas,但是不支持css mask属性,故利用php后台来裁剪。 准备两张图片,一张是镂空PNG图案,一张是任意纯色图片。 便能够在纯色图片上裁剪出镂空的图案为PNG文件。 见下图。 首先两

今天小编给大家介绍PHP+js实现裁剪任意形状图片的教程。

一些项目使用html2canvas,但是不支持css mask属性,故利用php后台来裁剪。准备两张图片,一张是镂空PNG图案,一张是任意纯色图片。便能够在纯色图片上裁剪出镂空的图案为PNG文件。

见下图。


首先两张PNG图片:


 
生成图片:
 

 
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;
 } 


版权声明 : 本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务和不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权, 违法违规的内容, 请发送邮件至2530232025#qq.cn(#换@)举报,一经查实,本站将立刻删除。
原文链接 :
相关文章
  • PHP获取系统毫秒数时间方法
    前言 php中获取时间方法是date(),在php中获取时间戳方法有time()、strtotime(); date():date(format, timestamp),format为格式、timestamp为时间戳(可选
  • PHP中的DI依赖注入的详细介绍
    什么是 DI / 依赖注入 依赖注入DI 其实本质上是指对类的依赖通过构造器完成 自动注入 通俗来说,就是你当前操作一个类,但是这个类的某
  • PHP8.1 Fiber交叉执行多任务(附代码)
    拿平时大家写的 for 循环举例。像 go 你可以写两个go每个里面各写一个循环同时输入,你可以看到输出是交替。在过去的php版本中,如果只开
  • PHP8.0的编译安装与使用的介绍
    安装与配置 本次使用的操作系统Ubuntu 18.04.4 LTS 安装 1.准备必要库 1 2 apt-get install -y autoconf libxml2-dev libsqlite3-dev \ libcurl4-openssl-dev libssl-dev l
  • Mac如何编译PHP 8.0 到MxSrvs工具

    Mac如何编译PHP 8.0 到MxSrvs工具
    开始准备工作 下载 PHP 8.0 PHP 官方下载 https://www.php.net/downloads.php 进入到 MxSrvs 的主程序路径下的/Applications/MxSrvs/bin,根据 Mxsrvs 的命名规则,
  • PHP8 中的 JIT的详细介绍

    PHP8 中的 JIT的详细介绍
    PHP 8 的 JIT(Just In Time)编译器将作为扩展集成到 php 中 Opcache 扩展 用于运行时将某些操作码直接转换为从 cpu 指令。 这意味着使用JIT后,
  • PHP8.2不再支持字符串中用${}插入变量了

    PHP8.2不再支持字符串中用${}插入变量了
    PHP 社区 4 月底通过了一项只有一张反对票的提案,提案内容是在即将发布的 PHP 8.2 中,不再支持使用 ${} 在字符串中插入变量的语法(标记
  • PHP8.2两个新的强类型:null和false的详细介绍

    PHP8.2两个新的强类型:null和false的详细介绍
    PHP 从 7.0 开始不断地在完善强类型,我们可以给方法参数、返回值、类属性等声明类型。 强类型可以让代码更加健壮,易于维护,可读性增
  • PHP从txt文件中读取数据的介绍

    PHP从txt文件中读取数据的介绍
    一、打开/关闭文件 1、对文件操作时首先要打开文件,打开文件用 fopen()函数,语法是: fopen(filename,mode,include_path,context); 2、对文件操作
  • PHP中token的生成
    php token的生成 接口特点汇总: 1、因为是非开放性的,所以所有的接口都是封闭的,只对公司内部的产品有效; 2、因为是非开放性的,所以
  • 本站所有内容来源于互联网或用户自行发布,本站仅提供信息存储空间服务,不拥有版权,不承担法律责任。如有侵犯您的权益,请您联系站长处理!
  • Copyright © 2017-2022 F11.CN All Rights Reserved. F11站长开发者网 版权所有 | 苏ICP备2022031554号-1 | 51LA统计