上传图片时压缩图片 - 后端做法

    /**
     * 函数:调整图片尺寸或生成缩略图 v 1.1
     * @param $Image 需要调整的图片(含路径)
     * @param $Dw 调整时最大宽度;缩略图时的绝对宽度
     * @param $Dh 调整时最大高度;缩略图时的绝对高度
     * @param $Type 1,调整尺寸; 2,生成缩略图
     * @return bool
     */
    public function compressImg($image, $Dw, $Dh, $type)
    {
        if (!file_exists($image)) {
            return false;
        }

        // 如果需要生成缩略图,则将原图拷贝一下重新给$Image赋值(生成缩略图操作)
        // 当Type==1的时候,将不拷贝原图像文件,而是在原来的图像文件上重新生成缩小后的图像(调整尺寸操作)
        if ($type != 1) {
            copy($image, str_replace(".", "_x.", $image));
            $image = str_replace(".", "_x.", $image);
        }
        // 取得文件的类型,根据不同的类型建立不同的对象
        $ImgInfo = getimagesize($image);
        switch ($ImgInfo[2]) {
            case 1:
                $Img = @imagecreatefromgif($image);
                break;
            case 2:
                $Img = @imagecreatefromjpeg($image);
                Break;
            case 3:
                $Img = @imagecreatefrompng($image);
                break;
        }
        // 如果对象没有创建成功,则说明非图片文件
        if (empty($Img)) {
            // 如果是生成缩略图的时候出错,则需要删掉已经复制的文件
            if ($type != 1) {
                unlink($image);
            }
            return false;
        }
        // 如果是执行调整尺寸操作则
        if ($type == 1) {
            $w = imagesx($Img);
            $h = imagesy($Img);

            $width = $w;
            $height = $h;

            if ($width > $Dw) {
                $Par = $Dw / $width;
                $width = $Dw;
                $height = $height * $Par;
                if ($height > $Dh) {
                    $Par = $Dh / $height;
                    $height = $Dh;
                    $width = $width * $Par;
                }
            } elseif ($height > $Dh) {
                $Par = $Dh / $height;
                $height = $Dh;
                $width = $width * $Par;
                if ($width > $Dw) {
                    $Par = $Dw / $width;
                    $width = $Dw;
                    $height = $height * $Par;
                }
            } else {
                $width = $Dw;
                $height = $Dh;
            }
            $nImg = imagecreatetruecolor($Dw, $Dh); // 新建一个真彩色画布
            $white = imagecolorallocate($nImg, 255, 255, 255);
            // 填充白底色
            imagefill($nImg, 0, 0, $white);
            if ($h / $w > $Dh / $Dw) { // 高比较大
                $width = $w * ($Dh / $h);
                $IntNW = $Dw - $width;
                $Dx = $IntNW / 2;
                $Dy = 0;
            } else { // 宽比较大
                $height = $h * ($Dw / $w);
                $IntNH = $Dh - $height;
                $Dx = 0;
                $Dy = $IntNH / 2;
            }
            imagecopyresampled($nImg, $Img, $Dx, $Dy, 0, 0, $width, $height, $w, $h); // 重采样拷贝部分图像并调整大小
            imagejpeg($nImg, $image); // 以JPEG格式将图像输出到浏览器或文件
            return true;
        } else { // 如果是执行生成缩略图操作则
            $w = imagesx($Img);
            $h = imagesy($Img);
            $nImg = imagecreatetruecolor($Dw, $Dh);
            $white = imagecolorallocate($nImg, 255, 255, 255);
            // 填充白底色
            imagefill($nImg, 0, 0, $white);
            if ($h / $w > $Dh / $Dw) { // 高比较大
                $width = $w * ($Dh / $h);
                $IntNW = $Dw - $width;
                imagecopyresampled($nImg, $Img, $IntNW / 2, 0, 0, 0, $width, $Dh, $w, $h);
            } else { // 宽比较大
                $height = $h * ($Dw / $w);
                $IntNH = $Dh - $height;
                imagecopyresampled($nImg, $Img, 0, $IntNH / 2, 0, 0, $Dw, $height, $w, $h);
            }
            imagejpeg($nImg, $image);
            return true;
        }
    }

需要注意的是: 如果是要生成宽高相等的图片,输出到页面的时候也要设置宽高等比例的

原文地址:https://www.cnblogs.com/pyspang/p/9567382.html

时间: 2024-08-30 09:03:01

上传图片时压缩图片 - 后端做法的相关文章

上传图片时压缩图片 - 前端(canvas)做法

HTML前端代码: <?php $this->layout('head'); ?> <?php $this->layout('sidebar'); ?> <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" /> <style type=

java上传图片并压缩图片大小

Thumbnailator 是一个优秀的图片处理的Google开源Java类库.处理效果远比Java API的好.从API提供现有的图像文件和图像对象的类中简化了处理过程,两三行代码就能够从现有图片生成处理后的图片,且允许微调图片的生成方式,同时保持了需要写入的最低限度的代码量.还支持对一个目录的所有图片进行批量处理操作.支持的处理操作:图片缩放,区域裁剪,水印,旋转,保持比例.另外值得一提的是,Thumbnailator至今仍不断更新,怎么样,感觉很有保障吧!Thumbnailator官网:h

kindeditor上传图片自动压缩过大的图片

kindeditor上传图片时自动将过大(像素以及图片长宽)的图片进行压缩,只需要在kindeditor中upload_json.ashx里面修改! <%@ webhandler Language="C#" class="Upload" %> /** * KindEditor ASP.NET * * 本ASP.NET程序是演示程序,建议不要直接在实际项目中使用. * 如果您确定直接使用本程序,使用之前请仔细确认相关安全设置. * */ using Sys

Android webview实现上传图片的效果(图片压缩)

mainactivity代码 package com.bwie.webviewupload; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.File; import java.io.FileNotFoundException; import java.io.InputStream; import java.text.SimpleDateFormat; import

用gulp-imageisux智图api压缩图片

? 智图平台是什么? 智图是腾讯ISUX前端团队开发的一个专门用于图片压缩和图片格式转换的平台,其功能包括针对png,jpeg,gif等各类格式图片的压缩,以及为上传图片自动选择最优的图片格式.同时,智图平台还会为用户转换一份webp格式的图片. ? 如何使用智图平台? 您只需要将要优化的图片拉至首页的拖拽区域后,系统会自动上传图片并经过智图压缩,返回新的图片.您也可以根据自己的实际使用情况选择不同的压缩率. ? 智图好在哪里? 智图能够自动为您选择压缩率压缩并且在合适的情况下为您选择正确的图片

Android设备上获取照片、裁剪图片、压缩图片

前言 在做上一个项目时深深受到了图片上传的苦恼.图片上传主要分为两个部分,首先要获取图片,而获取图片可以分为从文件获取或者拍照获取.第二个部分才是上传图片,两个部分都是走了不少弯路.由于Android系统的碎片化比较严重,我们可能出现在第一台机子上能获取图片,但是换一个机子就不能获取图片的问题,并且在Android6.0,7.0之后也要做一定的适配,这样对于开发者来说,无疑很蛋疼.由于也是初学者,很多东西没有考虑到,适配起来也是有点难度的. 这几天也是从github上找到了一个库(地址在这Tak

iOS 使用AFN 进行单图和多图上传 摄像头/相册获取图片,压缩图片

图片上传时必要将图片进行压缩,不然会上传失败 首先是同系统相册选择图片和视频.iOS系统自带有UIImagePickerController,可以选择或拍摄图片视频,但是最大的问题是只支持单选,由于项目要求需要支持多选,只能自己自定义.获取系统图库的框架有两个,一个是ALAssetsLibrary,兼容iOS低版本,但是在iOS9中是不建议使用的:另一个是PHAsset,但最低要求iOS8以上.兼容到iOS7,可以选择了ALAssetsLibrary 现在我们先说选择一张图的情况 一.单图多图上

js压缩图片base64长度

1 var myCanvas=$('.img-container > img').cropper('getCroppedCanvas'); 2 (function (base64){ 3 var image = new Image(),newBase64,MAX_HEIGHT = 160; 4 image.onload = function(){ 5 var canvas = document.getElementById("myCanvas"); 6 if(image.heig

canvas压缩图片

1.canvas.toDataUrl压缩图片 canvas的toDataUrl方法可以将内容导出为base64编码格式的图片,采用base64编码将比源文件大1/3,但是该方法可以指定导出图片质量,所以前端可实现上传图片的压缩.先通过fileApi拿到本地图片地址,然后新建一个Img元素,图片绘制到canvas中后再将其导出(压缩).例如: $(':file').on('change',function(){         var file = this.files[0];         v