/*************************************************************************************************************************************/ /* */ /* C A L C U L D E S C O O R D O N N E E S D U C E N T R E D E G R A V I T E : */ /* */ /* */ /* Definition : */ /* */ /* Cette commande calcule les coordonnees */ /* 'X' et 'Y du centre de gravite d'une */ /* image... */ /* */ /* */ /* Author of '$xci/CentreGravite.01$K' : */ /* */ /* Jean-Francois COLONNA (LACTAMME, 20220205094944). */ /* */ /*************************************************************************************************************************************/ /*===================================================================================================================================*/ /*************************************************************************************************************************************/ /* */ /* 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 #include image_image_IMAGESF_EXT /*===================================================================================================================================*/ /*************************************************************************************************************************************/ /* */ /* P A R A M E T R E S : */ /* */ /*************************************************************************************************************************************/ #define EDITER_LES_COORDONNEES_NORMALISEES_DU_CENTRE_DE_GRAVITE \ VRAI \ /* Faut-il editer les coordonnees des points ('VRAI') ou pas ('FAUX') et doivent-elles */ \ /* normalisees ('VRAI') ou denormalisees ('FAUX') ? */ /*===================================================================================================================================*/ /*************************************************************************************************************************************/ /* */ /* M A C R O S U T I L E S : */ /* */ /*************************************************************************************************************************************/ /*===================================================================================================================================*/ /*************************************************************************************************************************************/ /* */ /* C A L C U L D E S C O O R D O N N E E S D U C E N T R E D E G R A V I T E : */ /* */ /*************************************************************************************************************************************/ BCommande(nombre_d_arguments,arguments) /*-----------------------------------------------------------------------------------------------------------------------------------*/ Bblock DEFV(CHAR,INIC(POINTERc(nom_imageA),NOM_PIPE)); DEFV(Logical,INIT(editer_les_coordonnees_normalisees_du_centre_de_gravite ,EDITER_LES_COORDONNEES_NORMALISEES_DU_CENTRE_DE_GRAVITE ) ); /* Faut-il editer les coordonnees des points ('VRAI') ou pas ('FAUX') et doivent-elles */ /* normalisees ('VRAI') ou denormalisees ('FAUX') ? */ /*..............................................................................................................................*/ GET_ARGUMENTSi(nombre_d_arguments ,BLOC(GET_ARGUMENT_C("imageA=""A=",nom_imageA); GET_ARGUMENT_P("seuil=""s=",Icentre_de_gravite_____seuil); GET_ARGUMENT_L("standard=",les_images_sont_standards); GET_ARGUMENT_F("Fseuil=""Fs=",IFcentre_de_gravite_____seuil); GET_ARGUMENT_L("coordonnees_normalisees=""normalisees=""norm=" ,editer_les_coordonnees_normalisees_du_centre_de_gravite ); GET_ARGUMENT_N("coordonnees_denormalisees=""denormalisees=""denorm=" ,editer_les_coordonnees_normalisees_du_centre_de_gravite ); ) ); Test(PAS_D_ERREUR(CODE_ERROR(gIload_image(les_images_sont_standards,ImageA,IFmageA,nom_imageA)))) Bblock /* Chargement de l'image Argument. */ CALS(gIcentre_de_gravite(les_images_sont_standards,ImageA,IFmageA)); Test(IL_FAUT(editer_les_coordonnees_normalisees_du_centre_de_gravite)) Bblock CAL3(Prme1("XG=%+.^^^\n" ,COND(EST_VRAI(les_images_sont_standards) ,Icentre_de_gravite_____coordonnee_X ,IFcentre_de_gravite_____coordonnee_X ) ) ); CAL3(Prme1("YG=%+.^^^\n" ,COND(EST_VRAI(les_images_sont_standards) ,Icentre_de_gravite_____coordonnee_Y ,IFcentre_de_gravite_____coordonnee_Y ) ) ); Eblock ATes Bblock CAL3(Prme1("XG=%d\n" ,COND(EST_VRAI(les_images_sont_standards) ,_cDENORMALISE_OX(Icentre_de_gravite_____coordonnee_X) ,_cDENORMALISE_OX(IFcentre_de_gravite_____coordonnee_X) ) ) ); CAL3(Prme1("YG=%d\n" ,COND(EST_VRAI(les_images_sont_standards) ,_cDENORMALISE_OY(Icentre_de_gravite_____coordonnee_Y) ,_cDENORMALISE_OY(IFcentre_de_gravite_____coordonnee_Y) ) ) ); Eblock ETes Eblock ATes Bblock Test__CODE_ERREUR__ERREUR07; Eblock ETes RETU_Commande; Eblock ECommande