blob: e6619e349c7034e9e4e3017e0ba5d09437a7c941 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/**
* @author Denis M. Kishenko
* @version $Revision$
*/
package java.awt.geom;
import java.awt.Rectangle;
import java.awt.Shape;
import java.awt.geom.PathIterator;
import java.awt.geom.Rectangle2D;
import java.util.NoSuchElementException;
import org.apache.harmony.awt.internal.nls.Messages;
import org.apache.harmony.luni.util.NotImplementedException;
/**
* The Class Area provides a minimal implementation for a generic shape.
*
* @since Android 1.0
*/
public class Area implements Shape, Cloneable {
/**
* The source Shape object.
*/
Shape s;
/**
* The Class NullIterator.
*/
private static class NullIterator implements PathIterator {
/**
* Instantiates a new null iterator.
*/
NullIterator() {
}
public int getWindingRule() {
return WIND_NON_ZERO;
}
public boolean isDone() {
return true;
}
public void next() {
// nothing
}
public int currentSegment(double[] coords) {
// awt.4B=Iterator out of bounds
throw new NoSuchElementException(Messages.getString("awt.4B")); //$NON-NLS-1$
}
public int currentSegment(float[] coords) {
// awt.4B=Iterator out of bounds
throw new NoSuchElementException(Messages.getString("awt.4B")); //$NON-NLS-1$
}
}
/**
* Instantiates a new area with no data.
*/
public Area() {
}
/**
* Instantiates a new area with data given by the specified shape.
*
* @param s
* the shape that gives the data for this Area.
*/
public Area(Shape s) {
if (s == null) {
throw new NullPointerException();
}
this.s = s;
}
public boolean contains(double x, double y) {
return s == null ? false : s.contains(x, y);
}
public boolean contains(double x, double y, double width, double height) {
return s == null ? false : s.contains(x, y, width, height);
}
public boolean contains(Point2D p) {
if (p == null) {
throw new NullPointerException();
}
return s == null ? false : s.contains(p);
}
public boolean contains(Rectangle2D r) {
if (r == null) {
throw new NullPointerException();
}
return s == null ? false : s.contains(r);
}
/**
* Tests whether the object is equal to this Area.
*
* @param obj
* the object to compare.
* @return true, if successful.
* @throws NotImplementedException
* if this method is not implemented.
*/
public boolean equals(Area obj) throws org.apache.harmony.luni.util.NotImplementedException {
throw new RuntimeException("Not implemented"); //$NON-NLS-1$
}
public boolean intersects(double x, double y, double width, double height) {
return s == null ? false : s.intersects(x, y, width, height);
}
public boolean intersects(Rectangle2D r) {
if (r == null) {
throw new NullPointerException();
}
return s == null ? false : s.intersects(r);
}
public Rectangle getBounds() {
return s == null ? new Rectangle() : s.getBounds();
}
public Rectangle2D getBounds2D() {
return s == null ? new Rectangle2D.Double() : s.getBounds2D();
}
public PathIterator getPathIterator(AffineTransform t) {
return s == null ? new NullIterator() : s.getPathIterator(t);
}
public PathIterator getPathIterator(AffineTransform t, double flatness) {
return s == null ? new NullIterator() : s.getPathIterator(t, flatness);
}
/**
* Adds the specified area to this area.
*
* @param area
* the area to add to this area.
* @throws NotImplementedException
* if this method is not implemented.
*/
public void add(Area area) throws org.apache.harmony.luni.util.NotImplementedException {
throw new RuntimeException("Not implemented"); //$NON-NLS-1$
}
/**
* Performs an exclusive or operation between this shape and the specified
* shape.
*
* @param area
* the area to XOR against this area.
* @throws NotImplementedException
* if this method is not implemented.
*/
public void exclusiveOr(Area area) throws org.apache.harmony.luni.util.NotImplementedException {
throw new RuntimeException("Not implemented"); //$NON-NLS-1$
}
/**
* Extracts a Rectangle2D from the source shape if the underlying shape data
* describes a rectangle.
*
* @return a Rectangle2D object if the source shape is rectangle, or null if
* shape is empty or not rectangle.
*/
Rectangle2D extractRectangle() {
if (s == null) {
return null;
}
float[] points = new float[12];
int count = 0;
PathIterator p = s.getPathIterator(null);
float[] coords = new float[6];
while (!p.isDone()) {
int type = p.currentSegment(coords);
if (count > 12 || type == PathIterator.SEG_QUADTO || type == PathIterator.SEG_CUBICTO) {
return null;
}
points[count++] = coords[0];
points[count++] = coords[1];
p.next();
}
if (points[0] == points[6] && points[6] == points[8] && points[2] == points[4]
&& points[1] == points[3] && points[3] == points[9] && points[5] == points[7]) {
return new Rectangle2D.Float(points[0], points[1], points[2] - points[0], points[7]
- points[1]);
}
return null;
}
/**
* Reduces the size of this Area by intersecting it with the specified Area
* if they are both rectangles.
*
* @see java.awt.geom.Rectangle2D#intersect(Rectangle2D, Rectangle2D,
* Rectangle2D)
* @param area
* the area.
*/
public void intersect(Area area) {
Rectangle2D src1 = extractRectangle();
Rectangle2D src2 = area.extractRectangle();
if (src1 != null && src2 != null) {
Rectangle2D.intersect(src1, src2, (Rectangle2D)s);
}
}
/**
* Subtract the specified area from this area.
*
* @param area
* the area to subtract.
* @throws NotImplementedException
* if this method is not implemented.
*/
public void subtract(Area area) throws org.apache.harmony.luni.util.NotImplementedException {
throw new RuntimeException("Not implemented"); //$NON-NLS-1$
}
/**
* Checks if this Area is empty.
*
* @return true, if this Area is empty.
* @throws NotImplementedException
* if this method is not implemented.
*/
public boolean isEmpty() throws org.apache.harmony.luni.util.NotImplementedException {
throw new RuntimeException("Not implemented"); //$NON-NLS-1$
}
/**
* Checks if this Area is polygonal.
*
* @return true, if this Area is polygonal.
* @throws NotImplementedException
* if this method is not implemented.
*/
public boolean isPolygonal() throws org.apache.harmony.luni.util.NotImplementedException {
throw new RuntimeException("Not implemented"); //$NON-NLS-1$
}
/**
* Checks if this Area is rectangular.
*
* @return true, if this Area is rectangular.
* @throws NotImplementedException
* if this method is not implemented.
*/
public boolean isRectangular() throws org.apache.harmony.luni.util.NotImplementedException {
throw new RuntimeException("Not implemented"); //$NON-NLS-1$
}
/**
* Checks if this Area is singular.
*
* @return true, if this Area is singular.
* @throws NotImplementedException
* if this method is not implemented.
*/
public boolean isSingular() throws org.apache.harmony.luni.util.NotImplementedException {
throw new RuntimeException("Not implemented"); //$NON-NLS-1$
}
/**
* Resets the data of this Area.
*
* @throws NotImplementedException
* if this method is not implemented.
*/
public void reset() throws org.apache.harmony.luni.util.NotImplementedException {
throw new RuntimeException("Not implemented"); //$NON-NLS-1$
}
/**
* Transforms the data of this Area according to the specified
* AffineTransform.
*
* @param t
* the transform to use to transform the data.
*/
public void transform(AffineTransform t) {
s = t.createTransformedShape(s);
}
/**
* Creates a new Area that is the result of transforming the data of this
* Area according to the specified AffineTransform.
*
* @param t
* the transform to use to transform the data.
* @return the new Area that is the result of transforming the data of this
* Area according to the specified AffineTransform.
*/
public Area createTransformedArea(AffineTransform t) {
return s == null ? new Area() : new Area(t.createTransformedShape(s));
}
@Override
public Object clone() {
return new Area(this);
}
}