forked from BokSoSa/OMR_scanner
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathFilter.h
98 lines (69 loc) · 2.91 KB
/
Filter.h
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
// Filter.h: interface for the CFilter class.
//
//////////////////////////////////////////////////////////////////////
#include<opencv2/opencv.hpp>
#if !defined(AFX_FILTER_H__034717B5_0E25_4274_AE72_2FF2F9D09E29__INCLUDED_)
#define AFX_FILTER_H__034717B5_0E25_4274_AE72_2FF2F9D09E29__INCLUDED_
#define M_PI 3.14
#if _MSC_VER > 1000
#pragma once
#endif // _MSC_VER > 1000
class CFilter
{
public:
CFilter();
virtual ~CFilter();
// 가우시안 스무딩 필터링
cv::Mat GS_gaussian_smoothing_filtering(cv::Mat src_image, double sigma);
// // 최대/최소값 필터링
// IplImage *GS_maxmin_filtering(IplImage *src_image, int method, int mask_height = 3, int mask_width = 3);
// // α-trimmed 평균값 필터링
// IplImage *GS_alpha_trim_mean_filtering(IplImage *src_image, double alpha, int mask_height = 3, int mask_width = 3);
// 평균값 필터링
cv::Mat GS_mean_filtering(cv::Mat src_image, int mask_height = 3, int mask_width = 3);
// // 미디언 필터링
// IplImage *GS_median_filtering(IplImage *src_image, int mask_height = 3, int mask_width = 3, int type = 0);
// 소프턴 필터
cv::Mat GS_soften_filter(cv::Mat src_image, int method);
// 인핸스 포커스/디테일 필터
cv::Mat GS_enhance_filter(cv::Mat src_image, int method);
// 블러 라이트/블랜딩 필터
cv::Mat GS_blue_lb_filter(cv::Mat src_image, int method);
// 샤프닝
cv::Mat GS_sharpening(cv::Mat src_image, int method);
// 고주파 지원 통과 필터링
cv::Mat GS_high_boost(cv::Mat src_image, float alpha, float bias = 0.0f);
// 언샤프닝
cv::Mat GS_unsharpening(cv::Mat src_image, int method, float bias = 0.0f);
// 블러링
cv::Mat GS_blurring(cv::Mat src_image, int option, int method);
// RGB 컬러 공간에서의 양각 효과
cv::Mat GS_rgb_embossing(cv::Mat src_image, int method);
// HSV 컬러 공간에서의 양각 효과
cv::Mat GS_hsv_embossing(cv::Mat src_image, int method);
// 명암도 영상에서의 양각 효과
cv::Mat GS_embossing(cv::Mat src_image, int method);
// 명암도 영상에서의 양각 효과 - 거친 효과
cv::Mat GS_wild_embossing(cv::Mat src_image, int method);
// 회선 수행
cv::Mat GS_conv2(cv::Mat src_image, cv::Mat mat_kernel);
// 1차원 커널을 갖고 필터링.
cv::Mat ApplyFilter2D(cv::Mat src_image, /* 원본 영상 */
float *kernel, /* 1차원 커널 */
int kHeight, /* 커널의 높이 */
int kWidth); /* 커널의 너비 */
// 2차원 커널을 갖고 필터링.
cv::Mat ApplyFilter2D(cv::Mat src_image, /* 원본 영상 */
float **kernel, /* 1차원 커널 */
int kHeight, /* 커널의 높이 */
int kWidth); /* 커널의 너비 */
// CvMat인 kernel을 갖고 필터링.
cv::Mat ApplyFilter2D(cv::Mat src_image, /* 원본 영상 */
cv::Mat kernel); /* 커널 */
private:
// 블러링 - cvFilter2D() 함수 사용
cv::Mat GS_blurring_cvFilter2D(cv::Mat src_image, int method);
// 블러링 - cvSmooth() 함수 사용
cv::Mat GS_blurring_cvSmooth(cv::Mat src_image, int option, int method);
};
#endif // !defined(AFX_FILTER_H__034717B5_0E25_4274_AE72_2FF2F9D09E29__INCLUDED_)