`

缩放图片

 
阅读更多
      //使用前还需要在上传图片时对图片大小,尺寸做出限制
 // ini_set("memory_limit","20 M"); 图片达到2 M 的话    
   /**
     * 新建裁剪缩略图
     * @param
     *
     * @return int flag 0-缩放失败,1-成功,2-不需缩放,3-不需要缩放
     * ini_set("memory_limit","20 M"); 图片过大的话
     */
    public static function processImageCreate($oldWidth, $oldHeight, $newWidth, $newHeight, $srcImage, $newImgName, $cut=false) {
        $thumb_y = 0;
        $thumb_x = 0;
        //是否需要缩放
        if ($oldWidth > $newWidth || $oldHeight > $newHeight) {
            // 裁剪
            if ($cut) {
                //按小的边缩放
                if ($oldWidth < $oldHeight) {
                    $thumbWidth = $newWidth;
                    $thumbHeight = $oldHeight * $newWidth / $oldWidth;
                    // 裁剪
                    if ($thumbHeight > $newHeight) {
                        //$thumb_y        = -($thumbHeight - $newHeight)/2;

                    } else {
                        $thumbHeight = $newHeight;
                        $thumbWidth = $oldWidth * $newHeight / $oldHeight;
                        //$newHeight = $thumbHeight;
                    }
                } else {
                    $thumbHeight = $newHeight;
                    $thumbWidth = $oldWidth * $newHeight / $oldHeight;
                    if ($thumbWidth > $newWidth) {
                        //$thumb_x = -($thumbWidth - $newWidth) / 2;
                    } else {
                        $thumbWidth = $newWidth;
                        $thumbHeight = $oldHeight * $newWidth / $oldWidth;
                        //$newWidth = $thumbWidth;
                    }
                }

                // 仅缩放
            } else {
                if ($oldWidth > $oldHeight) {
                    $thumbWidth = $newWidth;
                    $thumbHeight = $oldHeight * $newWidth / $oldWidth;
                    $newHeight = $thumbHeight;
                } else {
                    $thumbHeight = $newHeight;
                    $thumbWidth = $oldWidth * $newHeight / $oldHeight;
                    $newWidth = $thumbWidth;
                }
            }

            // 新建空图片
            $thumb = imagecreatetruecolor($newWidth, $newHeight);
            // 组合新图片
            @imagecopyresampled($thumb, $srcImage, $thumb_x, $thumb_y, 0, 0, $thumbWidth, $thumbHeight, $oldWidth, $oldHeight);
            if (!imagejpeg($thumb, $newImgName, 100)) {
                $flag = 0;
            } else {
                $flag = 1;
            }
        } else if ($oldWidth == $newWidth || $oldHeight == $newHeight) {
            $flag = 2;
        } else {
            $flag = 3;
        }
        return $flag;
    }
分享到:
评论

相关推荐

    PB按比例缩放图片.rar_PB 缩放图片_PB图片框缩放_feet4lg_pb 图片_pb 自适应

    标题中的“PB按比例缩放图片.rar”表明这是一个关于PowerBuilder(简称PB)的应用示例,主要用于图片的按比例缩放。在编程中,尤其是在GUI应用程序开发中,图像的缩放是一个常见的需求,用于适应不同的屏幕尺寸或者...

    易语言缩放图片源码(指定宽度高度)

    标题提到的"易语言缩放图片源码(指定宽度高度)"是关于使用易语言来调整图像尺寸的代码实现,这在很多应用场景中都非常实用,如网页设计、图形用户界面(GUI)开发等。 易语言中的图像处理通常依赖于特定的库或...

    c#截取一张图片的部分 或者缩放图片

    缩放图片可以使用相同的Bitmap和Graphics类,但这次我们需要调整DrawImage方法中的参数来控制缩放比例。以下是一个缩放图片的示例: ```csharp // 定义缩放后的尺寸 int newWidth = 800; int newHeight = 600; // ...

    手机js手势放大缩放图片插件

    "手机js手势放大缩放图片插件"就是这样一个工具,它专为移动设备设计,旨在提升用户体验,让用户能够通过简单的触摸手势来放大和缩小网页中的图片。这篇文章将深入探讨这种插件的工作原理、实现方式以及其在实际开发...

    Unity3d UGUI以鼠标位置点为中心缩放图片项目源码

    总之,"Unity3d UGUI以鼠标位置点为中心缩放图片项目源码"是一个实用的示例,展示了如何利用Unity3d的UGUI系统结合鼠标交互来实现图片的动态缩放功能。通过深入理解UGUI的工作原理和事件处理机制,开发者可以进一步...

    手势缩放图片代码

    在Android开发中,手势识别是实现用户交互的重要一环,特别是在图像查看器或者地图应用中,手势缩放图片是一项常见的功能。"手势缩放图片代码"这个主题涉及到的核心知识点包括手势检测、ImageView的使用以及Android...

    MFC GDI+缩放图片示例

    在这个“MFC GDI+缩放图片示例”中,我们将探讨如何使用MFC与GDI+结合来动态地调整图像的大小,即缩放图片。首先,你需要包含必要的头文件,如`&lt;afxwin.h&gt;`、`&lt;gdiplus.h&gt;`,并确保链接到`gdiplus.lib`库。 在MFC...

    照片查看器缩放图片功能

    照片查看器的核心功能之一就是其缩放图片的能力,这一特性对于查看细节、调整布局或者简单地欣赏图片都极其重要。在本篇文章中,我们将深入探讨“照片查看器缩放图片功能”,并详细介绍如何使用这项功能以及它背后的...

    批量缩放图片的Java实现

    批量缩放图片是其中的一个重要环节,可以有效地节省存储空间,优化网页加载速度,或者适应不同的显示设备。下面,我们将深入探讨如何使用Java来实现批量缩放图片的功能。 首先,Java提供了强大的Java Advanced ...

    多点触控缩放图片

    在Android开发中,实现多点触控缩放图片是一项常见的需求,这通常涉及到手势识别、图像变换以及用户体验优化。本文将深入探讨如何处理多点触控缩放图像时遇到的问题,如图像缩小后反弹导致的变形,以及缩放功能与...

    php按比例缩放图片

    php按比例缩放图片 php按比例缩放图片 php按比例缩放图片

    android缩放图片代码实例

    本文将深入探讨如何在Android中有效地缩放图片,以避免内存溢出(Out Of Memory,简称OOM)问题,提升应用的运行效率。 ### 1. 图片缩放原理 Android中的图片缩放主要涉及到两个关键概念:`Bitmap`对象和` ...

    Android 双指拖动和双指缩放图片

    在Android开发中,实现双指拖动和双指缩放图片是常见的手势识别应用场景,尤其在图片查看器或画板类应用中极为常见。本文将深入探讨如何在Android平台上实现这一功能,以及如何将绘制的线条与背景图片进行正片叠底的...

    移动端点击放大、缩放图片,微信端点击放大图片

    "移动端点击放大、缩放图片,微信端点击放大图片"这个主题聚焦于如何在手机和平板等移动设备上,特别是在微信环境中,实现图片的点击放大及手势缩放功能。下面将详细介绍这一技术的实现方式和相关知识点。 首先,...

    微信小程序中实现手指缩放图片

    用手指缩放图片。其实在实现这个需求以前,并不知道,微信公众号以及微信小程序里面有一个原生的api就自带这个特效,而且微信朋友圈也是用的这个api。wx.previewImage,就是它。预览图片。除了不能预览开发环境的...

    js房产网站大小缩放图片滚动展示

    "js房产网站大小缩放图片滚动展示"这一技术就是为了让网站中的图片根据屏幕尺寸自适应缩放,并实现平滑滚动效果,从而提供优秀的用户体验。下面将详细探讨这一技术涉及的知识点。 1. **响应式设计**:在当前多设备...

    jQuery支持局部缩放图片放大镜插件.zip

    **jQuery支持局部缩放图片放大镜插件** 在网页设计中,为了提升用户体验,经常会用到图片放大镜功能,让用户可以更清晰地查看产品的细节。jQuery作为一款强大的JavaScript库,提供了丰富的插件来实现这样的效果。...

    纯HTML+js实现鼠标滚轮动态调整缩放图片大小

    纯HTML+js实现鼠标滚轮动态调整缩放图片大小 演示效果: https://www.bilibili.com/video/BV1pS4y167wJ/

    5.用鼠标缩放图片_starist_用鼠标缩放图片_

    在图像处理和计算机图形学领域,缩放图片是一项基本的操作,尤其在查看、编辑或展示图像时非常常见。本文将详细讲解如何通过鼠标滑轮在图片框中对图片进行放大或缩小的操作,以及相关的技术实现。 首先,让我们理解...

Global site tag (gtag.js) - Google Analytics