• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    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;
      } 
    

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

    您可能感兴趣的文章:
    • PHP图片裁剪函数(保持图像不变形)
    • php+js实现图片的上传、裁剪、预览、提交示例
    • php使用imagick模块实现图片缩放、裁剪、压缩示例
    • 使用gd库实现php服务端图片裁剪和生成缩略图功能分享
    • php图片的裁剪与缩放生成符合需求的缩略图
    • PHP图片处理之使用imagecopyresampled函数裁剪图片例子
    • PHP 裁剪图片成固定大小代码方法
    • PHP加Nginx实现动态裁剪图片方案
    • thinkPHP框架实现图像裁剪、缩放、加水印的方法
    • PHP图像裁剪缩略裁切类源码及使用方法
    上一篇:workerman结合laravel开发在线聊天应用的示例代码
    下一篇:php图片裁剪函数
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

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