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

Composants VCL Delphi Discussion :

changer de couleur dans une cellule stringgrid


Sujet :

Composants VCL Delphi

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    8
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 8
    Points : 7
    Points
    7
    Par défaut changer de couleur dans une cellule stringgrid
    bonjour, voici mon problème, j'ai une grille stringgrid, et lorsque j'insère mes donnée , certaine cellule doivent être rouge et d'autre blanche, mais je reussi seulement avec 1 cellule la première, voici une partie de mon code, ou est mon erreur..??

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
     
    if equipe <> '1' then begin
    coul := true;
    responsable := myROW^[5];
    SQLrech2 :='select * from equipe where id_equipe ="'+equipe+'"';
    if mysql_query(mySQLConnection, pchar(SQLrech2)) = 0 then begin
    myRES2 := mysql_store_result(mySQLConnection);
    if (myRES2 <> nil) then begin
    for z := 0 to myRES2.row_count - 1 do begin
    myROW := mysql_fetch_row(myRES2);
    bStr :=myRow^[1];
    donnee:=bStr +#13#10;
    end;
    end;
     
     
    procedure TForm1.semaineDrawCell(Sender: TObject; ACol, ARow: Integer;
    Rect: TRect; State: TGridDrawState);
    begin
    with Sender as TStringGrid do with Canvas do
    begin
    { Sélection de la couleur de fond }
    if gdFixed in State then
    Brush.Color := clBtnFace
    else if gdSelected in State then
    Brush.Color := clNavy
    else Brush.Color := clWhite;
    if coul = true then begin
    Brush.color := clred;
    coul := false;
    end;
    { Dessin du fond }
    FillRect(Rect);
    { Sélection de la couleur de texte }
    if gdSelected in State then
    SetTextColor(Canvas.Handle,clWhite)
    else SetTextColor(Canvas.Handle,clBlack);
    { Dessin du texte en utilisant la fonction API }
    DrawText(Canvas.Handle, PChar(Cells[ACol,ARow]), -1, Rect ,DT_NOPREFIX or DT_WORDBREAK );
    end;
    end;
    seul la couleur de une cellule change, les autre reste blanche, et de plus la boolean coul, reste a false, pourtant apres la premiere implementation elle est a true

    merci de votre aide

  2. #2
    Expert confirmé
    Avatar de anapurna
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2002
    Messages
    3 419
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 419
    Points : 5 818
    Points
    5 818
    Par défaut
    salut

    utilise plutot les colonne et les ligne pour definir tes couleur
    car le gselected ne fonction que sur une case

    @+ Phil
    Nous souhaitons la vérité et nous trouvons qu'incertitude. [...]
    Nous sommes incapables de ne pas souhaiter la vérité et le bonheur, et sommes incapables ni de certitude ni de bonheur.
    Blaise Pascal
    PS : n'oubliez pas le tag

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    8
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 8
    Points : 7
    Points
    7
    Par défaut
    bonjour

    en pratique je n'ai pas besoin du gselected j'ai essayer d'enlever les concordance mais rien fait, je croit que mon problème se situe au niveau de ma variable coul (boolean), car a la première itération, est elle a true, mais dans les autre itération est est a false, dite moi je je me trompe, est ce que la fonction drawcell fonctionne après TOUTES les itération de cellule, ou bien a chaque écriture de cellule..???

    merci

  4. #4
    Expert confirmé
    Avatar de anapurna
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2002
    Messages
    3 419
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 419
    Points : 5 818
    Points
    5 818
    Par défaut
    saalut ,

    ondrawcell est declanche au momment de dessinner la cellule
    parcontre il est evident que si l'equipe n'est pas egale a 1
    la mise a jour de tes couleur ne seras fait que sur une cellule

    @+ Phil
    Nous souhaitons la vérité et nous trouvons qu'incertitude. [...]
    Nous sommes incapables de ne pas souhaiter la vérité et le bonheur, et sommes incapables ni de certitude ni de bonheur.
    Blaise Pascal
    PS : n'oubliez pas le tag

  5. #5
    Membre confirmé
    Avatar de Philippe Gormand
    Inscrit en
    Mars 2002
    Messages
    330
    Détails du profil
    Informations forums :
    Inscription : Mars 2002
    Messages : 330
    Points : 647
    Points
    647
    Par défaut Bonsoir
    Si cela peut t'aider ou t'orienter :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    // Changer les couleurs de collones ou des ligne d'un TstringGrid
    
    Procedure TForm1.Grille1DrawCell(Sender: TObject; Col, Row: Longint;Rect: TRect; State: TGridDrawState);
    // Dans cet Exemple, la procedure colorie les Collones 2 et 5 en jaune.
    Var
       X,Y : Integer;
       S   : String;
    
    Begin
       If (Col In[2,5]) And (Row > 0) Then
        With Grille1.Canvas Do
         Begin
            If Not (gdSelected In state) Then
             Begin
                Pen.Style:=psClear;
                Brush.Style:=bsSolid;
                Brush.Color:=clYellow;
                Rectangle(Rect.Left,Rect.Top,Rect.Right,Rect.Bottom);
             End;
            s:=Grille1.Cells[Col,Row];
            x:=2+Rect.Left;
            y:=1+Rect.Top+(Rect.Bottom-Rect.Top-TextHeight(s))div 2;
            Font.Style:=[fsBold];
            TextOut(x,y,s);
            Pen.Style:=psSolid;
         End;
    End;
    A +
    Rien n'est moins sur que l'incertain : Pierre DAC

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 12/03/2011, 16h42
  2. Modifier la couleur du texte dans une cellule StringGrid
    Par Jotomaticen dans le forum C++Builder
    Réponses: 3
    Dernier message: 22/09/2009, 22h42
  3. Changer la couleur d'une cellule dans une table
    Par gbrion dans le forum WinDev
    Réponses: 4
    Dernier message: 26/04/2007, 21h55
  4. Changer la couleur d'une cellule specifique d'une stringgrid
    Par jamah dans le forum Composants VCL
    Réponses: 5
    Dernier message: 26/01/2006, 17h13
  5. mettre de la couleur dans une cellule
    Par Jiraiya42 dans le forum Balisage (X)HTML et validation W3C
    Réponses: 4
    Dernier message: 03/06/2005, 10h16

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