Merge from the pain train
[official-gcc.git] / libjava / java / awt / image / Kernel.java
blob2bc82ee74c6d5a2c8f90b41e82af73871418b585
1 /* Kernel.java -- Java class for an image processing kernel
2 Copyright (C) 2004, 2005 Free Software Foundation, Inc.
4 This file is part of GNU Classpath.
6 GNU Classpath is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2, or (at your option)
9 any later version.
11 GNU Classpath is distributed in the hope that it will be useful, but
12 WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with GNU Classpath; see the file COPYING. If not, write to the
18 Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
19 02111-1307 USA.
21 Linking this library statically or dynamically with other modules is
22 making a combined work based on this library. Thus, the terms and
23 conditions of the GNU General Public License cover the whole
24 combination.
26 As a special exception, the copyright holders of this library give you
27 permission to link this library with independent modules to produce an
28 executable, regardless of the license terms of these independent
29 modules, and to copy and distribute the resulting executable under
30 terms of your choice, provided that you also meet, for each linked
31 independent module, the terms and conditions of the license of that
32 module. An independent module is a module which is not derived from
33 or based on this library. If you modify this library, you may extend
34 this exception to your version of the library, but you are not
35 obligated to do so. If you do not wish to do so, delete this
36 exception statement from your version. */
39 package java.awt.image;
41 /**
42 * Kernel represents an image processing kernel. It gets used to hold
43 * convolution filters among other purposes. It stores an array of float
44 * values representing a 2-dimensional array in row-major order.
46 * @author Jerry Quinn (jlquinn@optonline.net)
47 * @version 1.0
49 public class Kernel implements Cloneable
51 private final int width;
52 private final int height;
53 private final float[] data;
55 /**
56 * Creates a new <code>Kernel</code> instance.
58 * @param width The 2D width of data.
59 * @param height The 2D height of data.
60 * @param data The source data array.
61 * @exception IllegalArgumentException if width * height < data.length.
63 public Kernel(int width, int height, float[] data)
64 throws IllegalArgumentException
66 this.width = width;
67 this.height = height;
68 if (data.length < width * height || width < 0 || height < 0)
69 throw new IllegalArgumentException();
70 this.data = new float[width * height];
71 System.arraycopy(data, 0, this.data, 0, width * height);
74 /**
75 * Return the X origin: (width - 1) / 2
77 public final int getXOrigin()
79 return (width - 1) / 2;
82 /**
83 * Return the Y origin: (height - 1) / 2
85 public final int getYOrigin()
87 return (height - 1) / 2;
90 /**
91 * @return The kernel width.
93 public final int getWidth()
95 return width;
98 /**
99 * @return The kernel height.
101 public final int getHeight()
103 return height;
107 * Return the kernel data.
109 * If data is null, allocates a new array and returns it. Otherwise, the
110 * kernel values are copied into data.
112 * @param data Array to copy values into, or null.
113 * @return The array with copied values.
114 * @exception IllegalArgumentException if data != null and too small.
116 public final float[] getKernelData(float[] data)
117 throws IllegalArgumentException
119 if (data == null)
120 return (float[])this.data.clone();
122 if (data.length < this.data.length)
123 throw new IllegalArgumentException();
125 System.arraycopy(this.data, 0, data, 0, this.data.length);
126 return data;
130 * @return a clone of this Kernel.
132 public Object clone()
136 return super.clone();
138 catch (CloneNotSupportedException e)
140 throw (Error) new InternalError().initCause(e); // Impossible