Bienvenue à Blogs CodeS-SourceS Identification | Inscription | Aide

Thomas Lebrun

Tout sur WPF, LINQ, C# et .NET en général !

Actualités

[WP7/Silverlight] Détecter la fin du scroll d’une ListBox
Pour les besoins d’un projet récent sur Windows Phone 7, le client souhaitait faire en sorte que lorsque l’utilisateur ait fini de scroller dans sa ListBox, si celle-ci se trouve être à la fin, alors on ré-interroge la source de données pour récupérer d’autres data et les injecter dans le contrôle.
Pour faire simple, imaginer une ListBox infinie mais avec de la pagination In love

Pour mettre en place cela, c’est tout simple. En effet, le code suivant permet d’accéder à la Scrollbar interne à la Listbox et de s’abonner à son évènement ValueChanged. Dans la callback, on regarde si la valeur actuelle correspond bien à la propriété Maximum de la Scrollbar, et le tour est joué:

   1: private double _lastScrollbarValue;
   2:  
   3: void ListBoxLoaded(object sender, RoutedEventArgs e)
   4: {
   5:     if(_scrollBar != null)
   6:         _scrollBar.ValueChanged -= ScrollBarValueChanged;
   7:  
   8:     _scrollBar = _listBox.GetChildrenByType<ScrollBar>(s => s.Name == "VerticalScrollBar").FirstOrDefault();
   9:  
  10:     if (_scrollBar != null)
  11:         _scrollBar.ValueChanged += ScrollBarValueChanged;
  12: }
  13:  
  14: void ScrollBarValueChanged(object sender, RoutedPropertyChangedEventArgs<double> e)
  15: {
  16:     if (e.NewValue == _scrollBar.Maximum && e.NewValue != _lastScrollbarValue)
  17:     {
  18:         // Here, load more data !
  19:     }
  20:  
  21:     _lastScrollbarValue = e.NewValue;
  22: }
Simple comme tout mais pourtant très pratique Winking smile

 

A+

Ce post vous a plu ? Ajoutez le dans vos favoris pour ne pas perdre de temps à le retrouver le jour où vous en aurez besoin :
Posted: mercredi 13 avril 2011 10:52 par Thomas LEBRUN

Commentaires

SlimH2S a dit :

Salut,

J'ai eu à faire la même chose dans un projet où l'on devait charger les éléments suivants à partir d'ODATA quand l'utilisateur s'approche trop près du bas du ListBox. D'ailleurs ce principe est utilisé par Facebook et Twitter pour charger la liste des publications. ;-)

# avril 16, 2011 23:56

SlimH2S a dit :

Salut,

J'ai eu à faire la même chose dans un projet où l'on devait charger les éléments suivants à partir d'ODATA quand l'utilisateur s'approche trop près du bas du ListBox. D'ailleurs ce principe est utilisé par Facebook et Twitter pour charger la liste des publications. ;-)

# avril 17, 2011 00:11

Jeemys a dit :

Hello,

J'ai l'impression que ta solution n'est pas complète, enfin j'ai des erreurs quand je copie le code (pas évident pour des débutants comme moi).

Si tu peux donner un peu plus de précision ce serait sympa. Merci toutefois pour ce tuto.

# mars 16, 2012 00:19
Les commentaires anonymes sont désactivés

Les 10 derniers blogs postés

- [ #Yammer ] From Mailbox to Yammer and back / De votre messagerie vers Yammer et retour ! par Le blog de Patrick [MVP SharePoint] le 09-15-2014, 11:31

- [ #Office 365 ] New service settings panel / Nouveau panneau de paramétrage des services par Le blog de Patrick [MVP SharePoint] le 09-11-2014, 08:50

- Problème de déploiement pour une démo SharePoint/TFS? par Blog de Jérémy Jeanson le 09-10-2014, 21:52

- [ #Office365 ] Delve first impressions / Premières impressions sur Delve par Le blog de Patrick [MVP SharePoint] le 09-09-2014, 16:57

- [ #Office365 ] How to change Administration console language ? / Comment changer la langue de la console d’administration ? par Le blog de Patrick [MVP SharePoint] le 09-09-2014, 08:25

- [ #SharePoint 2013 ] Suppression de bases de données en état “Pas de Réponse” par Le blog de Patrick [MVP SharePoint] le 09-04-2014, 14:10

- Changer l’adresse d’une ferme Office Web Apps associée à SharePoint par Blog de Jérémy Jeanson le 09-01-2014, 22:21

- Une ferme #SharePoint 2013 dans @Azure en quelques clics (1ère partie) ! par Le blog de Patrick [MVP SharePoint] le 08-28-2014, 18:52

- SharePoint 2013: Préparation de la migration - Création des site Templates dans 2010 et 2013 par Blog Technique de Romelard Fabrice le 08-20-2014, 16:31

- [ #Yammer ] How to change interface language ? Comment changer la langue de l’interface ? par Le blog de Patrick [MVP SharePoint] le 08-20-2014, 14:21