X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;ds=sidebyside;f=src%2FPerson.java;h=5d9d812924ec1daf2c66351c4f90272a397e7bce;hb=822afd4fe0aa1669db1e3be57b277f8aff977254;hp=c0483f8eb85b25cc6f25508ba021a5e266a1d203;hpb=b974e749af3a4b2df3737b2d361233c704dcc4d8;p=Persons_Comparator.git diff --git a/src/Person.java b/src/Person.java index c0483f8..5d9d812 100644 --- a/src/Person.java +++ b/src/Person.java @@ -1,14 +1,12 @@ -import java.util.ArrayList; import java.util.Comparator; -public class Person implements Comparable, Comparator { +public class Person implements Comparator { private Firstname firstname; private Origin origin; private Size size; private Weight weight; private Eye eye; - //List of persons in the database to compare to. - private ArrayList personArrayList; + private Integer distanceFromReference; Person() { setFirstname(new Firstname()); @@ -16,7 +14,7 @@ public class Person implements Comparable, Comparator { setPersonSize(new Size()); setWeight(new Weight()); setEye(new Eye()); - setPersonArrayList(new ArrayList<>()); + setDistanceFromReference(0); } Person(String firstname, String country, Integer size, Integer weight, String colorEye) { @@ -25,7 +23,7 @@ public class Person implements Comparable, Comparator { setPersonSize(new Size(size)); setWeight(new Weight(weight)); setEye(new Eye(colorEye)); - setPersonArrayList(new ArrayList<>()); + setDistanceFromReference(0); } public void setFirstname(Firstname firstname) { @@ -68,23 +66,34 @@ public class Person implements Comparable, Comparator { return eye; } - public void setPersonArrayList(ArrayList personArrayList) { - this.personArrayList = personArrayList; + public void setDistanceFromReference(Integer distanceFromReference) { + this.distanceFromReference = distanceFromReference; } - public ArrayList getPersonArrayList() { - return personArrayList; + public Integer getDistanceFromReference() { + return distanceFromReference; } @Override - public int compareTo(Person person) { - return this.firstname.compareTo(person.getFirstname()) + this.origin.compareTo(person.getOrigin()) - + this.size.compareTo(person.getPersonSize()) + this.weight.compareTo(person.getWeight()) - + this.eye.compareTo(person.getEye()); + public String toString() { + return "Person{" + + "firstname=" + firstname.getFirstname() + + ", origin=" + origin.getCountry() + + ", size=" + size.getSize() + + ", weight=" + weight.getWeight() + + ", eye=" + eye.getStrColor() + "(" + this.getEye().getColor().getRed() + "," + this.getEye().getColor().getGreen() + "," + this.getEye().getColor().getBlue() + ")" + + ", distanceFromReference=" + this.getDistanceFromReference() + + '}'; + } + + public Integer distanceTo(Person person) { + return this.getFirstname().distanceTo(person.getFirstname()) + this.getOrigin().distanceTo(person.getOrigin()) + + this.getPersonSize().distanceTo(person.getPersonSize()) + this.getWeight().distanceTo(person.getWeight()) + + this.getEye().distanceTo(person.getEye()); } @Override public int compare(Person p1, Person p2) { - return p1.compareTo(p2); + return p1.getDistanceFromReference().compareTo(p2.getDistanceFromReference()); } }