X-Git-Url: https://git.piment-noir.org/?p=TP_POO.git;a=blobdiff_plain;f=TP2%2FImage.java;h=c2b0b84d7f758b70e7bcc0d66675bf954ec9ba64;hp=807e11b2aec81d9a3ed836c6fb548fe468209604;hb=78c725c5e287068ee24d4abb950de2ab9520d76a;hpb=a988a46e0446d611bf97c2c6b1288a1befd2d4a7 diff --git a/TP2/Image.java b/TP2/Image.java index 807e11b..c2b0b84 100644 --- a/TP2/Image.java +++ b/TP2/Image.java @@ -1,22 +1,32 @@ +import java.util.Comparator; -class Image extends Forme { +@ClassPreamble ( + author = "Jérôme Benoit", + date = "09/11/2009" +) +public class Image extends Forme implements Compactable, + Comparable, + Comparator { final int IMAGE_MAX_SIZE = 100; - Point pOri; Forme[] formeCollection; int formeNumber; Image() { - pOri = new Point(); + super(); formeCollection = new Forme[IMAGE_MAX_SIZE]; formeNumber = 0; } Image(Point p) { - pOri = p; + super(p); formeCollection = new Forme[IMAGE_MAX_SIZE]; formeNumber = 0; } + public int getSize() { + return formeNumber; + } + private boolean isEmpty() { return (formeNumber == 0); } @@ -38,7 +48,55 @@ class Image extends Forme { } public boolean ajouter(Forme forme) { - return false; + boolean rtVal = false; + if (!isFull()) { + formeCollection[formeNumber] = forme; + formeNumber++; + rtVal = true; + } + return rtVal; + } + + public boolean supprimer(int index) { + boolean rtVal = false; + if (!isEmpty()) { + for (int j = index; (j < formeNumber - 1 && index < formeNumber); j++) { + formeCollection[j] = formeCollection[j + 1]; + } + rtVal = true; + formeNumber--; + } + return rtVal; + } + + public void afficher() { + String className = this.getClass().getSimpleName(); + System.out.println("---- " + className + " ----"); + for (int i = 0; i < formeNumber; i++) { + formeCollection[i].afficher(); + } + } + + public void compacter(int nElements) { + // Heavy solution + /* int minIndex = formeNumber - nElements - 1; + for (int i = formeNumber - 1; (i > minIndex && !isEmpty()); i--) { + supprimer(i); + } */ + // Lightweight solution + if (formeNumber - nElements > 0) { + formeNumber -= nElements; + } else { + formeNumber = 0; + } + } + + public int compareTo(Image image) { + return formeNumber - image.getSize(); + } + + public int compare(Image image1, Image image2) { + return (int)(image1.getpOri().getY() - image2.getpOri().getY()); } }