IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

WinDev Discussion :

Comment colorier une cellule de table par programation [WD14]


Sujet :

WinDev

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    39
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2009
    Messages : 39
    Points : 31
    Points
    31
    Par défaut Comment colorier une cellule de table par programation
    Comment colorier une cellule de table par programation:
    j'ai un table qui contient:
    1-Colonne liste des étudiants.
    2 Colonne Moyenne d'étudiants.
    3-Colonne statut (si l'étudient à une moyenne <10 la cellule de cette colonne qui correspond à ce étudient qui n'as pas de moyenne devient rouge . sinon vert)

    RQ: j'arrive à faire un code qui permet de colorer tout la ligne avec la fonction ("..CouleurFond=rouge"). mais j'aime bien colorer qu'une seul cellule

    merci d'avance .

  2. #2
    Membre éclairé Avatar de Raptor92
    Homme Profil pro
    Directeur des opérations & Innovation
    Inscrit en
    Juin 2009
    Messages
    972
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Directeur des opérations & Innovation
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2009
    Messages : 972
    Points : 766
    Points
    766
    Par défaut
    Bonjour,

    Dans "l'affichage d'une ligne" de votre table:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    i est un entier
    POUR i = 1 _A_ TableOccurrence(TABLE_STOCKS,toTotal)
    	SI TABLE_STOCKS.COL_QTE[i]..Valeur <> 0 ALORS
    		TABLE_STOCKS.COL_ARTICLE[i]..CouleurFond = VertClair
    	SINON SI TABLE_STOCKS[i]..Valeur = 0 ALORS
    		TABLE_STOCKS.COL_ARTICLE[i]..CouleurFond = Transparent
     
     
    	FIN
    FIN
    Bien entendu il vous faudra changer les noms et les adapter à votre table
    Dans mon cas cela fonctionne

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    39
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2009
    Messages : 39
    Points : 31
    Points
    31
    Par défaut
    Parfait Raptor92 Merci

  4. #4
    Membre éprouvé
    Homme Profil pro
    Inscrit en
    Mars 2002
    Messages
    899
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations forums :
    Inscription : Mars 2002
    Messages : 899
    Points : 1 103
    Points
    1 103
    Par défaut
    Citation Envoyé par Raptor92 Voir le message
    Dans "l'affichage d'une ligne" de votre table:
    Heu, là je suis pas vraiment d'accord...
    Le fait de se placer dans l'évènement "Affichage d'une ligne", appelle automatiquement l'évènement pour chaque ligne affichée.
    Donc :
    • Soit on fait l'instruction sur l'évènement "affichage d'une ligne", sans placer la boucle autour :
      Code de l'évènement "Affichage d'une ligne" : Sélectionner tout - Visualiser dans une fenêtre à part
      1
      2
      3
      4
       
      	SI TABLE_STOCKS.COL_QTE[i]..Valeur <> 0 ALORS
      		TABLE_STOCKS.COL_ARTICLE[i]..CouleurFond = VertClair
      	FIN
    • Soit on fait l'instruction sur une procédure externe à cet évènement, qu'on appelle par exemple après avoir remplit la table. Dans ce cas on place la boucle pour parcourir toutes les lignes
      Code de la procédure "ColorerColonne()" : Sélectionner tout - Visualiser dans une fenêtre à part
      1
      2
      3
      4
      5
      6
       
      POUR i = 1 _A_ TableOccurrence(TABLE_STOCKS,toTotal)
      	SI TABLE_STOCKS.COL_QTE[i]..Valeur <> 0 ALORS
      		TABLE_STOCKS.COL_ARTICLE[i]..CouleurFond = VertClair
      	FIN
      FIN

    Le fait de faire la boucle dans l'évènement "Affichage d'une ligne" fonctionne parfaitement, mais il parcourt toutes les lignes plusieurs fois, ce qui est vraiment pénalisant quand on a beaucoup de lignes.

  5. #5
    Inactif  
    Profil pro
    Inscrit en
    Février 2003
    Messages
    4 341
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2003
    Messages : 4 341
    Points : 5 953
    Points
    5 953
    Par défaut
    Attention ! Si la table est une table fichier, il faut absolument passer par la méthode "Affichage d'une ligne, et évidemment, ne traiter qu'une ligne à la fois.. Celle affichée !

  6. #6
    Expert confirmé
    Homme Profil pro
    ?
    Inscrit en
    Juillet 2002
    Messages
    2 379
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : ?

    Informations forums :
    Inscription : Juillet 2002
    Messages : 2 379
    Points : 4 496
    Points
    4 496
    Par défaut
    Bonjour

    Bowen, tu as tout a fait raison, mais tu as oublié d'enlever le [i] et d'ajouter l'indice de la ligne en cours pour la couleur
    Code de l'évènement "Affichage d'une ligne" : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SI TABLE_STOCKS.COL_QTE..Valeur <> 0 ALORS
       TABLE_STOCKS.COL_ARTICLE[TABLE_STOCKS]..CouleurFond = VertClair
    FIN

  7. #7
    Membre éprouvé
    Homme Profil pro
    Inscrit en
    Mars 2002
    Messages
    899
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations forums :
    Inscription : Mars 2002
    Messages : 899
    Points : 1 103
    Points
    1 103
    Par défaut
    Heu oui, ça sent le mauvais copier-coller ça...
    à noter que je remplacerais par IndiceEnCours() pour le numéro de ligne (ça ne change pas grand chose lors du parcours initial, mais lorsqu'on affiche une partie non visible du tableau, on ré-execute le code "affichage d'un ligne, et on colore alors la dernière ligne du tableau selon la règle énoncée actuellement).
    La bonne syntaxe, c'est donc :
    Code de la procédure "affichage d'une ligne" : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SI TABLE_STOCKS.COL_QTE <> 0 ALORS TABLE_STOCKS.COL_ARTICLE[IndiceEnCours]..CouleurFond = VertClair

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Colorier une cellule par copier-coller
    Par forum2015 dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 12/08/2014, 18h33
  2. rentrer dans une cellule de table par prog
    Par hehehe dans le forum WinDev
    Réponses: 3
    Dernier message: 22/10/2010, 16h00
  3. Réponses: 2
    Dernier message: 06/05/2009, 16h43
  4. [2.0 DataGridView] comment sélectionner une cellule par le code
    Par juniorAl dans le forum Windows Forms
    Réponses: 5
    Dernier message: 01/07/2008, 20h46

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo