-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDilation.java
81 lines (63 loc) · 2.44 KB
/
Dilation.java
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
/*
* To change this license header, choose License Headers in Project Properties.
* To change this template file, choose Tools | Templates
* and open the template in the editor.
*/
package sample.use.my2;
import kimage.image.Image;
import kimage.plugin.Plugin;
/**
*
* @author Weronika
*/
public class Dilation extends Plugin {
private int dimension = 11;
private boolean[][] SE;
// wartość reprezntuje 'grubość' obwódki wokół analizowanego piksela
private int frame_size;
private int size;
// inicjalizacja SE dla macierzy 5x5 z wszystkimi wartościami '1'
{
frame_size=dimension/2;
size=frame_size*2+1;
SE=new boolean[size][size];
for (int i=0; i<size; ++i)
for (int j=0; j<size; ++j)
SE[i][j]=false;
for (int i=0; i<size; ++i)
SE[7][i]=SE[6][i]=SE[8][i]=true;
}
public void process(Image imgIn, Image imgOut) {
int width = imgIn.getWidth();
int height = imgIn.getHeight();
// wartości wszystkich pikseli nowego obrazu
int[][] pic = new int[width][height];
// przejście po wszyskich pikselach obrazu
for (int i = 0; i < width; ++i) {
for (int j = 0; j < height; ++j) {
pic[i][j] = imgIn.getRed(i, j);
// przejście po wszystkich pikselach otaczających dany piksel
// zgodnie z wymiarem SE
for (int x = i - frame_size, x2 = 0;
x <= i + frame_size; ++x, ++x2) {
for (int y = j - frame_size, y2 = 0;
y <= j + frame_size; ++y, ++y2) {
if (x >= 0 && x < width && y >= 0 && y < height) {
// sprawdzenie czy piksel z otoczenia pokrywa
// się z odpowiadającą wartością '1' z SE
if (SE[x2][y2] && imgIn.getRed(x, y) == 0) {
pic[i][j] = 0;
}
}
}
}
}
}
// skopiowanie wyniku do obrazu wyjściowego
for (int i = 0; i < width; ++i) {
for (int j = 0; j < height; ++j) {
imgOut.setRGB(i, j, pic[i][j], pic[i][j], pic[i][j]);
}
}
}
}