-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathPicErosion.java
65 lines (55 loc) · 2.17 KB
/
PicErosion.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
/*
* 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;
import kimage.plugins.color.Grayscale;
import kimage.utils.gui.ImageFrame;
import sample.use.my.Greyscale;
import sample.use.my.sprawozdanie1.SaltPepper;
/**
*
* @author Weronika
*/
public class PicErosion extends Plugin {
private int dimension = 5;
// wartość reprezntuje 'grubość' obwódki wokół analizowanego piksela
private int frame_size=dimension/2;
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) {
int min=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
// jest mniejszy od aktualnego min
if (min>imgIn.getRed(x, y)) {
min=imgIn.getRed(x, y);
}
}
}
}
pic[i][j]=min;
}
}
// 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]);
}
}
}
}