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

Windows Presentation Foundation Discussion :

Layout de liste


Sujet :

Windows Presentation Foundation

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    134
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 134
    Par défaut Layout de liste
    Bonjour,

    J'ai encore un peu de mal à discerner les différentes possibilités de WPF, aussi j'aimerais votre avis sur une question architecture

    J'ai une liste d'élément que je dois présenter dans au moins 3 listes d'aspect différents


    J'aimerais donc fait une classe commune "carrousel" qui à partir de cette liste et d'une propriété du genre "display" afficherait la liste sous une forme ou une autre.

    En fouillant sur le net je tombe sur tout un tas de concept : datatemplate, itemControl, itemPresenter, contentPresenter, itemContent...

    bref je nage, je sais qu'est-ce qui fait quoi comment, et tout les noms se ressemble...
    Donc plutôt que de partir dans toutes les directions, j'aimerais qu'on me dise une façon de faire "élégante", et je me concentrerais sur celle là.

    voili voilà

  2. #2
    Rédacteur
    Avatar de Thomas Lebrun
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    9 161
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 9 161
    Par défaut
    Pour moi, je vois un contrôle de type ItemsControl avec 3 ItemTemplate différents.

  3. #3
    Membre expérimenté

    Profil pro
    Inscrit en
    Septembre 2005
    Messages
    214
    Détails du profil
    Informations personnelles :
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Septembre 2005
    Messages : 214
    Par défaut
    Pour le contrôle à choisir:

    • si tu veux gérer la notion de sélection, alors utilise un ListBox
    • sinon utilises un ItemsControl

    Pour le rendu graphique de tes élements, tu as plusieurs possibilités.

    • si tes éléments sont des classes différentes (classe mère ItemBase + Item1, Item2 et Item3 qui en héritent)

    Tu peux utiliser un DataTemplate en spécifiant TargetType. Tu crée ainsi 3 DataTemplate (pour Item1, Item2 et Item3). Ton ItemsControl utilisera alors automatiquement le bon DataTemplate en fonction du type de l'objet (Item1, Item2 ou Item3).

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    <Window.Resources>
      <DataTemplate TargetType={x:Type Item1}>
       ...
      </DataTemplate>
      <DataTemplate TargetType={x:Type Item2}>
       ...
      </DataTemplate>
      <DataTemplate TargetType={x:Type Item3}>
       ...
      </DataTemplate>
    </Window.Resources>
    • si tes éléments sont dans la même classe, et que tu les distingues par une propriété (par exemple Display qui vaut 1, 2 ou 3)

    Tu peux utiliser un seul DataTemplate que tu associes à la propriété ItemTemplate du ton ItemsControl. Tu peux ensuite utiliser un DataTrigger pour tester la valeur de la propriété Display et faire varié l'affichage en fonction.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    <DataTemplate x:key="dt">
        ...
        <DataTemplate.DataTrigger>
          <DataTrigger Property="Display" Value="1">
            <Setter ... />
          </DataTrigger>
        </DataTemplate.DataTrigger>
    </DataTemplate>
     
    <ItemsControl ... ItemTemplate={StaticResource dt}/>
    Dans les 2 cas, pour remplir le contrôle (ListBox ou ItemsControl) utilises une ObservableCollection que tu associes à la propriété ItemsSource par binding.

  4. #4
    Rédacteur
    Avatar de Thomas Lebrun
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    9 161
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 9 161
    Par défaut
    Citation Envoyé par Jérem22 Voir le message
    Tu peux utiliser un seul DataTemplate que tu associes à la propriété ItemTemplate du ton ItemsControl. Tu peux ensuite utiliser un DataTrigger pour tester la valeur de la propriété Display et faire varié l'affichage en fonction.
    Je trouver, personnellement, cette technique un peu plus lourde à mettre en place... Je préfère la première suggestion, celle avec les 3 DataTemplates.

  5. #5
    Membre expérimenté

    Profil pro
    Inscrit en
    Septembre 2005
    Messages
    214
    Détails du profil
    Informations personnelles :
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Septembre 2005
    Messages : 214
    Par défaut
    Effectivement, ça dépend des cas

    Si on veut juste changer une couleur alors c'est aussi plus lourd d'avoir 2x le même DataTemplate (à la couleur pret).

  6. #6
    Membre confirmé
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    134
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 134
    Par défaut
    Et en fait c'est quoi la différence entre un DataTemplate et un ControleTemplate ?
    C'est juste que le controleTemplate est appliqué à un UserControle et que le DataTemplate peut être associé à n'importe quel class ?


    Sinon les DataTemplates dont vous me parlez, sont ceux définit pour les items de ma liste. Pour personnaliser l'arrangement de mes items dans ma listBox ou mon ItemsControl c'est en surchargeant les méthodes MeasureOverride et ArrangeOverride c'est ça ?

  7. #7
    Membre expérimenté

    Profil pro
    Inscrit en
    Septembre 2005
    Messages
    214
    Détails du profil
    Informations personnelles :
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Septembre 2005
    Messages : 214
    Par défaut
    Un DataTemplate sert à donner une réprésentation visuelle à une classe. Un ControlTemplate sert à donner un visuel à un contrôle (par exemple dans le ControlTemplate d'un ListBox, on trouve un ScrollViewer, des ScrollBars, etc.).

    Pour jouer sur l'arrangement de tes items, utilises la propriété ItemsPanel. Par défaut, c'est un VirtualizingStackPanel, mais tu peux mettre n'importe quel panel dedans

Discussions similaires

  1. [Struts-Layout] deux listes dans un formulaire
    Par pigeon11 dans le forum Struts 1
    Réponses: 1
    Dernier message: 28/09/2007, 09h54
  2. Réponses: 2
    Dernier message: 29/06/2007, 11h20
  3. [Struts-Layout] Listes liées
    Par verdi-verda dans le forum Struts 1
    Réponses: 1
    Dernier message: 22/06/2007, 22h15
  4. [Struts-Layout] liste deroulante
    Par david06600 dans le forum Struts 1
    Réponses: 32
    Dernier message: 07/10/2006, 13h43
  5. Réponses: 6
    Dernier message: 27/03/2006, 19h11

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