C# OpenCV 강좌 : 제 18강 - 기하학적 변환

C# OpenCV WarpPerspective

C# OpenCV 강좌 : 제 18강 - 기하학적 변환
[ C#-OpenCvSharp2 ] - 윤대희

기하학적 변환 (Warp Perspective)


1 영상이나 이미지 위에 기하학적으로 변환하기 위해 사용합니다. 영상이나 이미지를 펼치거나 좁힐 수 있습니다.

  • Tip : WarpPerspective의 경우 4개의 점을 매핑합니다. (4개의 점을 이용한 변환)
  • Tip : WarpAffine의 경우 3개의 점을 매핑합니다. (3개의 점을 이용한 변환)

WarpAffie 알아보기 : 6강 바로가기


원본(Source, src)를 영상이나 이미지를 사용하면 됩니다.

영상 사용하기 : 3강 바로가기

이미지 사용하기 : 4강 바로가기



Class


using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using OpenCvSharp;

namespace test
{
    class OpenCV : IDisposable
    {  
        IplImage perspective;        
            
        public IplImage PerspectiveTransform(IplImage src)
        {
            perspective= new IplImage(src.Size, BitDepth.U8, 3);
        
            float width = src.Size.Width;
            float height = src.Size.Height;
        
            CvPoint2D32f[] srcPoint = new CvPoint2D32f[4]; 
            CvPoint2D32f[] dstPoint = new CvPoint2D32f[4];
        
            srcPoint[0] = new CvPoint2D32f(195.0f, 200.0f);
            srcPoint[1] = new CvPoint2D32f(45.0f, 400.0f);
            srcPoint[2] = new CvPoint2D32f(435.0f, 200.0f);
            srcPoint[3] = new CvPoint2D32f(575.0f, 400.0f);
        
            dstPoint[0] = new CvPoint2D32f(0.0f, 0.0f);
            dstPoint[1] = new CvPoint2D32f(0.0f, height);
            dstPoint[2] = new CvPoint2D32f(width, 0.0f);
            dstPoint[3] = new CvPoint2D32f(width, height);
        
            CvMat mapMatrix = Cv.GetPerspectiveTransform(srcPoint, dstPoint);
            Cv.WarpPerspective(src, perspective, mapMatrix, Interpolation.Linear, CvScalar.ScalarAll(0));
        
            return perspective;
        }
            
        public void Dispose()
        {
            if (perspective != null) Cv.ReleaseImage(perspective);        
        }
    }
}



Class Code


warp = new IplImage(src.Size, BitDepth.U8, 3);

float width = src.Size.Width;
float height = src.Size.Height;

warp, width, height를 선언합니다. CvPoint2D32f()float형 2D형식으로 값을 받기 때문에 float로 선언합니다.


CvPoint2D32f[] srcPoint = new CvPoint2D32f[4]; 
CvPoint2D32f[] dstPoint = new CvPoint2D32f[4];

srcPoint[0] = new CvPoint2D32f(195.0f, 200.0f);
srcPoint[1] = new CvPoint2D32f(45.0f, 400.0f);
srcPoint[2] = new CvPoint2D32f(435.0f, 200.0f);
srcPoint[3] = new CvPoint2D32f(575.0f, 400.0f);

dstPoint[0] = new CvPoint2D32f(0.0f, 0.0f);
dstPoint[1] = new CvPoint2D32f(0.0f, height);
dstPoint[2] = new CvPoint2D32f(width, 0.0f);
dstPoint[3] = new CvPoint2D32f(width, height);

Cv.GetPerspectiveTransform()CvPoint2D32f형식으로 값을 받기 때문에 CvPoint2D32f로 선언합니다.

4개의 점을 이용한 변환이기 때문에 배열의 크기를 4로 선언합니다.

srcPoint[]변환될 4개의 지점을 선택하고 dstPoint[] 변환되어 이미지를 출력할 4개의 지점을 선택합니다.

포인트의 순서는 0:좌상, 1:좌하, 2:우상, 3:우하입니다.

srcPoint[]에서 변환될 4개의 임의의 지점을 선택하고 dstPoint[]에서 출력될 화면 크기에 맞게 설정합니다.

  • Tip : 아래의 Result 소제목에서 포인트의 위치를 확인할 수 있습니다.
  • Tip : 0:좌상-빨강, 1:좌하-초록, 2:우상-파랑, 3:우하-노랑


CvMat mapMatrix = Cv.GetPerspectiveTransform(srcPoint, dstPoint);
Cv.WarpPerspective(src, perspective, mapMatrix, Interpolation.Linear, CvScalar.ScalarAll(0));

CvMat을 이용하여 mapMatrix를 선언해 변환된 이미지의 값을 계산합니다. Cv.GetPerspectiveTransform(변환될 지점, 변환된 지점)입니다.

Cv.WarpPerspective()를 이용하여 변환시킵니다. Cv.WarpPerspective(원본, 결과, Matrix, 보간법, 여백색상)입니다. 보간은 선형 보간을 사용하였습니다.

  • Tip : CvScalar.ScalarAll(0)는 여백을 검은색으로 채웁니다.



Main Code


using (OpenCV Convert = new OpenCV())
{
    pictureBoxIpl1.ImageIpl = Convert.DrawingImage(src);
    pictureBoxIpl2.ImageIpl = Convert.PerspectiveTransform(src);
}

DrawingImage()임의로 그려낸 이미지를 표시합니다. WarpPerspectiveTransform()변환된 이미지를 표시합니다.



Result


1



Book Image

개정판이 출간됐습니다!

C#과 파이썬을 활용한 OpenCV 4 프로그래밍 (개정판)

컴퓨터 비전 기초 이론부터 머신러닝을 활용한 영상 처리 프로젝트까지

  • C#과 파이썬용 OpenCV의 데이터 형식과 행렬 및 배열 연산
  • 이미지/동영상/카메라를 활용한 입출력과 결과 저장
  • 전처리 과정과 정보를 탐색하기 위한 이미지 변형
  • 유의미한 정보를 검출하기 위한 이미지 변환
  • 이미지에서 정보를 검출 및 인식
  • 객체 검출을 포함한 모션 추적
  • K-means, KNN, SVM 등의 머신러닝 알고리즘 적용 방법
  • 카페(Caffe), 다크넷(Darknet), 텐서플로 모델을 활용한 딥러닝 모듈 적용 방법
  • Tesseract-OCR과 C# OpenCvSharp4를 활용한 프로젝트
  • 텐서플로와 Python OpenCV4를 활용한 프로젝트
  • 윤대희 저 | 위키북스

    [yes24 바로가기] [알라딘 바로가기] [교보문고 바로가기]

    후원하기


    ⤧  Previous post C# OpenCV 강좌 : 제 17강 - Drawing ⤧  Next post C# OpenCV 강좌 : 제 19강 - 캡쳐 및 녹화
    C#-OpenCvSharp2 Category