OpenCV를 이용하여 비주얼 스튜디오 2015 에서 지정된 이미지를 축소 하고 회전시킬 수 있습니다.
먼저 코드를 실행시킨 모습입니다.
원본 사진의 크기와 축소시킨 사진의 크기를 비교했습니다.
원본 사진의 해상도는 1280 X 1920이며 1/4 크기, 320 X 480로 축소시켰습니다.
Mat image; // 빈 영상 생성
image = imread("woman.JPG", IMREAD_COLOR); //이미지 읽기
if (image.empty()) //이미지를 제대로 읽을 수 없으면 에러 메시지 출력
{
printf("Loading Error!");
return 0;
}
/*콘솔창에 띄워주기*/
printf("Original image is %d x %d\n", image.rows, image.cols);
namedWindow("Original image"); // 원본 이미지를 전시할 창 만들기
imshow("Original image", image); // 원본 이미지 보여주기
/* 축소 이미지띄우기 */
Mat resized_image; //축소된 이미지 저장
resize(image, resized_image, Size(), 0.25, 0.25, INTER_AREA); //원본 이미지 크기 조정하기. 가로 세로 모두 1/4로 축소.
printf("Resized image is %d x %d\n", resized_image.rows, resized_image.cols); // 축소된 이미지 사이즈 출력
namedWindow("Resized image");
imshow("Resized image", resized_image); // 축소된 이미지 보여주기
이미지를 imread 함수로 불러온 후 resize 함수를 이용하여 0.25(1/4)로 축소하도록 선언했습니다.
상세 기능은 주석으로 달았습니다.
이번에 쓴 기능은 원본사진의 크기만큼 빈 이미지파일을 생성시킨후에 축소된 사진을 복사하여 넣었습니다.
/* 축소 이미지->원본사이즈에 대입 */
Mat cover_image(image.rows, image.cols, CV_8UC3); // 원본사이즈만큼의 빈 이미지 생성
resized_image.copyTo(cover_image(Rect(100, 100, resized_image.cols, resized_image.rows))); //축소한 이미지를 원본사이즈크기에 결합
imshow("covered_image", cover_image);
cover_image라 이름을 짓고, copyTo를 이용하여 복사하여 넣습니다.
마지막으로 사진을 원하는 각도만큼 회전시킬 수 있습니다.
/*회전 이미지 띄우기 */
Mat rotation; // 회전할 이미지
Point2f pt(resized_image.cols / 2., resized_image.rows / 2.); //Point2f 로 회전시킬 이미지의 중심 설정 (정중앙)
Mat r = getRotationMatrix2D(pt, 45, 0.7); // 사진 회전시키기 (사진 중앙값, 회전값, 사진 비율)
warpAffine(resized_image, rotation, r, Size(resized_image.cols, resized_image.rows)); //설정해준 값을 회전시켜줌
imshow("rotate_image", rotation);
Point2f로 이미지를 회전시킬 때 중심을 설정해줍니다.
축소한 사진의 가로,세로에 2로 나누면 정중앙을 기준으로 회전합니다.
getRotationMatrix2D()함수를 이용해 각도, 사진의 크기 비율을 조절하여 회전시킬 준비를합니다.
warpAffine()함수는 설정해준 값을 기준으로 회전 시켜줍니다.
아래는 전체 소스입니다.
#include <opencv2/opencv.hpp>
#include <iostream>
using namespace cv;
int main()
{
Mat image; // 빈 영상 생성
image = imread("woman.JPG", IMREAD_COLOR); //이미지 읽기
if (image.empty()) //이미지를 제대로 읽을 수 없으면 에러 메시지 출력
{
printf("Loading Error!");
return 0;
}
/*콘솔창에 띄워주기*/
printf("Original image is %d x %d\n", image.rows, image.cols);
namedWindow("Original image"); // 원본 이미지를 전시할 창 만들기
imshow("Original image", image); // 원본 이미지 보여주기
/* 축소 이미지띄우기 */
Mat resized_image; //축소된 이미지 저장
resize(image, resized_image, Size(), 0.25, 0.25, INTER_AREA); //원본 이미지 크기 조정하기. 가로 세로 모두 1/4로 축소.
printf("Resized image is %d x %d\n", resized_image.rows, resized_image.cols); // 축소된 이미지 사이즈 출력
namedWindow("Resized image");
imshow("Resized image", resized_image); // 축소된 이미지 보여주기
/* 축소 이미지->원본사이즈에 대입 */
Mat cover_image(image.rows, image.cols, CV_8UC3); // 원본사이즈만큼의 빈 이미지 생성
resized_image.copyTo(cover_image(Rect(100, 100, resized_image.cols, resized_image.rows))); //축소한 이미지를 원본사이즈크기에 결합
imshow("covered_image", cover_image);
/*회전 이미지 띄우기 */
Mat rotation; // 회전할 이미지
Point2f pt(resized_image.cols / 2., resized_image.rows / 2.); //Point2f 로 회전시킬 이미지의 중심 설정 (정중앙)
Mat r = getRotationMatrix2D(pt, 45, 0.7); // 사진 회전시키기 (사진 중앙값, 회전값, 사진 비율)
warpAffine(resized_image, rotation, r, Size(resized_image.cols, resized_image.rows)); //설정해준 값을 회전시켜줌
imshow("rotate_image", rotation);
waitKey(0);
return 0;
}