Coordonnées des pixels de type double
Résolu
dadita
Messages postés
9
Date d'inscription
Statut
Membre
Dernière intervention
-
dadita Messages postés 9 Date d'inscription Statut Membre Dernière intervention -
dadita Messages postés 9 Date d'inscription Statut Membre Dernière intervention -
Bonjour,
comment faire pour représenter une image avec des coordonnées de pixel de type double?
c'est à dire une image construite à partir des points comme
en effet j'ai deux tableaux de données
le premier tableau de type int, et contient les valeurs de pixels RGB
j'ai un autre tableau de type double et contient les coordonnées des pixels de l'image originale après l'application d'une interpolation
maintenant je dois construire et afficher une image resultat de l'interpolation, avec les coordonnées:
Merciiiii
comment faire pour représenter une image avec des coordonnées de pixel de type double?
c'est à dire une image construite à partir des points comme
java.awt.geom.Point2D a = new Point2D.Double(13.1258,85.36985);
en effet j'ai deux tableaux de données
le premier tableau de type int, et contient les valeurs de pixels RGB
int[] pixels = image.getRGB(0,0, image.getWidth(), image.getHeight(), null, 0, image.getWidth());
j'ai un autre tableau de type double et contient les coordonnées des pixels de l'image originale après l'application d'une interpolation
gridValues = new Double[(xNumCells) * (yNumCells)]; for (int i = 0; i < yNumCells; i++) { for (int j = 0; j < xNumCells; j++) { // les points dp sont les points de l'image originale avec des coordonnées de type int (j,i) // getValue() est la fonction d'interpolation Point dp = new Point(j,i); int index = (i * (1 + xNumCells)) + j; double value = getValue(dp); gridValues[index] = value; } }
maintenant je dois construire et afficher une image resultat de l'interpolation, avec les coordonnées:
java.awt.geom.Point2D a = new Point2D.Double(j+gridValues[j],i+gridValues[j])
Merciiiii
A voir également:
- Coordonnées des pixels de type double
- Double ecran - Guide
- Whatsapp double sim - Guide
- Coordonnées gps - Guide
- Double driver - Télécharger - Pilotes & Matériel
- Double appel - Guide
1 réponse
Une image est nécessairement décrite par des pixels à coordonnées entières.
Donc tu dois transformer tes double en int (ce qui va nécessairement entrainer une perte de qualité de ton image) soit avec un cast, soit avec les méthodes Math.ceil, Math.round, Math.floor, ou autre...
Remarque : ton traitement de l'image avec un tableau à une dimension est un peu surprenant vu qu'on a des méthodes qui permettent de le faire en deux dimensions, ce qui est plus simple...
Donc tu dois transformer tes double en int (ce qui va nécessairement entrainer une perte de qualité de ton image) soit avec un cast, soit avec les méthodes Math.ceil, Math.round, Math.floor, ou autre...
Remarque : ton traitement de l'image avec un tableau à une dimension est un peu surprenant vu qu'on a des méthodes qui permettent de le faire en deux dimensions, ce qui est plus simple...
import java.awt.image.BufferedImage; import java.io.File; import java.io.IOException; import javax.imageio.ImageIO; /** Pixel construit par interpolation */ class Pixel { /** abscisse après interpolation */ public final double x; /** ordonnée après interpolation */ public final double y; /** valeur du pixel */ public final int rgb; // exemple de paramètres pour une interpolation linéaire private static double a=1, b=0.5, c=0, d=1; /** * Construction du pixel par interpolation. * @param x abscisse initiale * @param y ordonée initiale * @param rgb valeur du pixel */ public Pixel(int x,int y,int rgb) { // Enregistrement de la couleur this.rgb = rgb; // Calcul de l'interpolation this.x = a*x + b*y; this.y = c*x + d*y; } } public class Test { public static void interpoler(File imageSrcFile, File pngDstFile) throws IOException { // Lecture de l'image initiale BufferedImage image = ImageIO.read(imageSrcFile); int w = image.getWidth(); int h = image.getHeight(); // Stocke les pixels de la future image Pixel[] pixels = new Pixel[w*h]; // Déterminent les dimensions de l'image finale double minX = Double.POSITIVE_INFINITY; double maxX = Double.NEGATIVE_INFINITY; double minY = Double.POSITIVE_INFINITY; double maxY = Double.NEGATIVE_INFINITY; // Construction des pixels de la future image for (int x=0, k=0; x<w; x++) for (int y=0; y<h; y++, k++) { // Calcul de l'interpolation Pixel p = new Pixel(x,y,image.getRGB(x,y)); pixels[k] = p; // Mise à jour des dimensions if (p.x<minX) minX=p.x; if (p.x>maxX) maxX=p.x; if (p.y<minY) minY=p.y; if (p.y>maxY) maxY=p.y; } // Calcul de la taille de la future image int w2 = (int) (maxX-minX+1); int h2 = (int) (maxY-minY+1); if (w2>10000 || h2>10000) throw new RuntimeException("Dimensions de l'image supérieure à 10000 px de côté"); // Construction de la nouvelle image image = new BufferedImage(w2,h2,BufferedImage.TYPE_INT_ARGB); // Remplissage de la nouvelle image for (Pixel p : pixels) { int x = (int) (p.x - minX); // TODO : c'est ici qu'il faut choisir la conversion int y = (int) (p.y - minY); // TODO : (int), Math.floor, Math.ceil, Math.round, etc. image.setRGB(x, y, p.rgb); } // Ecriture de la nouvelle image ImageIO.write(image, "png", pngDstFile); } public static void main(String[] args) throws IOException { interpoler(new File("C:/test.png"),new File("C:/test2.png")); } }
Merciiiiiiiiiiiii