温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

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

发布时间:2021-04-20 10:22:18 阅读:249 作者:小新 栏目:开发技术
PHP开发者专用服务器限时活动,0元免费领,库存有限,领完即止! 点击查看>>

这篇文章主要介绍了php+js如何实现裁剪任意形状图片,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

js的作用是什么

1、能够嵌入动态文本于HTML页面。2、对浏览器事件做出响应。3、读写HTML元素。4、在数据被提交到服务器之前验证数据。5、检测访客的浏览器信息。6、控制cookies,包括创建和修改等。7、基于Node.js技术进行服务器端编程。

最近做到相关的项目,由于项目使用html2canvas,但是不支持css mask属性,故,利用php后台来裁剪。

准备两张图片,一张是镂空PNG图案,一张是任意纯色图片。

便能够在纯色图片上裁剪出镂空的图案为PNG文件。

见下图。

首先两张PNG图片:

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

生成图片

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

 JS片段:

html2canvas($(".head1pic"), {
     onrenderedfunction(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
            },
         successfunction(data) {
             $(".page2Bg")[0].setAttribute("src""assets/images/crop/cropDog1.png"); 
            },
         errorfunction(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$newPicturetrue );
    imagefill$newPicture00imagecolorallocatealpha$newPicture1001000127 ) );
 
    // 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$maskimagecolorat$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$pictureimagecolorat$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$yimagecolorallocatealpha$newPicture$color'red' ], $color'green' ], $color'blue' ], $alpha ) );
      }
    }
 
    // Copy back to original picture
    imagedestroy$picture );
    $picture $newPicture;
  }

感谢你能够认真阅读完这篇文章,希望小编分享的“php+js如何实现裁剪任意形状图片”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!

亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI

开发者交流群×