|
|||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||
public interface LonlatShape<T extends LonlatShape>
Generic supertype for all shapes in the (longitude, latitude) coordinate space.
Defines basic methods and enforces immutability and iterability. In addition, shapes must be defined in such a way that translation and uniform scaling do not change their class. Other types of affine transform may change the class. For example, scaling a square by the same factor in both dimensions always results in a square. Translating it by moving it any amount in either dimension always results in a square. However, scaling it by one factor in X and another factor in Y, or applying shears, results in something not a square.
Subclasses should generally provide themselves as the generic type parameter T. For example:
public class LonlatPoint implements LonlatShape<LonlatPoint> {
This clever construction allows you to use e.g. scale() on a shape of
declared type without having to cast the result:
LonlatPoint original = new LonlatPoint(100, 100); LonlatPoint scaled = original.scale(5);Copyright 2007 Partner Software, Inc.
| Method Summary | |
|---|---|
T |
scale(double factor)
Return a scaled version of the shape by multiplying all coordinates by the given factor in both dimensions. |
T |
translate(double offsetX,
double offsetY)
Translate the shape by adding all coordinates to the given x and y offsets. |
| Methods inherited from interface java.lang.Iterable |
|---|
iterator |
| Method Detail |
|---|
T scale(double factor)
factor - scaling factor
T translate(double offsetX,
double offsetY)
offsetX - offset for the x dimensionoffsetY - offset for the y dimension
|
|||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||