Questo è tratto dall'esercizio 3.28 del libro Introduzione alla programmazione Java - Edizione completa. Il codice verifica se i due rettangoli sono indipendenti, se uno è all'interno dell'altro e se uno è all'esterno dell'altro. Se nessuna di queste condizioni è soddisfatta, le due si sovrappongono.
** 3.28 (Geometria: due rettangoli) Scrivi un programma che richiede all'utente di inserire le coordinate centrali x, y, larghezza e altezza di due rettangoli e determina se il secondo rettangolo si trova all'interno del primo o si sovrappone al primo, come mostrato nella Figura 3.9. Metti alla prova il tuo programma per coprire tutti i casi. Ecco le esecuzioni di esempio:
Inserisci le coordinate x, y, centro di r1, larghezza e altezza: 2,5 4 2,5 43 Inserisci le coordinate x, y, centro di r2, larghezza e altezza: 1,5 5 0,5 3 r2 è all'interno di r1
Inserisci le coordinate x, y, centro di r1, larghezza e altezza: 1 2 3 5.5 Inserisci le coordinate x, y, centro di r2, larghezza e altezza: 3 4 4.5 5 r2 si sovrappone r1
Inserisci le coordinate x, y, centro di r1, larghezza e altezza: 1 2 3 3 Inserisci le coordinate x, y, centro di r2, larghezza e altezza: 40 45 3 2 r2 non si sovrappone a r1
import java.util.Scanner;
public class ProgrammingEx3_28 {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
System.out
.print("Enter r1's center x-, y-coordinates, width, and height:");
double x1 = input.nextDouble();
double y1 = input.nextDouble();
double w1 = input.nextDouble();
double h1 = input.nextDouble();
w1 = w1 / 2;
h1 = h1 / 2;
System.out
.print("Enter r2's center x-, y-coordinates, width, and height:");
double x2 = input.nextDouble();
double y2 = input.nextDouble();
double w2 = input.nextDouble();
double h2 = input.nextDouble();
w2 = w2 / 2;
h2 = h2 / 2;
// Calculating range of r1 and r2
double x1max = x1 + w1;
double y1max = y1 + h1;
double x1min = x1 - w1;
double y1min = y1 - h1;
double x2max = x2 + w2;
double y2max = y2 + h2;
double x2min = x2 - w2;
double y2min = y2 - h2;
if (x1max == x2max && x1min == x2min && y1max == y2max
&& y1min == y2min) {
// Check if the two are identicle
System.out.print("r1 and r2 are indentical");
} else if (x1max <= x2max && x1min >= x2min && y1max <= y2max
&& y1min >= y2min) {
// Check if r1 is in r2
System.out.print("r1 is inside r2");
} else if (x2max <= x1max && x2min >= x1min && y2max <= y1max
&& y2min >= y1min) {
// Check if r2 is in r1
System.out.print("r2 is inside r1");
} else if (x1max < x2min || x1min > x2max || y1max < y2min
|| y2min > y1max) {
// Check if the two overlap
System.out.print("r2 does not overlaps r1");
} else {
System.out.print("r2 overlaps r1");
}
}
}