/*************************************************************************************************************************************/
/* */
/* R E C H E R C H E D E S N I V E A U X M I N I M U M E T M A X I M U M */
/* P A R R A P P O R T A L A L U M I N A N C E : */
/* */
/* */
/* Definition : */
/* */
/* */
/* Cette commande prend une palette */
/* et recherche les niveaux qui donnent */
/* respectivement la plus basse et la plus */
/* fort luminance. */
/* */
/* */
/* Author of '$xciP/MIN_MAX$K' : */
/* */
/* Jean-Francois COLONNA (LACTAMME, 1989??????????). */
/* */
/*************************************************************************************************************************************/
/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/* */
/* 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 : */
/* */
/*************************************************************************************************************************************/
#define NIVEAU_DE_DEPART \
NOIR
#define NIVEAU_D_ARRIVEE \
BLANC
#define RECHERCHE_DU_MINIMUM \
VRAI
#define RECHERCHE_DU_MAXIMUM \
VRAI
#define AJOUTER_UN_K_LF_A_LA_FIN_DE_L_EDITION \
FAUX \
/* Parametre ajoute le 20080314174739 par symetrie avec '$xciP/G_NIVEAU$K 20080313113656'. */
/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/* */
/* M A C R O S U T I L E S : */
/* */
/*************************************************************************************************************************************/
/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/* */
/* R E C H E R C H E D E S N I V E A U X M I N I M U M E T M A X I M U M */
/* P A R R A P P O R T A L A L U M I N A N C E : */
/* */
/*************************************************************************************************************************************/
BCommande(nombre_d_arguments,arguments)
/*-----------------------------------------------------------------------------------------------------------------------------------*/
Bblock
DEFV(CHAR,INIC(POINTERc(nom_paletteA),NOM_PIPE));
/* Nom de la palette Argument a utiliser. */
DEFV(genere_p,INIT(niveau_de_depart,NIVEAU_DE_DEPART));
DEFV(genere_p,INIT(niveau_d_arrivee,NIVEAU_D_ARRIVEE));
/* Niveaux de depart et d'arrivee pour l'interpolation. */
DEFV(genere_p,INIT(premier_niveau_minimum,NIVEAU_UNDEF));
DEFV(genere_p,INIT(dernier_niveau_maximum,NIVEAU_UNDEF));
/* Niveaux correspondant respectivement a la premiere occurence de la plus faible luminance. */
/* et a la derniere occurence de la plus forte luminance. */
DEFV(Logical,INIT(recherche_du_minimum,RECHERCHE_DU_MINIMUM));
DEFV(Logical,INIT(recherche_du_maximum,RECHERCHE_DU_MAXIMUM));
/* Inidicateur definissant l'extremum (ou les) a rechercher. */
DEFV(Logical,INIT(ajouter_un_K_LF_a_la_fin_de_l_edition,AJOUTER_UN_K_LF_A_LA_FIN_DE_L_EDITION));
/* Parametre ajoute le 20080314174739 par symetrie avec '$xciP/G_NIVEAU$K 20080313113656'. */
DEFV(Float,INIT(luminance_du_niveau_courant,FLOT__UNDEF));
/* Definition de la luminance du niveau courant. */
DEFV(Float,INIT(minimum_de_la_luminance,F_INFINI));
/* Definition de la premiere occurence de la plus faible luminance. */
DEFV(Float,INIT(maximum_de_la_luminance,F_MOINS_L_INFINI));
/* Definition de la derniere occurence de la plus forte luminance. */
/*..............................................................................................................................*/
GET_ARGUMENTSf(nombre_d_arguments
,BLOC(GET_ARGUMENT_C("paletteA=""palette=""pA=""p=",nom_paletteA);
GET_ARGUMENT_L("COMP1=""ROUGE=""TEINT=",files_____manipuler_la_composante_COMP1_d_une_palette_de_couleurs);
GET_ARGUMENT_L("COMP2=""VERTE=""LUMIN=",files_____manipuler_la_composante_COMP2_d_une_palette_de_couleurs);
GET_ARGUMENT_L("COMP3=""BLEUE=""SATUR=",files_____manipuler_la_composante_COMP3_d_une_palette_de_couleurs);
GET_ARGUMENT_P("nD=",niveau_de_depart);
GET_ARGUMENT_P("nA=",niveau_d_arrivee);
GET_ARGUMENT_L("minimum=""m=",recherche_du_minimum);
GET_ARGUMENT_L("maximum=""M=",recherche_du_maximum);
GET_ARGUMENT_L("LF=""K_LF=",ajouter_un_K_LF_a_la_fin_de_l_edition);
)
);
CALS(Iload_palette_de_couleurs(nom_paletteA,ESPACE_DE_COULEURS_RVB));
/* Chargement de la palette de couleurs... */
BoIn(niveau_courant,niveau_de_depart,niveau_d_arrivee,PAS_COULEURS)
Bblock
EGAL(luminance_du_niveau_courant
,CALCUL_DE_LA_LUMINANCE(ACCES_listes_de_substitution(L_SUBSTITUTION_ROUGE,niveau_courant)
,ACCES_listes_de_substitution(L_SUBSTITUTION_VERTE,niveau_courant)
,ACCES_listes_de_substitution(L_SUBSTITUTION_BLEUE,niveau_courant)
)
);
/* Calcul de la luminance de chacun des 'COULEURS' points de l'espace 'RVB'. */
Test(IFLT(luminance_du_niveau_courant,minimum_de_la_luminance))
Bblock
EGAL(minimum_de_la_luminance,luminance_du_niveau_courant);
EGAL(premier_niveau_minimum,niveau_courant);
/* On memorise la premiere occurence (voir le 'IFLT') de la plus basse luminance. */
Eblock
ATes
Bblock
Eblock
ETes
Test(IFGE(luminance_du_niveau_courant,maximum_de_la_luminance))
Bblock
EGAL(maximum_de_la_luminance,luminance_du_niveau_courant);
EGAL(dernier_niveau_maximum,niveau_courant);
/* On memorise la derniere occurence (voir le 'IFGE') de la plus haute luminance. */
Eblock
ATes
Bblock
Eblock
ETes
Eblock
EBoI
Test(IL_FAUT(recherche_du_minimum))
Bblock
CAL3(Prme1("%d ",premier_niveau_minimum));
Eblock
ATes
Bblock
Eblock
ETes
Test(IL_FAUT(recherche_du_maximum))
Bblock
CAL3(Prme1("%d ",dernier_niveau_maximum));
Eblock
ATes
Bblock
Eblock
ETes
Test(IL_FAUT(ajouter_un_K_LF_a_la_fin_de_l_edition))
Bblock
CAL2(Prin0("\n"));
/* Possibilite ajoutee le 20080314174739... */
Eblock
ATes
Bblock
Eblock
ETes
RETU_Commande;
Eblock
ECommande
Copyright © Jean-François COLONNA, 2019-2024.
Copyright © CMAP (Centre de Mathématiques APpliquées) UMR CNRS 7641 / École polytechnique, Institut Polytechnique de Paris, 2019-2024.