Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- game
- TypeScript
- 자료구조
- Python
- dfs
- GIT
- Sequelize
- cookie
- JavaScript
- mongoose
- jest
- 공룡게임
- Dinosaur
- MySQL
- Bull
- nodejs
- OCR
- AWS
- class
- nestjs
- 게임
- MongoDB
- typeORM
- Nest.js
- Queue
- 정렬
- Express
- react
- flask
Archives
- Today
- Total
포시코딩
디아블로4 경매 사이트 만들기 (6) - OpenCV.js Image ROI 본문
728x90
개요
이전 포스팅에서 opencv의 Template Matching 기능을 통해
미리 세팅해놓은 테두리 이미지와 일치하는 부분을 찾는 과정까지 진행해봤다.
이번에는 찾아낸 일치하는 부분을 tesseract를 통해 텍스트 인식을 시키기 위해
따로 잘라낼 건데 이 잘라내는 기능 역시 opencv의 Image ROI 기능을 사용했다.
(*ROI는 Region of Interest의 줄임말로 내가 관심있는 부위라고 직역할 수 있다.)
https://docs.opencv.org/3.4/de/d06/tutorial_js_basic_ops.html
준비
Template Matching 코드에서 얻은 maxPoint 변수의 x, y 값이
매칭으로 찾은 부위의 시작 좌표인 것을 알 수 있었는데 이걸 이용해 잘라낼 사각형의 크기를 계산하면 다음과 같다.
이를 통해 Template Matching 코드와 Image ROI 코드를 적절히 활용하면 다음과 같이 작성할 수 있다.
코드
let src = cv.imread(imgElement);
let testImgElement = document.getElementById('templImageSrc');
let templ = cv.imread(testImgElement);
let dst = new cv.Mat();
let mask = new cv.Mat();
// Template Matching
cv.matchTemplate(src, templ, dst, cv.TM_CCOEFF, mask);
let result = cv.minMaxLoc(dst, mask);
let maxPoint = result.maxLoc;
// Image ROI
let rect = new cv.Rect(maxPoint.x, maxPoint.y, templ.cols, src.rows - maxPoint.y);
dst = src.roi(rect);
// 결과 출력
cv.imshow('canvasOutput', dst);
src.delete(); dst.delete(); mask.delete();
결과
여러 이미지로 테스트를 진행한 결과 모두 성공적인 결과를 얻을 수 있었다.
이제 잘라낸 이미지로 텍스트 인식을 해보자
728x90
'개인프로젝트 > OCR' 카테고리의 다른 글
디아블로4 경매 사이트 만들기 (7) - OpenCV.js Thresholding (끝) (0) | 2023.07.02 |
---|---|
디아블로4 경매 사이트 만들기 (5) - OpenCV.js Template Matching (0) | 2023.06.27 |
디아블로4 경매 사이트 만들기 (4) - Vue에서 Drag&Drop, Crop, Tesseract 사용하기 (0) | 2023.06.21 |
디아블로4 경매 사이트 만들기 (3) - 이미지 자르기 crop (0) | 2023.06.15 |
디아블로4 경매 사이트 만들기 (2) - 이미지 드래그 앤 드랍 (0) | 2023.06.15 |