Table of Contents
回复讨论(解决方案)
Home Backend Development PHP Tutorial 为什么上传图片中含有透明通道,图片就会变成黑色?

为什么上传图片中含有透明通道,图片就会变成黑色?

Jun 23, 2016 pm 01:58 PM
upload picture transparent

p.s. 改的图片上传类原文地址:http://blog.csdn.net/a957651480/article/details/23124257

1

<?phpclass Images{   var $inputName;                 //控件名   var $allowType = array(             'image/gif','image/jpg','image/jpeg','image/png','image/x-png','image/pjpeg'    );                             //上传类型   var $allowSize = 1048576;   //限制大小  var $saveDir = "";      //保存目录  var $FileName = ""; //文件名   var $isRename = false;               //是否重命名,默认为true    var $errID = 0;                     //错误代码,默认为0 var $errMsg = "";                   //错误信息  var $savePath = "";                 //保存路径  var $ImgSize = 0; //图片尺寸    function __construct($inputName,$allowType="",$allowSize="",$saveDir="",$isRename=true){        if(empty($inputName)){          $this->chk_err(-1);       //无传入控件名       }else{          $this->inputName = $inputName;       }       if(!empty($allowType)) $this->allowType = $allowType;        if(!empty($allowSize)) $this->allowSize = $allowSize;        if(!empty($saveDir)) $this->saveDir = $saveDir;      if(!empty($isRename)) $this->isRename = $isRename;   }   function is_uploaded(){     if(empty($_FILES[$this->inputName]['name'])){            $this->chk_err(4);    //没有文件被上传      }else{          if(is_uploaded_file($_FILES[$this->inputName]['tmp_name'])){             return true;            }else{              $this->chk_err(-2);       //文件上传不合法          }       }   }   function chk_type(){        if(!in_array($_FILES[$this->inputName]['type'],$this->allowType)){            $this->chk_err(-3);         //上传的文件类型不被允许        }else{          return true;        }   }   function chk_size(){        if($_FILES[$this->inputName]['size'] > $this->allowSize){          $this->chk_err(-4);          //上传的文件过大       }else{          return true;        }   }   function move_uploaded(){        //移动上传文件       if(!$this->is_uploaded()){           return false;       }       if(!$this->chk_size()){          return false;       }       if(!$this->chk_type()){          return false;       }       //重命名       if($this->isRename){         $arrTmp = pathinfo($_FILES[$this->inputName]['name']);           $extension = strtolower($arrTmp['extension']);          $file_newname = $this->FileName; //重命名新文件        }else{          $file_newname = $_FILES[$this->inputName]['name'];       }               if(!file_exists($this->saveDir)){       //判断保存目录是否存在         mkdir($this->saveDir,0777,true);    //建立保存目录     }       //移动文件      $result = move_uploaded_file($_FILES[$this->inputName]['tmp_name'],$this->saveDir."/".$file_newname);     if($result){            $path = $this->savePath = $this->saveDir."/".$file_newname;       //文件的成功保存路径         return $path;       }else{          $this->chk_err($_FILES[$this->inputName]['error']);       }       }   //判断出错信息    function chk_err($errID){       $this->errID = $errID;       switch($this->errID){            case -4:                $this->errMsg = '只能上传1M以内的图片 | <a href="javascript:window.history.back(-1);">[返回]</a>';              break;          case -3:                $this->errMsg = '这不是一张图片 | <a href="javascript:window.history.back(-1);">[返回]</a>';              break;          case -2:                $this->errMsg = '文件上传不合法 | <a href="javascript:window.history.back(-1);">[返回]</a>';              break;          case -1:                $this->errMsg = '无控件名传入 | <a href="javascript:window.history.back(-1);">[返回]</a>';               break;          case 1:             $this->errMsg = '上传的文件超出了php.ini中upload_max_filesize设定的最大值 | <a href="javascript:window.history.back(-1);">[返回]</a>';                break;          case 2:             $this->errMsg = '上传文件的大小超过了HTML表单中MAX_FILE_SIZE选项指定的值 | <a href="javascript:window.history.back(-1);">[返回]</a>';             break;          case 3:             $this->errMsg = '文件只有部分被上传 | <a href="javascript:window.history.back(-1);">[返回]</a>';                break;          case 4:             $this->errMsg = '请选择一张图片 | <a href="javascript:window.history.back(-1);">[返回]</a>';              break;          default:                break;      }       return false;       }   function get_errMsg(){      echo $this->errMsg;  //输出错误信息    }    /**     +----------------------------------------------------------     * 取得图像信息     *     +----------------------------------------------------------     * @static     * @access public     +----------------------------------------------------------     * @param string $image 图像文件名     +----------------------------------------------------------     * @return mixed     +----------------------------------------------------------     */    function getImageInfo($img) {        $imageInfo = getimagesize($img);        if( $imageInfo!== false) {            $imageType = strtolower(substr(image_type_to_extension($imageInfo[2]),1));            $imageSize = filesize($img);            $info = array(                "width"        =>$imageInfo[0],                "height" =>$imageInfo[1],                "type"       =>$imageType,                "size"      =>$imageSize,                "mime"      =>$imageInfo['mime'],            );            return $info;        }else {            return false;        }    }   /**     +----------------------------------------------------------     * 生成缩略图     +----------------------------------------------------------     * @static     * @access public     +----------------------------------------------------------     * @param string $image  原图     * @param string $type 图像格式     * @param string $thumbname 缩略图文件名     * @param string $maxWidth  宽度     * @param string $maxHeight  高度     * @param string $position 缩略图保存目录     * @param boolean $interlace 启用隔行扫描     * @param boolean $is_save 是否保留原图     +----------------------------------------------------------     * @return void     +----------------------------------------------------------     */      function thumb($image,$is_save=true,$suofang=0,$type='',$maxWidth=500,$maxHeight=500,$interlace=true){        // 获取原图信息       $info  = $this->getImageInfo($image);         if($info !== false) {            $srcWidth  = $info['width'];            $srcHeight = $info['height'];            $type = empty($type)?$info['type']:$type;         $type = strtolower($type);            $interlace  =  $interlace? 1:0;            unset($info);            if ($suofang==1) {                $width  = $srcWidth;                $height = $srcHeight;            } else {                $scale = min($maxWidth/$srcWidth, $maxHeight/$srcHeight); // 计算缩放比例                if($scale>=1) {                    // 超过原图大小不再缩略                    $width   =  $srcWidth;                    $height  =  $srcHeight;                }else{                    // 缩略图尺寸                    $width  = (int)($srcWidth*$scale);    //147                    $height = (int)($srcHeight*$scale);    //199                }            }            // 载入原图            $createFun = 'ImageCreateFrom'.($type=='jpg'?'jpeg':$type);            $srcImg     = $createFun($image);            //创建缩略图            if($type!='gif' && function_exists('imagecreatetruecolor'))                $thumbImg = imagecreatetruecolor($width, $height);            else                $thumbImg = imagecreate($width, $height);            // 复制图片            if(function_exists("ImageCopyResampled"))                imagecopyresampled($thumbImg, $srcImg, 0, 0, 0, 0, $width, $height, $srcWidth,$srcHeight);            else                imagecopyresized($thumbImg, $srcImg, 0, 0, 0, 0, $width, $height,  $srcWidth,$srcHeight);            if('gif'==$type || 'png'==$type) {                //imagealphablending($thumbImg, false);//取消默认的混色模式                //imagesavealpha($thumbImg,true);//设定保存完整的 alpha 通道信息                $background_color  =  imagecolorallocate($thumbImg,  0,255,0);  //  指派一个绿色               imagecolortransparent($thumbImg,$background_color);  //  设置为透明色,若注释掉该行则输出绿色的图            }            // 对jpeg图形设置隔行扫描            if('jpg'==$type || 'jpeg'==$type)     imageinterlace($thumbImg,$interlace);            //$gray=ImageColorAllocate($thumbImg,255,0,0);            //ImageString($thumbImg,2,5,5,"ThinkPHP",$gray);                     // 生成图片            $imageFun = 'imagejpeg';             $length = strlen("00.".$type) * (-1);           $_type = substr($image,-4);         $length = ($type != $_type ? $length+1 : $length);            //裁剪            if ($suofang == 1){                               //$thumbname01 = substr_replace($image,"01.".$type,$length);        //大头像               $thumbname02 = substr_replace($image,'.gif',-8);        //小头像               //$imageFun($thumbImg,$thumbname01,100);                $imageFun($thumbImg,$thumbname02,100);                              //$thumbImg01 = imagecreatetruecolor(190,195);                //imagecopyresampled($thumbImg01,$thumbImg,0,0,$_POST['x'],$_POST['y'],190,195,$_POST['w'],$_POST['h']);                              $thumbImg02 = imagecreatetruecolor($this->ImgSize,$this->ImgSize);                imagecopyresampled($thumbImg02,$thumbImg,0,0,$_POST['x'],$_POST['y'],$this->ImgSize,$this->ImgSize,$_POST['w'],$_POST['h']);              //$imageFun($thumbImg01,$thumbname01,100);              $imageFun($thumbImg02,$thumbname02,100);                                                unlink($image);                             //imagedestroy($thumbImg01);                imagedestroy($thumbImg02);              imagedestroy($thumbImg);                imagedestroy($srcImg);              return array(/*'big' => $thumbname01 ,*/ 'small' => $thumbname02);    //返回包含大小头像路径的数组                         }else{              if($is_save == false){                                          //缩略图覆盖原图,缩略图的路径还是原图路径                  $imageFun($thumbImg,$image,100);                }else{                  $thumbname03 = $image;  //缩略图与原图同时存在,                   $imageFun($thumbImg,$thumbname03,100);                  imagedestroy($thumbImg);                    imagedestroy($srcImg);                  return $thumbname03 ;                   //返回缩略图的路径,字符串              }           }         }         return false;    }}

Copy after login


回复讨论(解决方案)

上传不会改变图片,你可以把图片贴在这里
对于 GD2 缩略图都应 imagecreatetruecolor、imagecopyresampled
如果有透明色,还需 imagecolortransparent

贴出图来看一下

贴出图来看一下





就是一张含透明通道的普通图片……


贴出图来看一下





就是一张含透明通道的普通图片……


你是怎么上传调用的,我刚才试了下你的图片,我这传完没问题

imagecreate 和 imagecreatetruecolor 产生的图片都是黑色的(注意:不是透明的)
你的图片是透明的,自然就将背景显现出来了
也就是说图片是放在黑色的背景上的了
所以被缩放的图片还需要设置透明色

1

$url = 'http://img.bbs.csdn.net/upload/201404/15/1397545309_839045.gif';$sm = imagecreatefromstring(file_get_contents($url));$dm = imagecreatetruecolor(imagesx($sm), imagesy($sm));//$dm = imagecreate(imagesx($sm), imagesy($sm));$c = imagecolorallocate($dm, 100, 1, 1);imagefill($dm, 0, 0, $c);imagecolortransparent($dm, $c);imagecopyresampled($dm, $sm, 0, 0, 0, 0, imagesx($dm), imagesy($dm), imagesx($sm), imagesy($sm));imagegif($dm);

Copy after login


我自己解决了。。还是谢谢你们,是我没有用imagefill事先填充的原因

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

Repo: How To Revive Teammates
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How to solve the problem of automatically saving pictures when publishing on Xiaohongshu? Where is the automatically saved image when posting? How to solve the problem of automatically saving pictures when publishing on Xiaohongshu? Where is the automatically saved image when posting? Mar 22, 2024 am 08:06 AM

With the continuous development of social media, Xiaohongshu has become a platform for more and more young people to share their lives and discover beautiful things. Many users are troubled by auto-save issues when posting images. So, how to solve this problem? 1. How to solve the problem of automatically saving pictures when publishing on Xiaohongshu? 1. Clear the cache First, we can try to clear the cache data of Xiaohongshu. The steps are as follows: (1) Open Xiaohongshu and click the &quot;My&quot; button in the lower right corner; (2) On the personal center page, find &quot;Settings&quot; and click it; (3) Scroll down and find the &quot;Clear Cache&quot; option. Click OK. After clearing the cache, re-enter Xiaohongshu and try to post pictures to see if the automatic saving problem is solved. 2. Update the Xiaohongshu version to ensure that your Xiaohongshu

How to post pictures in TikTok comments? Where is the entrance to the pictures in the comment area? How to post pictures in TikTok comments? Where is the entrance to the pictures in the comment area? Mar 21, 2024 pm 09:12 PM

With the popularity of Douyin short videos, user interactions in the comment area have become more colorful. Some users wish to share images in comments to better express their opinions or emotions. So, how to post pictures in TikTok comments? This article will answer this question in detail and provide you with some related tips and precautions. 1. How to post pictures in Douyin comments? 1. Open Douyin: First, you need to open Douyin APP and log in to your account. 2. Find the comment area: When browsing or posting a short video, find the place where you want to comment and click the &quot;Comment&quot; button. 3. Enter your comment content: Enter your comment content in the comment area. 4. Choose to send a picture: In the interface for entering comment content, you will see a &quot;picture&quot; button or a &quot;+&quot; button, click

6 Ways to Make Pictures Sharper on iPhone 6 Ways to Make Pictures Sharper on iPhone Mar 04, 2024 pm 06:25 PM

Apple's recent iPhones capture memories with crisp detail, saturation and brightness. But sometimes, you may encounter some issues that may cause the image to look less clear. While autofocus on iPhone cameras has come a long way, allowing you to take photos quickly, the camera can mistakenly focus on the wrong subject in certain situations, making the photo blurry in unwanted areas. If your photos on your iPhone look out of focus or lack sharpness overall, the following post should help you make them sharper. How to Make Pictures Clearer on iPhone [6 Methods] You can try using the native Photos app to clean up your photos. If you want more features and options

How to make ppt pictures appear one by one How to make ppt pictures appear one by one Mar 25, 2024 pm 04:00 PM

In PowerPoint, it is a common technique to display pictures one by one, which can be achieved by setting animation effects. This guide details the steps to implement this technique, including basic setup, image insertion, adding animation, and adjusting animation order and timing. Additionally, advanced settings and adjustments are provided, such as using triggers, adjusting animation speed and order, and previewing animation effects. By following these steps and tips, users can easily set up pictures to appear one after another in PowerPoint, thereby enhancing the visual impact of the presentation and grabbing the attention of the audience.

How to convert pdf documents into jpg images with Foxit PDF Reader - How to convert pdf documents into jpg images with Foxit PDF Reader How to convert pdf documents into jpg images with Foxit PDF Reader - How to convert pdf documents into jpg images with Foxit PDF Reader Mar 04, 2024 pm 05:49 PM

Are you also using Foxit PDF Reader software? So do you know how Foxit PDF Reader converts pdf documents into jpg images? The following article brings you how Foxit PDF Reader converts pdf documents into jpg images. For those who are interested in the method of converting jpg images, please come and take a look below. First start Foxit PDF Reader, then find "Features" on the top toolbar, and then select the "PDF to Others" function. Next, open a web page called "Foxit PDF Online Conversion". Click the "Login" button on the upper right side of the page to log in, and then turn on the "PDF to Image" function. Then click the upload button and add the pdf file you want to convert into an image. After adding it, click "Start Conversion"

How to solve the black line problem of win11 transparent taskbar How to solve the black line problem of win11 transparent taskbar Dec 22, 2023 pm 10:04 PM

After many friends used translucenttb to set up a transparent taskbar, they found that there was a black line in the win11 transparent taskbar, which looked very uncomfortable. How should I solve it at this time? In fact, it can be solved in the software. There is a black line in the win11 transparent taskbar: Method 1: 1. According to user feedback, you can right-click translucenttb and open settings. 2. Then set the "margin" of the icon option to "1" to solve the problem. Method 2: 1. If it still doesn't work, you can right-click the blank space to open "Personalization" 2. Then select the system default theme to change it. Method three: 1. If all else fails, it is recommended that you uninstall translucenttb. 2. Then replace

How to use JavaScript to implement the drag and zoom function of images? How to use JavaScript to implement the drag and zoom function of images? Oct 27, 2023 am 09:39 AM

How to use JavaScript to implement the drag and zoom function of images? In modern web development, dragging and zooming images is a common requirement. By using JavaScript, we can easily add dragging and zooming functions to images to provide a better user experience. In this article, we will introduce how to use JavaScript to implement this function, with specific code examples. HTML structure First, we need a basic HTML structure to display pictures and add

How to arrange two pictures side by side in wps document How to arrange two pictures side by side in wps document Mar 20, 2024 pm 04:00 PM

When using WPS office software, we found that not only one form is used, tables and pictures can be added to the text, pictures can also be added to the table, etc. These are all used together to make the content of the entire document look richer. , if you need to insert two pictures into the document and they need to be arranged side by side. Our next course can solve this problem: how to place two pictures side by side in a wps document. 1. First, you need to open the WPS software and find the picture you want to adjust. Left-click the picture and a menu bar will pop up, select &quot;Page Layout&quot;. 2. Select &quot;Tight wrapping&quot; in text wrapping. 3. After all the pictures you need are confirmed to be set to &quot;Tight text wrapping&quot;, you can drag the pictures to the appropriate position and click on the first picture.

See all articles