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 :

TCheckBox avec les composants Interbase


Sujet :

Composants VCL Delphi

  1. #1
    Membre habitué

    Inscrit en
    Août 2005
    Messages
    253
    Détails du profil
    Informations forums :
    Inscription : Août 2005
    Messages : 253
    Points : 197
    Points
    197
    Par défaut TCheckBox avec les composants Interbase
    Bonjour

    J'utilise un checkbox avec les composants Interbase de Borland, le checkbox ecrit les valeurs dans la table mais à la lecture il n'affiche rien



    Une idée ?

  2. #2
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    104
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 104
    Points : 112
    Points
    112
    Par défaut case grisée
    1) Vérifier si le champ lié au DBCheckBox est null. Si c'est le cas, le composant doit être informé de la façon de représenter une valeur null (grisé par défaut de mémoire).
    2) Vérifier si la propriété AllowGrayed du DBCheckBox est à True. Dans ce cas, la valeur grisée est utilisée pour représenter la valeur null.

    Cdlt

  3. #3
    Membre habitué

    Inscrit en
    Août 2005
    Messages
    253
    Détails du profil
    Informations forums :
    Inscription : Août 2005
    Messages : 253
    Points : 197
    Points
    197
    Par défaut
    Verifié tout est ok
    Champs n'est pas null
    AllowGrayed du DBCheckBox est à True

  4. #4
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    104
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 104
    Points : 112
    Points
    112
    Par défaut
    Le champ lié au DBCheckbox est bien de type booléen ?

  5. #5
    Membre habitué

    Inscrit en
    Août 2005
    Messages
    253
    Détails du profil
    Informations forums :
    Inscription : Août 2005
    Messages : 253
    Points : 197
    Points
    197
    Par défaut
    Y'a pas ce type avec Firebird

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

    Informations forums :
    Inscription : Janvier 2005
    Messages : 104
    Points : 112
    Points
    112
    Par défaut TDBCheckBox.GetFieldState
    La réponse à ton problème est surement dans la méthode suivante :
    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
    function TDBCheckBox.GetFieldState: TCheckBoxState;
    var
      Text: string;
    begin
      if FDatalink.Field <> nil then
        if FDataLink.Field.IsNull then
          Result := cbGrayed
        else if FDataLink.Field.DataType = ftBoolean then
          if FDataLink.Field.AsBoolean then
            Result := cbChecked
          else
            Result := cbUnchecked
        else
        begin
          Result := cbGrayed;
          Text := FDataLink.Field.Text;
          if ValueMatch(FValueCheck, Text) then Result := cbChecked else
            if ValueMatch(FValueUncheck, Text) then Result := cbUnchecked;
        end
      else
        Result := cbUnchecked;
    end;
    Par déduction, ta case est grisée soit :
    1) Ton champ est null
    2) Ton champ n'est pas du type booléen et les valeurs stockées dans ton champ ne correspondent pas aux valeurs des propriétés ValueChecked, ValueUnchecked du TDBCheckBox ...

    Par exemple
    Si ton champ est de type entier, indique 1 pour ValueChecked et 0 pour ValueUnchecked
    Si ton champ est de type chaîne, indique "vrai" pour ValueChecked et "faux" pour ValueUnchecked.
    Bien sûr ce ne sont que des conventions que je donne à titre d'exemple, à toi de choisir quelle est la valeur pour cocher ou pour décocher.

  7. #7
    Membre habitué

    Inscrit en
    Août 2005
    Messages
    253
    Détails du profil
    Informations forums :
    Inscription : Août 2005
    Messages : 253
    Points : 197
    Points
    197
    Par défaut
    Merci, On peut contourner ça avec ses propres procédures & fonctions , le problème que depuis mon passage sous firebird, je ne fais que reprogrammer avec propres fonction, ce ma tracasse énormément vu le temps que ça prend.

    Merci en tout cas.

  8. #8
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    104
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 104
    Points : 112
    Points
    112
    Par défaut
    Citation Envoyé par helmis Voir le message
    On peut contourner ça avec ses propres procédures & fonctions
    Je ne suis pas sûr d'avoir bien compris cette phrase.
    Je pense qu'il n'y a pas de contourner le fonctionnement standard du TDBCheckBox. Il suffit juste de renseigner les propriétés ValueChecked, ValueUnchecked et AllowGrayed pour définir le comportement du composant.

    Si ton champ prend les valeurs de 1 à 5 et que tu veux cocher la case uniquement pour les valeurs 1 et 3, il suffit de renseigner la propriété ValueChecked avec "1;3" et ValueUnchecked avec "2;4;5"

    Cdlt

  9. #9
    Membre habitué

    Inscrit en
    Août 2005
    Messages
    253
    Détails du profil
    Informations forums :
    Inscription : Août 2005
    Messages : 253
    Points : 197
    Points
    197
    Par défaut
    ça ne marche pas, j'ai déjà essayer il faux toucher le checkbox car il a besoin d'un champs booléen pour tourner correctement.

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

    Informations forums :
    Inscription : Janvier 2005
    Messages : 104
    Points : 112
    Points
    112
    Par défaut
    ça ne marche pas, j'ai déjà essayer il faux toucher le checkbox car il a besoin d'un champs booléen pour tourner correctement.
    Ah ? Quels sont les symptomes ? La case reste grisée ?

  11. #11
    Membre habitué

    Inscrit en
    Août 2005
    Messages
    253
    Détails du profil
    Informations forums :
    Inscription : Août 2005
    Messages : 253
    Points : 197
    Points
    197
    Par défaut
    Exactement,Merci pour ton aide.

  12. #12
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 043
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 043
    Points : 40 957
    Points
    40 957
    Billets dans le blog
    62
    Par défaut
    je ne comprends pas . J'utilise les TDBCheckBox sans problèmes avec un Champ ayant les valeurs 'O' ou 'N' déclaré Char(1) en Interbase donc non boolean au sens strict du terme et cela fonctionne parfaitement
    bien sûr si la valeur est null la case est grisée mais là c'est un problème de 'gestion' de Default Value . Dans mon , mes , cas et sauf rares exceptions le champ ne peut avoir que ces deux valeurs (apres tout il n'y a que deux etats possible , coché ou non , 'O' ou 'N',)
    lors de la creation d'un champ de ce type je le declare donc
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    CHAMP_BOOLEAN CHAR(1) NOT NULL DEFAULT 'O'
    , et pour betonner je rajoute une contrainte de valeur
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    CONSTRAINT UNBOOLEAN CHECK CHAMP_BOOLEAN IN ('O','N')
    ou le rattache a un DOMAIN
    MVP Embarcadero
    Delphi installés : D3,D7,D2010,XE4,XE7,D10 (Rio, Sidney), D11 (Alexandria), D12 (Athènes)
    SGBD : Firebird 2.5, 3, SQLite
    générateurs États : FastReport, Rave, QuickReport
    OS : Window Vista, Windows 10, Windows 11, Ubuntu, Androïd

  13. #13
    Membre habitué

    Inscrit en
    Août 2005
    Messages
    253
    Détails du profil
    Informations forums :
    Inscription : Août 2005
    Messages : 253
    Points : 197
    Points
    197
    Par défaut
    C'est résolu après avoir changé le type 'Char' en 'VarChar'.
    Explication ???

Discussions similaires

  1. Gestion des transactions avec les composants DOA
    Par lper dans le forum Bases de données
    Réponses: 2
    Dernier message: 01/12/2008, 16h06
  2. Affichage instable avec les composants SWING
    Par valfajr dans le forum AWT/Swing
    Réponses: 11
    Dernier message: 05/05/2006, 00h04
  3. Problème Update Base de données avec les composants ADO
    Par lingli dans le forum Bases de données
    Réponses: 5
    Dernier message: 20/04/2006, 00h41
  4. Violation d'accès avec les composants Word 97/ 2000
    Par edechaux dans le forum Composants VCL
    Réponses: 3
    Dernier message: 07/03/2006, 09h48
  5. Réponses: 13
    Dernier message: 19/01/2006, 10h06

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