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

Bases de données Delphi Discussion :

Mettre la valeur de OnGetText dans un DBGrid


Sujet :

Bases de données Delphi

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    119
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2003
    Messages : 119
    Par défaut Mettre la valeur de OnGetText dans un DBGrid
    Bonjour à tous,

    Voila, je m'explique, j'ai une procédure OnGetText
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    procedure TDataModule1.IBtblAvenantsPRESTGetText(Sender: TField;
      var Text: String; DisplayText: Boolean);
    begin
      case IBtblAvenantsPREST.AsInteger of
        1: Text := 'A facturer';
        6: Text := 'Annulé';
        8: Text := 'Pas de prestation';
        9: Text := 'Facturé';
      end;
    end;
    et j'utilise une DBGrid dans laquelle j'ai un champ appellé PREST, les valeurs dans PREST peuvent être 1, 6, 8 ou 9, mais j'aimerai affiché dans la DBGrid le texte 'A Facturer' pour 1 , 'Annulé' pour 6, etc...
    Pouvez-vous m'aider?
    Heu si l'explication n'est pas clair, j'essayerai de m'expliquer autrement.

    Merci d'avance.

    Jeankiki

  2. #2
    Modérateur
    Avatar de Rayek
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    5 236
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 236
    Par défaut
    une des possibilité.

    - Tu crées une table TbPrest : Id (entier), Libelle (Chaine de x caractère)
    - Au niveau de de l'affichage dans ta dbgrid, tu fais une requete avec jointure sur la table TbPrest

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
     Select T1.Champ1,T1.Champ2,TP.Libelle from TablePrincipale as T1 inner join TbPrest on T1.Prest = TbPrest.Id
    Puis tu lie ton champ a libellé dans la dbgrid

    L'avantage de cette solution, c'est que si un jour tu as un nouveau type, tu n'as pas besoin de recompiler ton programme mais juste a rajouter une ligne dans la table TbPrest.

    Cela fonctionnera bien sauf si tu fait des actions directes sur les table/query, car il n'est pas possible d'edite/modifier/supprimer dans une requete multi tables
    Modérateur Delphi

    Le guide du bon forumeur :
    __________
    Rayek World : Youtube Facebook

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    119
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2003
    Messages : 119
    Par défaut
    ok, merci pour ta réponse, mais n'y a t'il pas une autre possibilité, je voudrais éviter de créer une nouvelle table; je n'ai aucun problème pour afficher la valeur correct avec un DBText et je voudrais pouvoir faire la même chose dans un DBGrid.

  4. #4
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    119
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2003
    Messages : 119
    Par défaut
    Petite info supplémentaire
    Dans l'évènement OnDrawColumnCell j'ai le code ci-dessous
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    procedure TfrmHistoriqueAvenants.dbgridListeAvenantsDrawColumnCell(
      Sender: TObject; const Rect: TRect; DataCol: Integer; Column: TColumn;
      State: TGridDrawState);
    begin
      if gdSelected in State then
      begin
          TDBGrid(Sender).Canvas.Brush.Color := clBtnFace;  //clInfoBk; //clYellow;
          TDBGrid(Sender).Canvas.Font.Color := clBlack;
          TDBGrid(Sender).Canvas.Font.Style := [fsBold];
      end;
      TDBGrid(Sender).DefaultDrawColumnCell(Rect, DataCol, Column, State);
    end;
    et à mon avis, il doit être possible de faire en sorte que les valeurs apparaissent correctement.

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    119
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2003
    Messages : 119
    Par défaut
    Bon ben voici la solution à mon problème, il faut remplacer
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    IBtblAvenantsPREST.AsInteger
    par
    dans la procédure ci-dessous

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    procedure TDataModule1.IBtblAvenantsPRESTGetText(Sender: TField; 
      var Text: String; DisplayText: Boolean); 
    begin 
      case IBtblAvenantsPREST.AsInteger of 
        1: Text := 'A facturer'; 
        6: Text := 'Annulé'; 
        8: Text := 'Pas de prestation'; 
        9: Text := 'Facturé'; 
      end; 
    end;
    et ajouté la dernière ligne dans le code ci-dessous
    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
     
    procedure TfrmHistoriqueAvenants.dbgridListeAvenantsDrawColumnCell(
      Sender: TObject; const Rect: TRect; DataCol: Integer; Column: TColumn;
      State: TGridDrawState);
    var
      Text: string;
    begin
      if gdSelected in State then
      begin
          TDBGrid(Sender).Canvas.Brush.Color := clBtnFace;  //clInfoBk; //clYellow;
          TDBGrid(Sender).Canvas.Font.Color := clBlack;
          TDBGrid(Sender).Canvas.Font.Style := [fsBold];
      end;
      TDBGrid(Sender).DefaultDrawColumnCell(Rect, DataCol, Column, State);
     
    TDBGrid(Sender).DataSource.DataSet.FieldByName('PREST').OnGetText:= DataModule1.IBtblAvenantsPRESTGetText;
    end;
    Jeankiki

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

Discussions similaires

  1. Mettre une valeur par défaut dans un input type='file'
    Par fab76000 dans le forum Langage
    Réponses: 2
    Dernier message: 27/01/2009, 19h59
  2. Réponses: 10
    Dernier message: 04/11/2008, 14h30
  3. Réponses: 4
    Dernier message: 05/06/2007, 09h16
  4. Réponses: 2
    Dernier message: 03/01/2007, 11h46

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