• PHP图片的裁剪与缩放


    图片太大且规格不统一,显示的控制需要靠JavaScript来完成,用在移动设备上时显示效果不好且流量巨大,需要对现有图片库的图片进行一次处理,生成符合移动设备用的缩略图,将原来客户端JS做的工作转移到服务器端用PHP的GD库来集中处理。

    图片源与需要的大小:

    $src_img = "wallpaper.jpg";
    $dst_w = 300;
    $dst_h = 200;
    

      

    剪裁图像,保证图像区域最大化显示,并按比例缩放到指定大小。

    一开始采用了 imagecopyresized 方法进行图像等比缩小,实际操作后发现,图像缩小后燥点非常严重。后再换用 imagecopyresampled (这里说一下,网上转载这个文章的很多,但是他们都把imagecopyresampled写成了imagecopysampled导致无法使用,所以我才重新贴了这个)方法,该方法会对图像进行重新采样,对缩小的图像进行平滑处理,使清晰度得到很大提高。

    <?php
    list($src_w,$src_h)=getimagesize($src_img);  // 获取原图尺寸
    $dst_scale = $dst_h/$dst_w; //目标图像长宽比
    $src_scale = $src_h/$src_w; // 原图长宽比
    
    if($src_scale>=$dst_scale)
    {  
    	// 过高
    	$w = intval($src_w);
    	$h = intval($dst_scale*$w);
    	$x = 0;
    	$y = ($src_h - $h)/3;
    }
    else
    { 
    // 过宽
    	$h = intval($src_h);
    	$w = intval($h/$dst_scale);
    	$x = ($src_w - $w)/2;
    	$y = 0;
    }
    // 剪裁
    $source=imagecreatefromjpeg($src_img);
    $croped=imagecreatetruecolor($w, $h);
    imagecopy($croped,$source,0,0,$x,$y,$src_w,$src_h);
    // 缩放
    $scale = $dst_w/$w;
    $target = imagecreatetruecolor($dst_w, $dst_h);
    $final_w = intval($w*$scale);
    $final_h = intval($h*$scale);
    imagecopyresampled($target,$croped,0,0,0,0,$final_w,$final_h,$w,$h);
    // 保存
    $timestamp = time();
    imagejpeg($target, "$timestamp.jpg");
    imagedestroy($target);
    ?>
    

      希望大家能用到,还是比较方便的。

  • 相关阅读:
    基于 HTML5 WebGL 构建智能数字化城市 3D 全景
    基于 H5 + WebGL 实现 3D 可视化地铁系统
    基于 HTML5 WebGL 的 3D 科幻风机
    基于 HTML5 + WebGL 的太阳系 3D 展示系统
    HT Vue 集成
    基于 HTML5 + WebGL 的地铁 3D 可视化系统
    基于 HTML5 WebGL 和 VR 技术的 3D 机房数据中心可视化
    String、StringBuffer和StringBuilder的区别
    Python--Numpy基础
    python中的next()以及iter()函数
  • 原文地址:https://www.cnblogs.com/hikarusun/p/2856614.html
Copyright © 2020-2023  润新知