/*************************************************************************************************************************************/ /* */ /* G E N E R A T I O N D ' U N E P A L E T T E D E S T I N E E A U */ /* C O M P A C T A G E D E S N I V E A U X D ' U N E I M A G E : */ /* */ /* */ /* Definition : */ /* */ /* */ /* Cette commande prend une image */ /* et cree une palette dont la composante */ /* ROUGE permet de compacter les niveaux via : */ /* */ /* $xci/substitue$X \ */ /* A="IMAGE A COMPACTER" \ */ /* p="PALETTE DE COMPACTAGE" \ */ /* substitution=L_SUBSTITUTION_ROUGE \ */ /* R="IMAGE COMPACTEE" \ */ /* $formatI */ /* */ /* alors que la composante VERTE permet de */ /* restaurer les niveaux originaux via : */ /* */ /* $xci/substitue$X \ */ /* A="IMAGE COMPACTEE" \ */ /* p="PALETTE DE COMPACTAGE" \ */ /* substitution=L_SUBSTITUTION_VERTE \ */ /* R="IMAGE DECOMPACTEE" \ */ /* $formatI */ /* */ /* ou "PALETTE DE COMPACTAGE" est la palette */ /* generee par : */ /* */ /* $xciP/compactage.01$X \ */ /* A="IMAGE A COMPACTER" \ */ /* p="PALETTE DE COMPACTAGE" \ */ /* $formatI */ /* */ /* ou on note que la composante '$BLEUE' est */ /* inutile... */ /* */ /* */ /* Author of '$xciP/compactage.01$K' : */ /* */ /* Jean-Francois COLONNA (LACTAMME, 20150129133118). */ /* */ /*************************************************************************************************************************************/ /*===================================================================================================================================*/ /*************************************************************************************************************************************/ /* */ /* I N T E R F A C E ' listG ' : */ /* */ /* */ /* :Debut_listG: */ /* :Fin_listG: */ /* */ /*************************************************************************************************************************************/ /*===================================================================================================================================*/ /*************************************************************************************************************************************/ /* */ /* D I R E C T I V E S S P E C I F I Q U E S D E C O M P I L A T I O N : */ /* */ /*************************************************************************************************************************************/ /*===================================================================================================================================*/ /*************************************************************************************************************************************/ /* */ /* F I C H I E R S D ' I N C L U D E S : */ /* */ /*************************************************************************************************************************************/ #include INCLUDES_BASE /*===================================================================================================================================*/ /*************************************************************************************************************************************/ /* */ /* P A R A M E T R E S : */ /* */ /*************************************************************************************************************************************/ /*===================================================================================================================================*/ /*************************************************************************************************************************************/ /* */ /* M A C R O S U T I L E S : */ /* */ /*************************************************************************************************************************************/ /*===================================================================================================================================*/ /*************************************************************************************************************************************/ /* */ /* C A L C U L D ' U N E P A L E T T E A P A R T I R D ' U N E I M A G E : */ /* */ /*************************************************************************************************************************************/ BCommande(nombre_d_arguments,arguments) /*-----------------------------------------------------------------------------------------------------------------------------------*/ Bblock DEFV(CHAR,INIC(POINTERc(nom_imageA),NOM_PIPE)); /* Nom de l'image Argument. */ DEFV(CHAR,INIC(POINTERc(nom_paletteR),NOM_PIPE)); /* Nom de la palette Resultat a generer. */ DEFV(CHAR,INIC(POINTERc(systeme_de_sortie),ESPACE_DE_COULEURS_RVB)); /* Definition du systeme de sortie : {R,V,B}. */ /*..............................................................................................................................*/ GET_ARGUMENTSi(nombre_d_arguments ,BLOC(GET_ARGUMENT_C("imageA=""A=",nom_imageA); GET_ARGUMENT_C("paletteR=""pR=""palette=""p=",nom_paletteR); ) ); Test(PAS_D_ERREUR(CODE_ERROR(Iload_image(ImageA,nom_imageA)))) Bblock DEFV(genere_p,INIT(niveau_courant,NOIR)); CALS(Ihistogramme(ImageA)); /* Calcul de l'histogramme de l'image courante. */ BoIn(niveau,NOIR,BLANC,PAS_COULEURS) Bblock EGAL(ACCES_listes_de_substitution(L_SUBSTITUTION_ROUGE,niveau),NOIR); EGAL(ACCES_listes_de_substitution(L_SUBSTITUTION_VERTE,niveau),NOIR); EGAL(ACCES_listes_de_substitution(L_SUBSTITUTION_BLEUE,niveau),NOIR); /* Initialisation... */ Eblock EBoI BoIn(niveau,NOIR,BLANC,PAS_COULEURS) Bblock Test(IZGT(ACCES_HISTOGRAMME(niveau))) Bblock EGAL(ACCES_listes_de_substitution(L_SUBSTITUTION_ROUGE,niveau),niveau_courant); /* Generation de la liste de compression des niveaux. */ EGAL(ACCES_listes_de_substitution(L_SUBSTITUTION_VERTE,niveau_courant),niveau); /* Generation de la liste d'inversion de compression des niveaux. */ INCR(niveau_courant,PAS_COULEURS); Eblock ATes Bblock Eblock ETes Eblock EBoI CALS(Iupdate_palette_de_couleurs(nom_paletteR,systeme_de_sortie)); /* Mise a jour de la palette de couleurs... */ Eblock ATes Bblock Test__CODE_ERREUR__ERREUR07; Eblock ETes RETU_Commande; Eblock ECommande