PHP图片自动裁切

PHP图片自动裁切 

如果做过那种门户站的朋友,肯定知道,一张图片可能会在不同的地方显示,大小不同,比例也不同,

如果只用一张图的话,那么肯定会变形,而且在显示小图的地方,链接 大图,又太浪费了.....用缩略图来处理,也不完美,因为每个地方出现的比例 大小可能都不一样 ,举个例子!!!!!!!!!!!!

请看上图。

在这个地方,其实调去出来的是一个列表,但是 图片的大小是不一样的,有多大宽有的窄,,当遇到这样的情况的时候 你们怎么办呢,如果直接用原来的地址,肯定是会变形的,如果搞缩略图也不靠谱,这个调去是自动调去的,你根本不知道哪个图片需要多大的宽高,

------------------------------------------------------------------------------------------------------------------

下面进入正题:

我一直用一种方法,就是PHP 自动裁切...相比你们看到过类似那种图片地址吧  /aaaa/abc_200_100.jpg  或者/aaaa/abc_200*100.jpg

我的方式就是在需要图片地方把这个图片地址转化为 类似上面的那种地址, 然后通过apache 的rewrite 定向到一个处理程序.根据宽高生成一个图片然后保存起来,

这样做的好处有几个地方:

第一,非常灵活,在有图片地方,你需要多宽多高,都可以随意 控制,不会变形,而且程序永远会让图片内容显示的最多

第二个,当图片生成过一次的时候,apache下次就不会再重定向到程序了,因为在规则前面 有 !d !f 这个判断,意思就是当前文件不存在的时候才会定向走,下次图片存在了,就不会再出来了直接就是真是的图片了

不好的地方,就是生成的图片可能会比较多,占用的空间也比较大,但是如果是自己服务器 那就无所谓了,可以归类整理下

OK 奉上代码,我们就以discuz为例

function crop_img($img, $width = 200, $height = 200) {

$img_info =parse_url($img);

/* 外部链接直接返回图片地址*/

if(!empty($img_info[‘host‘]) && $img_info[‘host‘] !=$_SERVER[‘HTTP_HOST‘]) {

return $img;

} else {

$pos = strrpos($img,‘.‘);

$img = substr($img, 0,$pos) . ‘_‘ . $width . ‘_‘ . $height . substr($img, $pos);

return $img;

}

}

function img($img,$width,$height){

$img_info =parse_url($img);

/* 外部链接直接返回图片地址*/

if(!empty($img_info[‘host‘]) && $img_info[‘host‘] !=$_SERVER[‘HTTP_HOST‘]) {

return $img;

} else {

$pos = strrpos($img,‘.‘);

$img = substr($img, 0,$pos) . ‘_‘ . $width . ‘_‘ . $height . substr($img, $pos);

echo ‘<imgsrc="‘.$img.‘" width="‘.$width.‘"height="‘.$height.‘" />‘;

return ;

}

}

函数的用法crop_img(‘原图地址‘,‘宽度‘,‘高度‘); 这个函数返回处理过的图片地址,img 函数直接返回图片标签字符串,比如在discuz模板里面调用这个函数 {eval img($pic,200,100)}

这样返回的地址就是/data/attachment/forum/aaaaaa_200_100.jpg  目前来说 这个图片是不存在 那么看第二步

第二步 需要添加apache的rewrite规则

<IfModule mod_rewrite.c>

RewriteEngine on

RewriteCond%{REQUEST_FILENAME} !-d

RewriteCond%{REQUEST_FILENAME} !-f

RewriteRule^data/attachment/(.*)$ images.php?url=$1 [L]

</IfModule>

上面的意思,就是data/attachement/这个地址开头不存在的文件都定向到image.php来处理,并且把url当参数传过去

第三部就是image.php这个里面的代码里

<?php

$url = $_GET[‘url‘];

$src = ‘./data/attachment/‘ . preg_replace(‘/_(\d+)_(\d+)/‘, ‘‘,$url);

$filename = ‘./data/attachment/‘ . $url;

if (file_exists($filename)) {

ob_start();

header(‘Content-type:image/jpeg‘);

readfile($filename);

ob_flush();

flush();

} else {

if(!preg_match(‘/_(\d+)_(\d+)/‘, $url, $wh)){

defulat();

exit();

}

$width = $wh[1];

$height = $wh[2];

thumb(realpath($src),$width, $height, $filename, ‘crop‘, ‘85‘);

}

function thumb($src, $width, $height, $filename, $mode = ‘scale‘,$quality = ‘100‘) {

try {

$imageValue = getimagesize($src);

$sourceWidth =$imageValue[0];  //原图宽

$sourceHeight =$imageValue[1]; //原图高

$thumbWidth =$width;   //缩略图宽

$thumbHeight =$height; //缩略图高

$_x = 0;

$_y = 0;

$w = $sourceWidth;

$h = $sourceHeight;

if ($mode == ‘scale‘){

if ($sourceWidth<= $thumbWidth && $sourceHeight <= $thumbHeight) {

$_x =floor(($thumbWidth - $sourceWidth) / 2);

$_y =floor(($thumbHeight - $sourceHeight) / 2);

$thumbWidth =$sourceWidth;

$thumbHeight =$sourceHeight;

} else {

if($thumbHeight * $sourceWidth > $thumbWidth * $sourceHeight) {

$thumbHeight = floor($sourceHeight * $width / $sourceWidth);

$_y =floor(($height - $thumbHeight) / 2);

} else {

$thumbWidth = floor($sourceWidth * $height / $sourceHeight);

$_x =floor(($width - $thumbWidth) / 2);

}

}

} else if ($mode ==‘crop‘) {

if ($sourceHeight< $thumbHeight) { //如果原图尺寸小于当前尺寸

$thumbWidth =floor($thumbWidth * $sourceHeight / $thumbHeight);

$thumbHeight =$sourceHeight;

}

if ($sourceWidth< $thumbWidth) {

$thumbHeight =floor($thumbHeight * $sourceWidth / $thumbWidth);

$thumbWidth =$sourceWidth;

}

$s1 = $sourceWidth/ $sourceHeight; //原图比例

$s2 = $width /$height;         //新图比例

if ($s1 == $s2) {

} else if ($s1> $s2) {  //全高度

$y = 0;

$ax =floor($sourceWidth * ($thumbHeight / $sourceHeight));

$x = ($ax -$thumbWidth) / 2;

$w =$thumbWidth / ($thumbHeight / $sourceHeight);

} else { //全宽度

$x = 0;

$ay =floor($sourceHeight * ($thumbWidth / $sourceWidth)); //模拟原图比例高度

$y = ($ay -$thumbHeight) / 2;

$h =$thumbHeight / ($thumbWidth / $sourceWidth);

}

}

switch($imageValue[2]) {

case 2: $source =imagecreatefromjpeg($src);

break;

case 1: $source =imagecreatefromgif($src);

break;

case 3: $source =imagecreatefrompng($src);

break;

case 6: $source =imagecreatefromwbmp($src);

break;

default:defulat();

return;

}

header("Content-type: image/jpeg");

$thumb =imagecreatetruecolor($width, $height);

imagefill($thumb, 0,0, imagecolorallocate($thumb, 255, 255, 255));

imagecopyresampled($thumb, $source, 0, 0, $x, $y, $width, $height, $w,$h);

imagejpeg($thumb,null, $quality);

// if($_SERVER[‘HTTP_REFERER‘] || false !== stripos($_SERVER[‘HTTP_REFERER‘],‘http://‘ . $_SERVER[‘SERVER_NAME‘])) {

imagejpeg($thumb,$filename, $quality);

// }

imagedestroy($thumb);

imagedestroy($source);

} catch (Exception $ex) {

defulat();

}

}

function defulat() {

$default_img =realpath(‘media/images/nopic.jpg‘);

ob_start();

header(‘Content-type:image/jpeg‘);

readfile($default_img);

ob_flush();

flush();

}

thumb 函数可以控制 裁切方式,scale 为等比缩放,不裁切,不够的地方 用白色填充,crop 为裁切,如果要求的宽高比 大于原图宽高比,那么就保持最大显示宽度,居中裁切上下多余部分,如果要求宽高比小于原图宽高比,那么就保持最大高度,居中裁切左右多余部分,总而言之,在保持不变形的前提下 ,把图片缩小,而且最大保留图片的内容.哈哈这个代码有多叼,试试知道了,,,当然你需要支持rewrite功能和GD2 支持

拒绝当废柴,我要当学霸!领取PHP教程!

时间: 2024-11-13 09:53:59

PHP图片自动裁切的相关文章

[JS]图片自动切换效果(学习笔记)

上次在下载的网页中看到 javascript实现图片自动切换效果: <style text="text/css"> /*图片滚动栏*/.container, .container * {    margin: 0;    padding: 0;}.container {    width: 1005px;    height: 395px;    float: right;    overflow: hidden;    position: relative;    rig

根据图片URL裁切并生成缩略图

package jtest; import java.awt.Graphics; import java.awt.Image; import java.awt.Toolkit; import java.awt.image.BufferedImage; import java.awt.image.CropImageFilter; import java.awt.image.FilteredImageSource; import java.awt.image.ImageFilter; import

如何通过CSS实现背景图片自动平铺或拉伸至整个屏幕(自适应大小)

默认情况下,通过HTML代码的BODY标签设置好背景图片<body background="x.jpg"> 后,图片会自动横向和纵向平铺.这就会产生一些美观上的问题. XP人提供CSS代码如下,放在页面头部即可,仅供参考: <style type="text/css"> body { background:url(/img/background.png); background-repeat: repeat-x; background-pos

Viewpager图片自动轮播,网络图片加载,图片自动刷新

package com.teffy.viewpager; import java.util.ArrayList; import java.util.concurrent.Executors; import java.util.concurrent.ScheduledExecutorService; import java.util.concurrent.TimeUnit; import android.annotation.SuppressLint; import android.app.Act

python爬虫实战——5分钟做个图片自动下载器

python爬虫实战--图片自动下载器 制作爬虫的基本步骤 顺便通过这个小例子,可以掌握一些有关制作爬虫的基本的步骤. 一般来说,制作一个爬虫需要分以下几个步骤: 分析需求(对,需求分析非常重要,不要告诉我你老师没教你) 分析网页源代码,配合F12(没有F12那么乱的网页源代码,你想看死我?) 编写正则表达式或者XPath表达式(就是前面说的那个神器) 正式编写python爬虫代码 效果 运行: 恩,让我输入关键词,让我想想,输入什么好呢?好像有点暴露爱好了. 回车 好像开始下载了!好赞!,我看

面向对象之图片自动切换

图片自动切换一: css样式: <style> *{ padding: 0; margin: 0; } div{ width:600px; height: 320px; background-color: pink; margin:10px auto; text-align: center; border-radius: 30px; } input{ width: 50px; height: 30px; } ul li{ list-style-type: none; margin-top: 1

网页图片自动缩小代码 防止图片撑破表格

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Content-Typ

【图文详解】python爬虫实战——5分钟做个图片自动下载器

python爬虫实战--图片自动下载器 之前介绍了那么多基本知识[Python爬虫]入门知识,大家也估计手痒了.想要实际做个小东西来看看,毕竟: talk is cheap show me the code! 制作爬虫的基本步骤 顺便通过这个小例子,可以掌握一些有关制作爬虫的基本的步骤. 一般来说,制作一个爬虫需要分以下几个步骤: 1. 分析需求(对,需求分析非常重要,不要告诉我你老师没教你) 2. 分析网页源代码,配合F12(没有F12那么乱的网页源代码,你想看死我?) 3. 编写正则表达式或

Android开发之实现图片自动滚动显示标签的ViewPager

Android中实现图片自动滚动的效果非常的常见,我们可以自己动画去实现功能.但是在Android中提供了一个ViewPager类,实现了滚动效果,在Android的extras目录下android-support-vx.jar中,x代表版本4,7等等.使用时我们需要android.support.v4.view.ViewPager的viewPager标签. 博客来源:http://blog.csdn.net/fengshizty 代码非常的简单,不用解释: xml布局文件如下: <Relati