1 | // from http://www.jhlabs.com/ip/filters/download.html |
2 | |
3 | /* |
4 | Copyright 2006 Jerry Huxtable |
5 | |
6 | Licensed under the Apache License, Version 2.0 (the "License"); |
7 | you may not use this file except in compliance with the License. |
8 | You may obtain a copy of the License at |
9 | |
10 | http://www.apache.org/licenses/LICENSE-2.0 |
11 | |
12 | Unless required by applicable law or agreed to in writing, software |
13 | distributed under the License is distributed on an "AS IS" BASIS, |
14 | WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
15 | See the License for the specific language governing permissions and |
16 | limitations under the License. |
17 | */ |
18 | |
19 | /** |
20 | * A filter which replcaes each pixel by the maximum of itself and its eight neightbours. |
21 | */ |
22 | sclass MaximumFilter extends WholeImageFilter { |
23 | int hRadius; |
24 | int vRadius; |
25 | |
26 | *() { this(1); } |
27 | *(int radius) { hRadius = vRadius = radius; } |
28 | *(int *hRadius, int *vRadius) {} |
29 | |
30 | protected int[] filterPixels( int width, int height, int[] inPixels, Rectangle transformedSpace ) { |
31 | int index = 0; // seed value (black) |
32 | int[] outPixels = new int[width * height]; |
33 | int y1 = -vRadius/2, y2 = y1+vRadius; |
34 | int x1 = -hRadius/2, x2 = x1+hRadius; |
35 | |
36 | for (int y = 0; y < height; y++) { |
37 | for (int x = 0; x < width; x++) { |
38 | int pixel = 0; |
39 | for (int dy = y1; dy <= y2; dy++) { |
40 | int iy = y+dy; |
41 | int ioffset; |
42 | if (0 <= iy && iy < height) { |
43 | ioffset = iy*width; |
44 | for (int dx = x1; dx <= x2; dx++) { |
45 | int ix = x+dx; |
46 | if (0 <= ix && ix < width) { |
47 | pixel = PixelUtils.combinePixels(pixel, inPixels[ioffset+ix], PixelUtils.MAX); |
48 | } |
49 | } |
50 | } |
51 | } |
52 | outPixels[index++] = pixel; |
53 | } |
54 | } |
55 | ret outPixels; |
56 | } |
57 | } |
Began life as a copy of #1024652
download show line numbers debug dex old transpilations
Travelled to 6 computer(s): bhatertpkbcr, mqqgnosmbjvj, pyentgdyhuwx, pzhvpgtvlbxg, tvejysmllsmz, vouqrxazstgt
No comments. add comment
Snippet ID: | #1025042 |
Snippet name: | MaximumFilter |
Eternal ID of this version: | #1025042/4 |
Text MD5: | bce288cddf773a96b5b9db0cb7efccd6 |
Author: | stefan |
Category: | javax / imaging |
Type: | JavaX fragment (include) |
Public (visible to everyone): | Yes |
Archived (hidden from active list): | No |
Created/modified: | 2019-09-02 21:29:59 |
Source code size: | 1837 bytes / 57 lines |
Pitched / IR pitched: | No / No |
Views / Downloads: | 278 / 620 |
Version history: | 3 change(s) |
Referenced in: | [show references] |