Je créerais un » ImageProcesssor « (ou n'importe quel nom convenant à votre projet) et un objet de configuration ProcessConfiguration , qui contient tous les paramètres nécessaires.
ImageProcessor p = new ImageProcessor();
ProcessConfiguration config = new processConfiguration().setTranslateX(100)
.setTranslateY(100)
.setRotationAngle(45);
p.process(image, config);
À l'intérieur du processeur d'image, vous encapsulez l'ensemble du processus derrière un mehtod process()
public class ImageProcessor {
public Image process(Image i, ProcessConfiguration c){
Image processedImage=i.getCopy();
shift(processedImage, c);
rotate(processedImage, c);
return processedImage;
}
private void rotate(Image i, ProcessConfiguration c) {
//rotate
}
private void shift(Image i, ProcessConfiguration c) {
//shift
}
}
Cette méthode appelle les méthodes de transformation dans l'ordre correct shift()
, rotate()
. Chaque méthode obtient les paramètres appropriés de la ProcessConfiguration passée .
public class ProcessConfiguration {
private int translateX;
private int rotationAngle;
public int getRotationAngle() {
return rotationAngle;
}
public ProcessConfiguration setRotationAngle(int rotationAngle){
this.rotationAngle=rotationAngle;
return this;
}
public int getTranslateY() {
return translateY;
}
public ProcessConfiguration setTranslateY(int translateY) {
this.translateY = translateY;
return this;
}
public int getTranslateX() {
return translateX;
}
public ProcessConfiguration setTranslateX(int translateX) {
this.translateX = translateX;
return this;
}
private int translateY;
}
J'ai utilisé des interfaces fluides
public ProcessConfiguration setRotationAngle(int rotationAngle){
this.rotationAngle=rotationAngle;
return this;
}
qui permet une initialisation astucieuse (comme vu ci-dessus).
L'avantage évident, encapsulant les paramètres nécessaires dans un seul objet. Vos signatures de méthode deviennent lisibles:
private void shift(Image i, ProcessConfiguration c)
Il s'agit de déplacer une image et les paramètres détaillés sont en quelque sorte configurés .
Alternativement, vous pouvez créer un ProcessingPipeline :
public class ProcessingPipeLine {
Image i;
public ProcessingPipeLine(Image i){
this.i=i;
};
public ProcessingPipeLine shift(Coordinates c){
shiftImage(c);
return this;
}
public ProcessingPipeLine rotate(int a){
rotateImage(a);
return this;
}
public Image getResultingImage(){
return i;
}
private void rotateImage(int angle) {
//shift
}
private void shiftImage(Coordinates c) {
//shift
}
}
Un appel de méthode à une méthode processImage
instancierait un tel pipeline et rendrait transparent quoi et dans quel ordre est fait: décalage , rotation
public Image processImage(Image i, ProcessConfiguration c){
Image processedImage=i.getCopy();
processedImage=new ProcessingPipeLine(processedImage)
.shift(c.getCoordinates())
.rotate(c.getRotationAngle())
.getResultingImage();
return processedImage;
}