Thumbnail resize 시 GIF 파일 애니메이션 작동하게하는 방법 입니다.

안녕하세요.

Thumbnail에 gif resize 시 애니메이션 제거 되는 현상에 관련하여 답변을 찾다가. 본 스레드에도 답변이 제대로 되어있지 않은 것 같아서 제가 해결한 방법을 남겨드립니다.

 

일단, Thumbnail 게시판기타 썸네일을 필요로 하는 스킨 제작resize 하게되면, GIF 파일이 정지하는 문제가 발생합니다.

이 부분을 타 플러그인을 활용하여 해결하였습니다. 

Animated Gif Resize 라는 플러그인 입니다. (주소: https://wordpress.org/plugins/animated-gif-resize/)

 

다만, 해당 플러그인이 75x75 로 리사이즈 하고 싶을 경우. gif는 잘 되지만, 그 외의 jpg, png 등에서 세로로 긴 이미지를 제대로 resize 못하는 경향이 있습니다.

이를 해결하기 위해 약간의 수정을 하여 GIF Resize 시에만 'Animated Gif Resize' 플러그인의 필터를 활성화 시켰습니다.

그리고 kboard 플러그인의 Functions.helper.php 파일의 kboard_resize() 도 일부 코드를 추가 하였습니다.

 

'Animated Gif Resize' 플러그인의 'animated-gif-resize.php' 파일 수정 (before)

// before
add_filter("wp_image_editors", "bbpp_animated_gif_wp_image_editors", 10, 1);

'Animated Gif Resize' 플러그인의 'animated-gif-resize.php' 파일 수정 (after)

// after : gif resize 의 경우에만 해당 필터를 활성화.
function SetGifResizeEditor(){
	add_filter("wp_image_editors", "bbpp_animated_gif_wp_image_editors", 10, 1);
}

 

'kboard' 플러그인 'helper/Functions.helper.php' 파일의 kboard_resize() 에 아래와 같이 추가

function kboard_resize($image_src, $width, $height){
	
	/* 중략 */
	
	if(file_exists($new_image)){
		return $new_image_src;
	}
	
	// 추가 부분: gif 파일인 경우 Animated Git Resize의 필터를 활성화 해주기 위한 SetGifResizeEditor() 함수 수행
	$searchName = '.gif';
	if(strpos($basename, $searchName) !== false) {	SetGifResizeEditor(); } 
	// 추가부분 끝

	$image_editor = wp_get_image_editor($upload_dir['basedir'] . "{$resize_dir}/{$basename}");
	
	/* 후략 */
}

 

이것 때문에 거의 10시간 이상 고민했었는데...

해결방법을 찾고, 또 공유할 수 있게 되어서 대단히 만족합니다^^;;

kboard를 이용하는 개발자로서 조금이나마 많은 분들에게 도움이 되었으면 좋겠습니다. 

워드프레스 에러 기술지원 서비스 전문가에게 맡기세요
좋은 정보와 인맥을 동시에, 워드프레스 사용자 단톡방 참여하기
좋은 정보와 인맥을 동시에, 워드프레스 사용자 단톡방 참여하기