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 :

Champ boolean en clair


Sujet :

Bases de données Delphi

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2005
    Messages
    285
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2005
    Messages : 285
    Points : 74
    Points
    74
    Par défaut Champ boolean en clair
    Bonjour,

    tout d'abord mes meilleurs voeux pour 2007, Pace è Salute à tous
    Bon, voilà mon problème:

    Dans une table, j'ai un champ booléan.
    Dans un DBCtrlGrid je cherche à remplacer le DBCheckBox par un label dans lequel je veux écrire 'Effectué' si le champ est à true et 'non efféctué' si le champ est à false.

    Pour le moment j'ai écrit ce code:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    if tblDetailChantierFait.Value = false then
          frmSuivi.Label1.Caption:='Effectué' 
        else
          frmSuivi.Label1.Caption:='non efféctué' ;
    mais ça ne marche pas car je ne trouve pas dans quel évènement le mettre

    Si quelqu'un à une idée.....

    D'avance merci

    Codial

  2. #2
    Modérateur
    Avatar de Rayek
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    5 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    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 235
    Points : 8 504
    Points
    8 504
    Par défaut
    Dans le OnDrawColumnCell de ta grid

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    With TDbCtrlGrid(Sender) do
    begin
      if tblDetailChantierFait.Value = false then
        Canvas.TextOut(Rect.Left+2,Rect.Top+2,'Effectué')
      else
        Canvas.TextOut(Rect.Left+2,Rect.Top+2,'Non Effectué');
    end;
    Avec ca pas besoin de label (a moins que le DbCtrlGrid fonctionne différement ?)
    Modérateur Delphi

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

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2005
    Messages
    285
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2005
    Messages : 285
    Points : 74
    Points
    74
    Par défaut
    Bonjour Malatar,

    Dommage, après vérification il s'avère que l'évènement OnDrawColumnCell n'existe pas pour un TDbCtrlGrid.
    Merci quand même pour la réponse.

    Je pense qu'il faut le mettre le code dans un évènement du Dataset mais je ne trouve pas lequel!!!

    Une autre idée?

    Codial

  4. #4
    Expert éminent sénior
    Avatar de Cl@udius
    Homme Profil pro
    Développeur Web
    Inscrit en
    Février 2006
    Messages
    4 878
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 4 878
    Points : 10 008
    Points
    10 008
    Par défaut
    Salut

    une idée comme ça: tu te créé un champ calculé en utilisant le code que tu as déjà écris:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
      if tblDetailChantierFait.Value = false then
        tblDetailChantierMonChampCalcule.Value := 'Effectué' 
      else
        tblDetailChantierMonChampCalcule.Value := 'non efféctué' ;
    Ensuite tu poses un TDBText sur ton DBCtrlGrid lié à ce champ calculé.

    @+ Claudius

  5. #5
    Membre éprouvé Avatar de Yurck
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2005
    Messages
    682
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 15
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2005
    Messages : 682
    Points : 912
    Points
    912
    Par défaut
    Bonjour,

    Ou tu modifie le OnGetText de ton champ.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    procedure TDatamodule.tblDetailChantierFaitGetText(Sender: TField;
      var Text: String; DisplayText: Boolean);
    begin
      if tblDetailChantierFait.isnull then
        Text := 'non défini'
      else
      if (tblDetailChantierFait.value = true) then
         Text := 'Effectué'
      else
         Text := 'non efféctué';
    end;

    a+
    Dans le vocabulaire des couturiers seulement, patron est synonyme de modèle.
    Aymond d'Alost

  6. #6
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2005
    Messages
    285
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2005
    Messages : 285
    Points : 74
    Points
    74
    Par défaut
    Bonjour,

    Je vous remercie pour vos solutions, les deux fonctionnent bien.
    J'avais testé la piste de Claudius et c'était bon. Entre temps il y a eu la réponse de Yurck qui me convient bien.

    Encore merci à vous deux.

    Cordialement

    Codial

  7. #7
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2005
    Messages
    285
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2005
    Messages : 285
    Points : 74
    Points
    74
    Par défaut
    Bonjour,
    je reviens sur le sujet.

    Je souhaite affecter une couleur au DBText suivant que le champ est à true ou à false. Voici le code:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    if tblDetailChantierFait.isnull then
        Text := 'non défini'
      else
      if tblDetailChantierFait.value = true then  begin
         Text := 'Effectué';
         frmSuivi.DBText2.Font.Color:=$00000000;//Noir
         end
      else
        begin
        Text := 'A effectuer';
        frmSuivi.DBText2.Font.Color:= $00FF0000 ;//Bleu
        end;
    Or à l'affichage le premier enregistrement est systématiquement bleu bien que le champ soit à true.

    Où est mon erreur?

    D'avance merci

    Codial

  8. #8
    Membre actif Avatar de hugobob
    Profil pro
    FOI
    Inscrit en
    Septembre 2005
    Messages
    169
    Détails du profil
    Informations personnelles :
    Localisation : Gabon

    Informations professionnelles :
    Activité : FOI

    Informations forums :
    Inscription : Septembre 2005
    Messages : 169
    Points : 203
    Points
    203
    Par défaut
    Salut !!!

    je crois c'est parce que tu n'utilises pas un evenement du TDbCtrlGrid pour le realiser . essaye un peu l'evenement quand la fiche se dessine !

    Je fouille !!!!!

  9. #9
    Membre expert
    Avatar de aityahia
    Homme Profil pro
    CIEPTAL CARS SPA
    Inscrit en
    Mars 2006
    Messages
    1 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : Algérie

    Informations professionnelles :
    Activité : CIEPTAL CARS SPA
    Secteur : Transports

    Informations forums :
    Inscription : Mars 2006
    Messages : 1 938
    Points : 3 329
    Points
    3 329
    Par défaut
    utilisé des champs calculer et des champs de référence c'est bien mais
    attentions sa réduit considérablement les performance de votre application.

  10. #10
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2005
    Messages
    285
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2005
    Messages : 285
    Points : 74
    Points
    74
    Par défaut
    Bonjour,

    merci hugobob pour la piste.
    J'avais listé les évènements du TDbCtrlGrid mais je ne m'étais pas attardé sur OnPaintPanel or c'est cet évènement là qui permet de faire ce que je voulais.
    J'y ai mis mon code:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    procedure TfrmSuivi.DBCtrlGrid1PaintPanel(DBCtrlGrid: TDBCtrlGrid;
      Index: Integer);
    begin
    if DM.tblDetailChantierFait.value = true then
        DBText2.Font.Color:=$00000000
      else
        DBText2.Font.Color:= clRed; //$00FF0000 ;
    end;
    et c'est bon ça marche!!!

    Merci à tous les solutions et les pistes

    Cordialement

    Codial

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

Discussions similaires

  1. Erreur sur CREATE TABLE avec champ boolean
    Par codial dans le forum Bases de données
    Réponses: 1
    Dernier message: 23/03/2007, 18h30
  2. Insertion d'un champ boolean
    Par plutonium719 dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 28/07/2006, 13h06
  3. [D6] OndrawColumncell champs boolean: Afficher Icon
    Par Redsky dans le forum Composants VCL
    Réponses: 15
    Dernier message: 05/02/2006, 15h25
  4. Champ boolean
    Par krfa1 dans le forum Requêtes
    Réponses: 2
    Dernier message: 22/09/2005, 12h26
  5. Comment créer un champs " BOOLEAN " dans ACCESS ?
    Par Didier100 dans le forum Bases de données
    Réponses: 3
    Dernier message: 21/10/2004, 11h15

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