好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > php+js實現裁剪任意形狀圖片

php+js實現裁剪任意形狀圖片

熱門標簽:神龍斗士電話機器人 合肥企業外呼系統線路 電信外呼系統多少錢一個月 桂陽公司如何做地圖標注 宿州正規外呼系統軟件 企業400電話辦理多少費用 太原400電話申請流程 代理打電話機器人 萍鄉商鋪地圖標注

最近做到相關的項目,由于項目使用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圖像裁剪縮略裁切類源碼及使用方法

標簽:鄂州 衡陽 綏化 白銀 太原 廊坊 辛集 崇左

巨人網絡通訊聲明:本文標題《php+js實現裁剪任意形狀圖片》,本文關鍵詞  php+js,實現,裁剪,任意,形狀,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《php+js實現裁剪任意形狀圖片》相關的同類信息!
  • 本頁收集關于php+js實現裁剪任意形狀圖片的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 午夜精品一区二区三区在线成人| 欧美大肚乱孕交hd| 极品美女做受XXX片| AV狠狠色综合欧美天天图片| 教室眠催白丝美女校花| 黄色一级片免费| 喜爱夜蒲3吃奶床戏| 亚洲精品久久水蜜桃| 97久久久碰碰碰久久碰碰碰| 电影天堂影院免费观看| 老妇性老太色hd老妇俱乐部| 国精产品999国精产| 女人被狂躁免费看30分钟| 韩国肉乳床欢无码A片小说| 快点啊哦用力太深了| 夜夜天天操| 色噜噜的亚洲男人的天堂| 国产原创一区| 无码人妻波多野结衣| 麻豆国产AV超爽剧情系列| 美女亚洲视频| 女子初尝黑人第一次| 操她视频| 亚洲韩国无码毛淑日本| 综合久久久久6亚洲综合| 久久午夜精品| jizz在线观看国产精品| 日韩免费一区二区三区| 性欧美大战久久久久久久| 我15被好几个同学做了| 久久99国产精品成人| 狂揉美女胸线免费网站下站| 狼色精品人妻在线视频网站| KTV把奶罩解开让客人摸| 肉肉肉+定期按摩(h)| 秘?无码一区二区三潘金莲| 粗大黑长进进出出| 色哦色哦哦色天天综合| 美女的隐私免费露出来| 人獸交XXOO变态另类| 快C我啊?用力?嗯?轻一点图片|