summaryrefslogtreecommitdiff
path: root/java/ImageProcessing/filters/EmbossFilter.java
blob: 4fb61842ebc8ae81698a705e638d253fd503edc5 (plain)
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
package imaging.filters;

import java.awt.image.*;

public class EmbossFilter extends SpatialFilter
{
  int[] grey_raster_;
  
  public EmbossFilter()
  {
  }
    
  public String info ()
  {
    return "Embosses an image.";
  }

  public void imageComplete(int status)
  {
    Timer timer = new Timer();
    
    if (status == IMAGEERROR || status == IMAGEABORTED)
      {
	consumer.imageComplete(status);
	System.out.println("Image Error: " + status);
	return;
      }
    
    int[] pixels = new int[columns_];
    createColorRasters();
    int pixel = 0;
    int red, green, blue;
    int row1, row2, row3, row4, row5;
    int new_grey = 0;
    int alpha;

    for (int x = 1; x < rows_; x++)
      {
	for (int y = 1; y < columns_; y++)
	  {
	    alpha = defaultRGB_.getAlpha(raster_[pixel++]);

	    row1 = columns_*(x - 1) + y;
	    row2 = row1 + columns_;
	    row3 = row2 + columns_;
	    row4 = row3 + columns_;
	    row5 = row4 + columns_;
	    
	    new_grey =
	      (- grey_raster_[row1 - 1]
	      - grey_raster_[row1]
	      - grey_raster_[row2 - 1]
	      + grey_raster_[row2 + 1]
	      + grey_raster_[row3]
	      + grey_raster_[row3 + 1])/6 + 128;

	    if (new_grey > 255)
	      new_grey = 255;

	    pixels[y - 1] = (alpha << 24) | (new_grey << 16) | (new_grey << 8) | new_grey;

	  }
	consumer.setPixels(0, x-1, columns_, 1, defaultRGB_, pixels, 0, columns_);
      }
    //    System.out.println(timer);
    consumer.imageComplete(status);
  }

  protected void createColorRasters()
  {
    int off = 0;
    int index = columns_;
    int pixel;
    grey_raster_ = new int[(rows_ + 1)*(columns_ + 1)];
    
    for (int x = 1; x < rows_ + 1; x++)
      {
	for (int y = 1; y < columns_ + 1; y ++)
	  {
	    index++;
	    pixel = raster_[off];
	    grey_raster_[index] = (int)(((double).212671*(double)defaultRGB_.getRed(pixel))
	      + (double)((double).715160*(double)defaultRGB_.getGreen(pixel))
	      + (double)((double).072169*(double)defaultRGB_.getBlue(pixel)));
										
	    off++;
	  }
      }
  }
}