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

Concepteur LiveBindings XE3 : lier un contrôle de liste à un champ

Ceci est la traduction du billet de Jim Tierney sur le Concepteur LiveBindings XE3 portant sur la liaison d'une zone de liste à un champ de source de données.

Article lu   fois.

L'auteur

Profil ProSite personnel

Liens sociaux

Viadeo Twitter Facebook Share on Google+   

I. Introduction

Les contrôles de liste peuvent être liés aux sources de données. TListBox, TComboBox, et TListView de la VCL sont des exemples de contrôles de liste. Lorsqu'un contrôle de liste est lié à un champ d'une source de données, l'élément sélectionné dans le contrôle de liste correspond à la valeur de la source de données. Pour changer la valeur du champ, l'utilisateur peut sélectionner un autre élément du contrôle de liste.

En pratique, deux sources de données sont utilisées avec un contrôle de liste. La première source de données fournit la valeur sélectionnable du contrôle et la seconde la liste des éléments que contiendra la liste. LiveBindings les appelle respectivement « DataSource » et « FillDataSource ».

Le TPrototypeBindSource est un moyen simple permettant de créer des sources de données. Nous pouvons configurer un TPrototypeBindSource comme « DataSource » (source des données) et un autre comme étant le « FillDataSource » (source de remplissage de la liste).

La miniapplication que nous allons développer à la suite nous montrera comment lier une zone de liste visuellement à deux sources de données.

II. Construction de l'application

En premier lieu, créer la source des données de la liste

  1. Créer un nouveau projet de type Application VCL.
  2. Déposer un composant TPrototypeBindSource sur le formulaire.
  3. Dans l'inspecteur d'objets, définir la propriété PrototypeBindSource1.RecordCount à 10.
  4. Ajouter un champ « ColorsName » au TPrototypeBindSource (voir cet article pour plus de détails).

Ensuite, créer la source de données de remplissage de la liste

  1. Déposer un second TPrototypeBindSource sur le formulaire.
  2. Dans l'inspecteur d'objets, lui donner le nom de « PrototypeBindSourceFill ».
  3. Ajouter un champ « ColorsName » au composant.
  4. Nommer le nouveau champ « AColorsName ».
  5. Décocher les cases « Shuffle » et « Repeat » afin de générer une liste ordonnée de valeurs uniques
Image non disponible

Déposer ensuite une TListBox sur le formulaire

Image non disponible

Afficher le concepteur LiveBindings à l'aide du menu « Voir/Concepteur LiveBindings ».

Image non disponible

Le composant ListBox1 est affiché dans le concepteur avec trois membres : « SelectedValue », « Item.Text » et « Item.LookupData ».
Lier « PrototypeBindSource1.ColorsName » à « ListBox1.SelectedValue »
Lier « PrototypeBindSourceFill.AColorsName » à « ListBox1.Item.Text ».

Image non disponible

L'on se rend compte que la zone de liste est remplie dans le concepteur VCL.

Image non disponible

L'élément « Darkgreen » est sélectionné, car la valeur du champ « ColorsName1 » dans le premier TPrototypeBindSource1 est « Darkgreen ».
Faire un clic droit sur le composant TPrototypeBindSource1 et sélectionner l'option « Ajouter un navigateur » pour rajouter un navigateur sur le formulaire. À présent notre application est prête à être exécutée.

Image non disponible

La sélection dans la ListBox changera au fur et à mesure que l'utilisateur change l'enregistrement actif à l'aide du navigateur.
Un TLabeledEdit a été ajouté afin de montrer comment la sélection d'une valeur dans la ListBox change la valeur du champ.

Voici le schéma final du concepteur LiveBindings.

Image non disponible

Le prochain article décrira comment utiliser le membre « Item.LookupData » afin de créer une liste de recherche.

Vous avez aimé ce tutoriel ? Alors partagez-le en cliquant sur les boutons suivants : Viadeo Twitter Facebook Share on Google+