Interval2D.java


Below is the syntax highlighted version of Interval2D.java from §9.3 Geometric Intersection.


/******************************************************************************
 *  Compilation:  javac Interval2D.java
 *  Execution:    java Interval2D
 *
 *  Implementation of 2D interval with integer coordinates.
 *
 ******************************************************************************/

public class Interval2D { 
    public final Interval1D intervalX;   // x-interval
    public final Interval1D intervalY;   // y-interval
   
    public Interval2D(Interval1D intervalX, Interval1D intervalY) {
        this.intervalX = intervalX;
        this.intervalY = intervalY;
    }

    // does this 2D interval a intersect b?
    public boolean intersects(Interval2D b) {
        if (!intervalX.intersects(b.intervalX)) return false;
        if (!intervalY.intersects(b.intervalY)) return false;
        return true;
    }

    // does this 2D interval contain (x, y)?
    public boolean contains(int x, int y) {
        return intervalX.contains(x) && intervalY.contains(y);
    }

    // return string representation
    public String toString() {
        return intervalX + " x " + intervalY;
    }



    // test client
    public static void main(String[] args) {
        Interval1D intervalX = new Interval1D(0, 1);
        Interval1D intervalY = new Interval1D(5, 7);
        Interval2D box1 = new Interval2D(intervalX, intervalY);
        intervalX = new Interval1D(-5, 5);
        intervalY = new Interval1D(3, 8);
        Interval2D box2 = new Interval2D(intervalX, intervalY);
        StdOut.println("box1 = " + box1);
        StdOut.println("box2 = " + box2);
        StdOut.println(box1.contains(1, 5));
        StdOut.println(!box1.contains(2, 6));
        StdOut.println(box1.intersects(box2));
        StdOut.println(box2.intersects(box1));
    }
}


Copyright © 2002–2016, Robert Sedgewick and Kevin Wayne.
Last updated: Tue Aug 30 10:09:18 EDT 2016.