Pochodzi z ćwiczenia 3.28 z książki Wprowadzenie do programowania Java - edycja kompleksowa. Kod sprawdza, czy dwa prostokąty są wcięte, czy jeden jest w drugim i czy jeden znajduje się poza drugim. Jeśli żaden z tych warunków nie jest spełniony, oba się pokrywają.
** 3,28 (Geometria: dwa prostokąty) Napisz program, który zachęci użytkownika do wprowadzenia środkowych współrzędnych x, y, szerokości i wysokości dwóch prostokątów i określi, czy drugi prostokąt znajduje się wewnątrz pierwszego, czy zachodzi na pierwszy, jak pokazano na rysunku 3.9. Przetestuj swój program na wszystkie przypadki. Oto przykładowe przebiegi:
Podaj współrzędne x1, y, szerokość i wysokość r1: 2,5 4 2,5 43 Podaj współrzędne x2, y, szerokość i wysokość r2: 1,5 5 0,5 3 r2 znajduje się wewnątrz r1
Podaj współrzędne x1, y, szerokość i wysokość r1: 1 2 3 5.5 Podaj współrzędne x2, y, szerokość i wysokość r3: 3 4 4,5 5 r2 nakłada się na r1
Wprowadź współrzędne x1, y, szerokość i wysokość r1: 1 2 3 3 Wprowadź współrzędne x2, y, szerokość i wysokość r2: 40 45 3 2 r2 nie zachodzi na 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");
}
}
}