通過重映射來表達每個像素的位置(x,y) :g(x,y)=f(h(x,y)),h(x,y)是映射方法函數。當h(x,y) = (i.cols()-x,y),表示按照x軸方向發生偏轉。
函數:imgproc.remap(mat src, mat dst, mat map1, mat map2, int interpolation, int bordermode, scalar bordervalue)
參數說明:
src:源圖像
dst:目標圖像
map1:它有兩種可能表示的對象,一種是表示點(x,y)的第一個映射,另一種是cv_16sc2、cv_32fc1、cv_32fc2類型的x值
map2:它有兩種可能表示的對象,一種是當map1表示點(x,y)的第一個映射時,不代表任何值,另一種是cv_16uc1、cv_32fc1類型的y值
interpolation:插值方式,不支持inter_area
bordermode:邊界模式,默認border_contant
bordervalue:當有常數邊界時使用的值,默認為0
示例代碼:
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
|
public static void main(string[] args) { system.loadlibrary(core.native_library_name); mat src = imgcodecs.imread( "f:\\t0105b07b97736d453d.jpg" ); mat dst = src.clone(); mat map_x = new mat(src.size(), cvtype.cv_32fc1); mat map_y = new mat(src.size(), cvtype.cv_32fc1); int key = 1 ; // key取值1、2、3、4 for ( int i = 0 ; i < src.rows(); i++) { for ( int j = 0 ; j < src.cols(); j++) { switch (key) { case 1 : // 重映射1 if (j > src.cols() * 0.25 && j < src.cols() * 0.75 && i > src.rows() * 0.25 && i < src.rows() * 0.75 ) { map_x.put(i, j, 2 * (j - src.cols() * 0.25 ) + 0.5 ); map_y.put(i, j, 2 * (i - src.rows() * 0.25 ) + 0.5 ); } else { map_x.put(i, j, 0.0 ); map_y.put(i, j, 0.0 ); } break ; case 2 : // 重映射2 map_x.put(i, j, j); map_y.put(i, j, src.rows() - i); break ; case 3 : // 重映射3 map_x.put(i, j, src.cols() - j); map_y.put(i, j, i); break ; case 4 : // 重映射4 map_x.put(i, j, src.cols() - j); map_y.put(i, j, src.rows() - i); break ; default : break ; } } } imgproc.remap(src, dst, map_x, map_y, imgproc.inter_linear, core.border_constant, new scalar( 0 , 0 , 0 )); imgcodecs.imwrite( "f:\\dst.jpg" , dst); } |
源圖像:
第一種映射:
第二種映射:
第三種映射:
第四種映射:
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。
原文鏈接:http://blog.csdn.net/m1109048058/article/details/77413954