티스토리 뷰
728x90
반응형
이미지 저장시 네 귀퉁이를 곡선으로 처리하여 좀 더 부드러운 느낌을 줄수 없을까?
요즘 너무 직각의 이미지만 보니, 라운드가 땡기는군요.
아래의 코드는 GD라이브러리를 이용한 라운드코너이미지 만들기 php소스 코드 입니다.
http://www.assemblysys.com/dataServices/php_roundedCorners.php
GD라이브러리가 설치된 환경에서 위의 코드를 복사하여 roundedCorners.php 파일로 저장합니다.
그리고 이미지를 출력시에
src의 변수에 원본이미지의 경로를 담고, radius 변수에 곡선의 각도를 입력해주시면 됩니다.
그 이외의 옵션 변수들은 API를 참고하시기 바랍니다.
roundedCorners.php는 해당 경로의 이미지를 읽어 라운드처리한 이미지를 임시로 생성한뒤 출력합니다.
하지만 이방법을 사용시에 트래픽이 많은 곳에서는 과도한 메모리가 사용될 우려가 있으므로,
위의 php코드를 변형, 사용하여 이미지 업로드시에 라운드코너이미지를 생성하여 저장하고, 이를 불러오는 방법이 좋겠습니다.
요즘 너무 직각의 이미지만 보니, 라운드가 땡기는군요.
아래의 코드는 GD라이브러리를 이용한 라운드코너이미지 만들기 php소스 코드 입니다.
http://www.assemblysys.com/dataServices/php_roundedCorners.php
$image_file = $_GET['src'];
$corner_radius = isset($_GET['radius']) ? $_GET['radius'] : 20; // The default corner radius is set to 20px
$angle = isset($_GET['angle']) ? $_GET['angle'] : 0; // The default angle is set to 0º
$topleft = (isset($_GET['topleft']) and $_GET['topleft'] == "no") ? false : true; // Top-left rounded corner is shown by default
$bottomleft = (isset($_GET['bottomleft']) and $_GET['bottomleft'] == "no") ? false : true; // Bottom-left rounded corner is shown by default
$bottomright = (isset($_GET['bottomright']) and $_GET['bottomright'] == "no") ? false : true; // Bottom-right rounded corner is shown by default
$topright = (isset($_GET['topright']) and $_GET['topright'] == "no") ? false : true; // Top-right rounded corner is shown by default
$images_dir = 'images/';
$corner_source = imagecreatefrompng('images/rounded_corner.png');
$corner_width = imagesx($corner_source);
$corner_height = imagesy($corner_source);
$corner_resized = ImageCreateTrueColor($corner_radius, $corner_radius);
ImageCopyResampled($corner_resized, $corner_source, 0, 0, 0, 0, $corner_radius, $corner_radius, $corner_width, $corner_height);
$corner_width = imagesx($corner_resized);
$corner_height = imagesy($corner_resized);
$image = imagecreatetruecolor($corner_width, $corner_height);
$image = imagecreatefromjpeg($images_dir . $image_file); // replace filename with $_GET['src']
$size = getimagesize($images_dir . $image_file); // replace filename with $_GET['src']
$white = ImageColorAllocate($image,255,255,255);
$black = ImageColorAllocate($image,0,0,0);
// Top-left corner
if ($topleft == true) {
$dest_x = 0;
$dest_y = 0;
imagecolortransparent($corner_resized, $black);
imagecopymerge($image, $corner_resized, $dest_x, $dest_y, 0, 0, $corner_width, $corner_height, 100);
}
// Bottom-left corner
if ($bottomleft == true) {
$dest_x = 0;
$dest_y = $size[1] - $corner_height;
$rotated = imagerotate($corner_resized, 90, 0);
imagecolortransparent($rotated, $black);
imagecopymerge($image, $rotated, $dest_x, $dest_y, 0, 0, $corner_width, $corner_height, 100);
}
// Bottom-right corner
if ($bottomright == true) {
$dest_x = $size[0] - $corner_width;
$dest_y = $size[1] - $corner_height;
$rotated = imagerotate($corner_resized, 180, 0);
imagecolortransparent($rotated, $black);
imagecopymerge($image, $rotated, $dest_x, $dest_y, 0, 0, $corner_width, $corner_height, 100);
}
// Top-right corner
if ($topright == true) {
$dest_x = $size[0] - $corner_width;
$dest_y = 0;
$rotated = imagerotate($corner_resized, 270, 0);
imagecolortransparent($rotated, $black);
imagecopymerge($image, $rotated, $dest_x, $dest_y, 0, 0, $corner_width, $corner_height, 100);
}
// Rotate image
$image = imagerotate($image, $angle, $white);
// Output final image
imagejpeg($image);
imagedestroy($image);
imagedestroy($corner_source);
?>
GD라이브러리가 설치된 환경에서 위의 코드를 복사하여 roundedCorners.php 파일로 저장합니다.
그리고 이미지를 출력시에
- src='roundedCorners.php?src=bunny.jpg&radius=40'
- src='roundedCorners.php?src=bunny.jpg&radius=40&angle=15'
- src='roundedCorners.php?src=bunny.jpg&radius=40&topleft=no&bottomright=no'
src의 변수에 원본이미지의 경로를 담고, radius 변수에 곡선의 각도를 입력해주시면 됩니다.
그 이외의 옵션 변수들은 API를 참고하시기 바랍니다.
roundedCorners.php는 해당 경로의 이미지를 읽어 라운드처리한 이미지를 임시로 생성한뒤 출력합니다.
하지만 이방법을 사용시에 트래픽이 많은 곳에서는 과도한 메모리가 사용될 우려가 있으므로,
위의 php코드를 변형, 사용하여 이미지 업로드시에 라운드코너이미지를 생성하여 저장하고, 이를 불러오는 방법이 좋겠습니다.
728x90
반응형
'WEB2.0 > 프로그래밍' 카테고리의 다른 글
[php] 해외의 웹호스팅 사용시 timezone 세팅하기 (1) | 2009.03.31 |
---|---|
매쉬업경진대회 종료 (0) | 2009.03.08 |
자바스크립트로 이미지 로테이션(rotation)하기 (0) | 2009.03.05 |
19가지 기대되는 PHP 템플릿 엔진 (0) | 2009.01.20 |
PHP 프레임워크 리스트 (0) | 2009.01.11 |
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- 구글
- 웹표준
- 트위터
- 스마트폰
- 대학생
- 공모전
- CSS
- AWS
- 자바스크립트
- 앱
- 아이폰
- 모바일
- 어플리케이션
- 애플
- Apple
- 게임
- 경진대회
- php
- 벤처
- JavaScript
- android
- 네이버
- 아이디어
- 소프트웨어
- 안드로이드
- iPhone
- 앱스토어
- 창업
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
글 보관함