/* |
|
* Copyright (c) 2008, 2012, Oracle 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. Oracle 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 Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
|
* or visit www.oracle.com if you need additional information or have any |
|
* questions. |
|
*/ |
|
package sun.java2d.pipe; |
|
import sun.java2d.SunGraphics2D; |
|
/** |
|
* This interface defines the set of calls that pipeline objects |
|
* can use to pass on responsibility for drawing arbitrary |
|
* parallelogram shapes. |
|
* Six floating point numbers are provided and the parallelogram |
|
* is defined as the quadrilateral with the following vertices: |
|
* <pre> |
|
* origin: (x, y) |
|
* => (x+dx1, y+dy1) |
|
* => (x+dx1+dx2, y+dy1+dy2) |
|
* => (x+dx2, y+dy2) |
|
* => origin |
|
* </pre> |
|
* The four u[xy][12] parameters are the unsorted extreme coordinates |
|
* of the primitive in user space. They may have been generated by a |
|
* line or a rectangle so they could have u[xy]2 < u[xy]1 in some cases. |
|
* They should be sorted before calculating the bounds of the original |
|
* primitive (such as for calculating the user space bounds for the |
|
* Paint.createContext() method). |
|
*/ |
|
public interface ParallelogramPipe { |
|
public void fillParallelogram(SunGraphics2D sg, |
|
double ux1, double uy1, |
|
double ux2, double uy2, |
|
double x, double y, |
|
double dx1, double dy1, |
|
double dx2, double dy2); |
|
/** |
|
* Draw a Parallelogram with the indicated line widths |
|
* assuming a standard BasicStroke with MITER joins. |
|
* lw1 specifies the width of the stroke along the dx1,dy1 |
|
* vector and lw2 specifies the width of the stroke along |
|
* the dx2,dy2 vector. |
|
* This is equivalent to outsetting the indicated |
|
* parallelogram by lw/2 pixels, then insetting the |
|
* same parallelogram by lw/2 pixels and filling the |
|
* difference between the outer and inner parallelograms. |
|
*/ |
|
public void drawParallelogram(SunGraphics2D sg, |
|
double ux1, double uy1, |
|
double ux2, double uy2, |
|
double x, double y, |
|
double dx1, double dy1, |
|
double dx2, double dy2, |
|
double lw1, double lw2); |
|
} |