thinkphp 프레임워크에서 이미지 회전 및 자르기 기능을 구현하는 방법

WBOY
풀어 주다: 2023-05-30 11:52:38
앞으로
1080명이 탐색했습니다.

1단계: thinkphp 프레임워크 설치
자신의 개발에 thinkphp 프레임워크를 사용하려면 당연히 자신의 프로젝트에 Thinkphp 프레임워크를 설치해야 합니다. thinkphp 설치는 매우 간단합니다. 압축을 푼 패키지를 프로젝트 루트 디렉터리로 직접 옮기기만 하면 됩니다. 이동 후 thinkphp 사용을 시작하려면 프로젝트의 항목 파일 index.php만 수정하면 됩니다.

2단계: thinkphp의 이미지 처리 클래스 소개
이미지를 조작하기 위한 thinkphp 프레임워크의 이미지 처리 클래스를 소개합니다. 주로 크기 조정, 자르기, 회전 등의 기본 처리 방법을 포함합니다. 그 중 회전 자르기가 이 기사의 초점입니다.

이미지 처리 클래스를 소개하려면 컨트롤러에 다음 코드를 추가하세요.

use think\Image;
로그인 후 복사

3단계: 이미지 회전 및 자르기 구현
회전 및 자르기는 이미지 회전과 자르기를 결합한 작업으로 매우 간단합니다. 구현하다. 다음은 이 기사에서 가장 어려운 부분입니다. 즉,rotateCrop 함수의 코드 구현입니다.

/**
* 旋转并裁剪图片操作
* @param string $image 被操作图片路径
* @param int $width 裁剪宽度
* @param int $height 裁剪高度
* @param int $degree 旋转角度
* @return bool|string 处理后保存的文件路径或者false
**/
public function rotateCrop($image, $width, $height, $degree) {
    $image = Image::open($image);
    $image->rotate($degree)->crop($width, $height)->save($image);
    return $image->save() ? $image->getPathName() : false;
}
로그인 후 복사

이 함수에서는 이미지 경로, 자르기 너비, 자르기 높이, 회전 각도의 4개 매개변수를 전달해야 합니다. 이미지 경로는 필수 매개변수이고 나머지 3개 매개변수는 선택 매개변수입니다. 너비와 높이는 기본적으로 0입니다. . 즉, 자르기가 수행되지 않습니다. 회전 각도의 기본값은 0이며 이는 회전이 수행되지 않음을 의미합니다.

가장 중요한 것은 회전 및 자르기 작업입니다. Image::open($image) 함수는 이미지 객체를 열고 객체에서 회전() 및 자르기() 메서드를 호출하여 회전 및 자르기 작업을 수행하고 마지막으로 save() 이미지를 저장하고 출력하면 됩니다.

4단계: 효과 테스트
마지막으로 코드를 테스트해 보겠습니다. 컨트롤러에 다음 코드를 추가하세요.

$image = 'image/test.jpg';
$width = 200;
$height = 300;
$degree = 90;
$test = $this->rotateCrop($image, $width, $height, $degree);
echo &#39;<img src="&#39;.$test.&#39;" />&#39;;
로그인 후 복사

위 코드에서 $image는 대상 이미지 경로, $width 및 $height는 테스트 자르기 매개변수, $degree는 테스트 회전 매개변수입니다.rotateCrop( ) 함수를 실행한 후 반환 저장된 이미지 경로를 선택하고 마지막으로 페이지에 표시합니다. 모든 것이 올바른지 확인한 후 페이지를 다시 로드하면 처리된 사진을 찾아볼 수 있습니다

위 내용은 thinkphp 프레임워크에서 이미지 회전 및 자르기 기능을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:yisu.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿