Notice
Recent Posts
Recent Comments
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- java
- 빅데이터
- 자바
- 풀스택프레임워크
- 자바정리
- 개발자
- backend
- 백준
- 주가예측
- java정리
- 코테
- 코딩독학
- C++
- frontend
- 프로그래머스
- 사물인터넷
- 개발
- 이웃한 칸
- 코스닥
- Python
- 코딩
- 코딩테스트
- 프로그래밍
- 자바독학
- 프로그램
- Reflex
- 개인프로젝트
- 모의 주식
- Project
- SNS
Archives
- Today
- Total
Creative Code
Chapter10.cpp (이미지 픽셀 분리) 본문
※Chapter10.cpp파일
#pragma once
#include <opencv2/opencv.hpp>
using namespace std;
using namespace cv;
//이미지에서 Red, Blue, Green 성분만 불러 grayscale로 읽기
void show_BGR_channels() {
Mat src = imread("candies.png", IMREAD_COLOR); // 356 * 493
Mat B(src.size(), CV_8UC1); // Blue 색상만 가져오기 때문에 채널이 1개
Mat G(src.size(), CV_8UC1);
Mat R(src.size(), CV_8UC1);
for (int i = 0; i < src.rows; ++i) {
for (int j = 0; j < src.cols; ++j) {
Vec3b& p1 = src.at<Vec3b>(i, j);
B.at<uchar>(i, j) = p1[0];
G.at<uchar>(i, j) = p1[1];
R.at<uchar>(i, j) = p1[2];
}
}
imshow("SRC", src);
imshow("B", B);
imshow("G", G);
imshow("R", R);
waitKey();
destroyAllWindows();
}
//split함수를 이용해 HSV성분으로 분리해 grayscale로 읽기
void color_split() {
Mat src = imread("candies.png");
Mat dst(src.size(), src.type());
vector<Mat>hsv_planes;
cvtColor(src, dst, COLOR_BGR2HSV);
split(dst, hsv_planes);
imshow("src", src);
imshow("DST", dst);
imshow("H", hsv_planes[0]);
imshow("S", hsv_planes[1]);
imshow("V", hsv_planes[2]);
waitKey();
destroyAllWindows();
}
//피부색을 검출하는 방법 -> 히스토그램 역투영
※opencv_Projects.cpp 파일
#include <opencv2/opencv.hpp>
using namespace std;
extern void show_BGR_channels();
extern void color_split();
int main() {
//show_BGR_channels();
color_split();
}
'OpenCV(C++)' 카테고리의 다른 글
Chapter15.cpp (knn 머신러닝) (0) | 2023.09.18 |
---|---|
Chapter11.cpp (영상 이진화, 모폴로지) (0) | 2023.09.18 |
Chapter9.cpp (edge,직선, 원 검출) (2) | 2023.09.15 |
Chapter8.cpp (affine 변환) (0) | 2023.09.15 |
Chapter7.cpp (영상 필터링) (0) | 2023.09.14 |