This commit is contained in:
AlgaLaptop
2025-12-29 00:09:11 +01:00
parent 608853fcfe
commit f6f0eca79f
6 changed files with 149 additions and 26 deletions
+3 -4
View File
@@ -84,13 +84,12 @@ Objectif : Écriture du format `.pif` + finalisation convertisseur
| US | Assigné | Statut | | Description | | US | Assigné | Statut | | Description |
|------------|---------|--------|-----|-------------| |------------|---------|--------|-----|-------------|
| US-D2 | AA | DONE | 🟩 | Vérifier BitOutputStream avec flux réel | | US-D2 | AA | DONE | 🟩 | Vérifier BitOutputStream avec flux réel |
| US-C5 | AD | DOING | 🟨 | Implémenter PIFWriter (header + tables + pixels compressés) | | US-C5 | AD | DONE | 🟩 | Implémenter PIFWriter (header + tables + pixels compressés) |
| US-U6 | AD | DOING | 🟨 | Exporter une image en `.pif` | | US-U6 | AD | DONE | 🟩 | Exporter une image en `.pif` |
| US-P1 | AA | DONE | 🟩 | Finaliser affichage des fréquences | | US-P1 | AA | DONE | 🟩 | Finaliser affichage des fréquences |
| US-P2 | AA | DONE | 🟩 | Finaliser affichage codes Huffman | | US-P2 | AA | DONE | 🟩 | Finaliser affichage codes Huffman |
| US-P3 | AA | DONE | 🟩 | Finaliser affichage codes canoniques | | US-P3 | AA | DONE | 🟩 | Finaliser affichage codes canoniques |
| US-U7 | AD | DOING | 🟨 | Implémenter laperçu (PreviewPanel) | | US-U7 | AD | DONE | 🟩 | Implémenter laperçu (PreviewPanel) |
| US-D3..D6 | YB | TODO | 🟥 | Lier interface convertisseur -> compression |
## Fichiers à créer Sprint 2 ## Fichiers à créer Sprint 2
+5
View File
@@ -97,6 +97,11 @@ $(BIN)/$(PKG_PATH)/vconverter/CodeTablePanel.class: $(BIN) \
# Compilation des classes mpif # Compilation des classes mpif
$(BIN)/$(PKG_PATH)/mpif/PIFWriter.class: $(BIN) \
$(BIN)/$(PKG_PATH)/mimage/RGBImage.class \
$(SRC)/$(PKG_PATH)/util/BitOutputStream.class \
$(SRC)/$(PKG_PATH)/mpif/PIFWriter.java
$(JAVAC) -cp $(BIN) -d $(BIN) $(SRC)/$(PKG_PATH)/mpif/PIFWriter.java
# Compilation du controleur # Compilation du controleur
+15 -2
View File
@@ -4,6 +4,7 @@ import fr.iutfbleau.sae.mhuffman.FrequencyTable;
import fr.iutfbleau.sae.mhuffman.HuffmanTree; import fr.iutfbleau.sae.mhuffman.HuffmanTree;
import fr.iutfbleau.sae.mimage.Pixel; import fr.iutfbleau.sae.mimage.Pixel;
import fr.iutfbleau.sae.mimage.RGBImage; import fr.iutfbleau.sae.mimage.RGBImage;
import fr.iutfbleau.sae.mpif.PIFWriter;
import fr.iutfbleau.sae.vconverter.ConverterWindow; import fr.iutfbleau.sae.vconverter.ConverterWindow;
import java.awt.image.BufferedImage; import java.awt.image.BufferedImage;
import java.io.File; import java.io.File;
@@ -134,8 +135,20 @@ public class ConverterController {
} }
public void saveAsPIF(String filepath) { public void saveAsPIF(String pathfile) {
// À implémenter : sauvegarder l'image convertie au format PIF
// je Vérifie que l'image et les codes canoniques sont disponibles
if(this.image == null || this.canonRED == null){
System.err.println("Impossible d'ecrire le fichier PIF : données manquantes.");
return;
}
try {
PIFWriter ecriveur = new PIFWriter();
ecriveur.writeTOFile(pathfile, this.image, this.canonRED, this.canonGREEN, this.canonBLUE);
} catch (Exception e) {
System.err.println("Erreur lors de l’écriture du fichier .pif : " + pathfile);
}
} }
public RGBImage getImage(){ public RGBImage getImage(){
+15 -15
View File
@@ -1,12 +1,4 @@
package fr.iutfbleau.sae; package fr.iutfbleau.sae;
import java.util.HashMap;
import java.util.Map;
import fr.iutfbleau.sae.mhuffman.FrequencyTable;
import fr.iutfbleau.sae.mhuffman.HuffmanNode;
import fr.iutfbleau.sae.mhuffman.HuffmanTree;
import fr.iutfbleau.sae.mhuffman.CanonicalCode;
import fr.iutfbleau.sae.mimage.*;
import fr.iutfbleau.sae.vconverter.ConverterWindow; import fr.iutfbleau.sae.vconverter.ConverterWindow;
public class Convertisseur { public class Convertisseur {
public static void main(String[] args) { public static void main(String[] args) {
@@ -15,19 +7,27 @@ public class Convertisseur {
// je la passe au controleur // je la passe au controleur
ConverterController controller = new ConverterController(window); ConverterController controller = new ConverterController(window);
// chemin de l'image de test // chemins de l'image
String testIMG = "temp/test1.jpg"; String inpuPath;
controller.loadImage(testIMG); // je charge l'image String outputPath;
if (args.length >= 1) {
inpuPath = args[0];
}
if (args.length >= 2) {
outputPath = args[1];
}
// Logique de conversion dans lordre // je charge l'image
controller.loadImage(testIMG);
// je place la logique de conversion dans lordre
controller.computeFrequencies(); controller.computeFrequencies();
controller.computeHuffman(); controller.computeHuffman();
controller.computeCanonical(); controller.computeCanonical();
if (condition) {
}
//System.out.println("DLKSLDKSLKDSLKSLKSLDKSLDKLSdkslkdl");
} }
} }
+109 -2
View File
@@ -1,17 +1,124 @@
package fr.iutfbleau.sae.mpif; package fr.iutfbleau.sae.mpif;
import fr.iutfbleau.sae.mimage.RGBImage;
import fr.iutfbleau.sae.util.BitOutputStream; import fr.iutfbleau.sae.util.BitOutputStream;
import java.io.FileOutputStream;
import java.util.Map; import java.util.Map;
public class PIFWriter { public class PIFWriter {
// Ecriture de l'en-tête du fichier PIF (largeur et hauteur)
public void writeHeader(BitOutputStream out,int width, int height){ public void writeHeader(BitOutputStream out,int width, int height){
try {
out.writeBits(width >> 8 & 0xFF, 8); // octet de poids fort
out.writeBits(width & 0xFF, 8); // octet de poids faible
out.writeBits(height >> 8 & 0xFF, 8); // octet de poids fort
out.writeBits(height & 0xFF, 8); // octet de poids faible
} catch (Exception e) {
System.err.println("Erreur lors de l’écriture de len-tête du fichier PIF");
}
} }
public void writeTables(BitOutputStream out, Map<Integer, String> canonicalCodes){ public void writeTables(BitOutputStream out, Map<Integer, String> canonR,
Map<Integer, String> canonG, Map<Integer, String> canonB){
try {
// Écriture des longueurs des codes canoniques pour chaque composante
for (int i = 0; i < 10; i++) {
int len;
if (canonR.containsKey(i)) { // petite securité (au cas où)
len = canonR.get(i).length();
}else {
len = 0;
}
out.writeBits(len, 8);
} }
for (int i = 0; i < 10; i++) {
int len;
if (canonG.containsKey(i)) {
len = canonG.get(i).length();
}else {
len = 0;
}
out.writeBits(len, 8);
}
for (int i = 0; i < 10; i++) {
int len;
if (canonB.containsKey(i)) {
len = canonB.get(i).length();
}else {
len = 0;
}
out.writeBits(len, 8);
}
} catch (Exception e) {
System.err.println("Erreur lors de l’écriture des tables de fréquences dans le fichier PIF");
}
}
public void encodePixels(BitOutputStream out){ private void writeBitFromString(BitOutputStream out, String code){
try {
for (int i = 0; i < code.length(); i++) {
if (code.charAt(i) == '1') {
out.writeBit(1);
} else {
out.writeBit(0);
}
}
} catch (Exception e) {
System.err.println("Erreur lors de l’écriture des bits dans le fichier PIF");
}
}
// Méthode pour encoder les pixels de l'image en utilisant les codes canoniques
public void encodePixels(BitOutputStream out, RGBImage image, Map<Integer, String> canonRED, Map<Integer, String> canonGREEN, Map<Integer, String> canonBLUE){
try {
int width = image.getWidth();
int height = image.getHeight();
for (int y = 0; y < height; y++) {
for (int x = 0; x < width; x++) {
// Récupérer les valeurs R, G, B du pixel
int r = image.getPixel(x, y).getR();
int g = image.getPixel(x, y).getG();
int b = image.getPixel(x, y).getB();
// Écrire les codes dans le flux binaire
writeBitFromString(out, canonRED.get(r));
writeBitFromString(out, canonGREEN.get(g));
writeBitFromString(out, canonBLUE.get(b));
} }
} }
} catch (Exception e) {
System.err.println("Erreur lors de lencodage des pixels dans le fichier PIF");
}
}
public void writeTOFile(String filepath, RGBImage image,
Map<Integer,String> canonR,
Map<Integer,String> canonG,
Map<Integer,String> canonB)
throws Exception {
// Création du flux de sortie binaire
FileOutputStream fos =new FileOutputStream(filepath);
BitOutputStream ecriveur =new BitOutputStream(fos);
// Écriture de l'en-tête
writeHeader(ecriveur, image.getWidth(), image.getHeight());
// Écriture des tables de longueurs des codes canoniques
writeTables(ecriveur, canonR, canonG, canonB);
// Ecriture des pixels
encodePixels(ecriveur, image, canonR, canonG, canonB);
ecriveur.fermerFlux();
System.err.println("SYSTEME");
}
}
@@ -1,9 +1,8 @@
package fr.iutfbleau.sae.vconverter; package fr.iutfbleau.sae.vconverter;
import fr.iutfbleau.sae.util.Config;
import java.awt.*; import java.awt.*;
import java.awt.image.BufferedImage;
import java.util.Map; import java.util.Map;
import javax.swing.*; import javax.swing.*;
import java.awt.image.BufferedImage;
/** /**
* Fenêtre principale du convertisseur. * Fenêtre principale du convertisseur.