Question

Je dois écrire un programme qui remplace chaque pixel par sa valeur médiane et ses 8 voisins.Ce que j'ai sera compilé, mais lorsque j'essaie de créer une nouvelle image, j'obtiens plusieurs erreurs.L'aide est appréciée.

Voici le stacktrace :

Exception in thread "main" java.lang.ClassCastException: [I cannot be cast to java.lang.Comparable
at java.util.ComparableTimSort.countRunAndMakeAscending(ComparableTimSort.java:290)
at java.util.ComparableTimSort.sort(ComparableTimSort.java:171)
at java.util.ComparableTimSort.sort(ComparableTimSort.java:146)
at java.util.Arrays.sort(Arrays.java:472)
at ImageProcessing.median(ImageProcessing.java:25

Et voici mon code :

public static int [] [] median(int [] [] image) {
    int height = image.length;
    int width = image[0].length;
    int [] [] result = new int [height] [width];

    for (int col = 0 ; col < image.length ; col++) {
        result[0][col] = image[0][col];
        result[height - 1][col] = image[height - 1][col];
    }

    for (int row = 0 ; row < image[0].length ; row++) {
        result[row][0] = image[row][0];
        result[row][width - 1] = image[row][width - 1];
    }

    for (int row = 1 ; row < height - 1 ; row++) {
        for (int col = 1 ; col < width - 1 ; col++) {
            Arrays.sort(image);
            result[row][col] = image[row][col] / 2;
        }
    }
    return result;
}
Était-ce utile?

La solution

L'erreur que vous obtenez est due au fait que dans la dernière paire de boucles, votre appel à Arrays.sort(image) tente de trier les lignes de l'image.

Au lieu d'appeler Arrays.sort(image), vous devrez dresser une liste des neuf valeurs de pixels que vous souhaitez examiner (le pixel lui-même et ses huit voisins).Puis trier que, et écrivez la valeur médiane à result.

Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top