PHP 그림 은 다른 크기 의 디 스 플레이 에 자동 으로 자 릅 니 다.

8221 단어 재단한다
그런 포 털 사이트 의 친 구 를 해 봤 다 면 한 장의 사진 이 다른 곳 에 표시 되 고 크기 가 다 르 며 비율 도 다르다 는 것 을 알 수 있 을 것 이다.
한 장의 그림 만 사용 하면 틀림없이 변형 되 고 작은 그림 이 표 시 된 곳 에서 큰 그림 을 연결 하 는 것 은 너무 낭비 된다...........................................................................

그림 을 보 세 요.
이곳 에서 사실은 목록 을 옮 겼 지만 그림 의 크기 는 다 릅 니 다.얼마나 넓 고 좁 습 니까?이런 상황 을 만 났 을 때 당신들 은 어떻게 하 시 겠 습 니까?만약 에 원래 의 주 소 를 직접 사용 하면 틀림없이 변 형 될 것 입 니 다.미리 보기 그림 을 만 들 어도 믿 을 수 없습니다.이것 은 자동 으로 옮 겨 진 것 입 니 다.어떤 그림 이 얼마나 넓 고 높 아야 하 는 지 전혀 모 릅 니 다.
------------------------------------------------------------------------------------------------------------------
다음은 본론 으로 들 어 갑 니 다.
저 는 항상 한 가지 방법 을 사용 해 왔 습 니 다.바로 PHP 자동 절단 입 니 다...........................................................200_100.jpg 또는/aaa/abc200*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 '<img src="'.$img.'" width="'.$width.'" height="'.$height.'" />';
return ;
}
}
함수 의 용법 cropimg('원본 주소','너비','높이');이 함 수 는 처 리 된 그림 주 소 를 되 돌려 줍 니 다.img 함 수 는 그림 태그 문자열 을 직접 되 돌려 줍 니 다.예 를 들 어 discuz 템 플 릿 에서 이 함수{eval img($pic,200,100)}을 호출 합 니 다.
이렇게 돌아 오 는 주 소 는/data/attachment/forum/aaaaa 입 니 다.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 을 매개 변수 로 전달 하 는 것 입 니 다.
3 부 는 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 지원 이 필요 합 니 다.

좋은 웹페이지 즐겨찾기