All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.codename1.ui.geom.Shape Maven / Gradle / Ivy

There is a newer version: 7.0.167
Show newest version
/*
 * Copyright (c) 2012, Codename One and/or its affiliates. All rights reserved.
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
 * This code is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License version 2 only, as
 * published by the Free Software Foundation.  Codename One designates this
 * particular file as subject to the "Classpath" exception as provided
 * by Oracle in the LICENSE file that accompanied this code.
 *  
 * This code is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
 * version 2 for more details (a copy is included in the LICENSE file that
 * accompanied this code).
 * 
 * You should have received a copy of the GNU General Public License version
 * 2 along with this work; if not, write to the Free Software Foundation,
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 * 
 * Please contact Codename One through http://www.codenameone.com/ if you 
 * need additional information or have any questions.
 */
package com.codename1.ui.geom;

import com.codename1.ui.Transform;

/**
 * 

An interface that can be implemented by any class that wants to be drawable * as a shape.

* * * Fill a shape general path * *

* Shape can also be used to clip an area e.g.: *

* * Shaped clipping in action * * @author Steve Hannah * @see GeneralPath for a concrete implementation of Shape. * @see com.codename1.ui.Graphics#drawShape * @see com.codename1.ui.Graphics#fillShape */ public interface Shape { /** * Gets an iterator to walk all of the path segments of the shape. * @return A PathIterator that can iterate over the path segments of the shape. * */ public PathIterator getPathIterator(); /** * Gets an iterator where all points are transformed by the provided transform. *

Note: If {@link com.codename1.ui.Transform#isSupported()} is false, then using this iterator will throw a Runtime Exception.

* @param transform * @return A PathIterator where points are transformed by the provided transform. */ public PathIterator getPathIterator(Transform transform); /** * Returns the bounding rectangle for the shape. This should be the smallest rectangle * such that the all path segments in the shape are contained within it. * @return A {@link Rectangle} that comprises the bounds of the shape. */ public Rectangle getBounds(); /** * Gets the bounds of the shape as a 4-element array representing the (x,y,width,height) * tuple. * @return [x, y, width, height] bounds of this shape. */ public float[] getBounds2D(); /** * Checks if this shape is a rectangle. A Shape is a rectangle if it is a closed quadrilateral * composed of two vertical lines and two horizontal lines. If all points have integer coordinates, * and this returns true, then getBounds() should return an equivalent rectangle to the shape itself. * @return True if shape is a rectangle. */ public boolean isRectangle(); /** * Checks if the shape contains the given point. * @param x The x-coordinate of the point to test. * @param y The y-coordinate of the point to test. * @return True if (x, y) is inside the shape. */ public boolean contains(int x, int y); /** * Returns the shape formed by the intersection of this shape and the provided * rectangle. * @param rect A rectangle with which to form an intersection. * @return The shape formed by intersecting the current shape with the provided rectangle. */ public Shape intersection(Rectangle rect); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy