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

- Compte rendu : SharePoint / O365 : des pratiques pour une meilleure productivité par The Mit's Blog le 12-12-2014, 18:11

- [TFS] Suppression des feature SQL Entreprise en masse par Blog de Jérémy Jeanson le 12-06-2014, 09:18

- [Clean Code] règles de nommage par Fathi Bellahcene le 12-04-2014, 22:59

- Windows To Go 10 et Upgrades impossibles par Blog de Jérémy Jeanson le 12-04-2014, 21:38

- SharePoint OnPremise: Statistiques d’utilisation pour traquer les sites fantomes par Blog Technique de Romelard Fabrice le 12-03-2014, 10:28

- SharePoint 2007: Script PowerShell permettant le backup de toutes les collections de sites d’une application Web par Blog Technique de Romelard Fabrice le 12-02-2014, 10:00

- Xamarin : un choix précieux par .net is good... C# is better ;) le 12-01-2014, 15:10

- Office 365: Comparaison des composants pour préparer votre migration de SharePoint 2007 vers Office 365 par Blog Technique de Romelard Fabrice le 11-28-2014, 16:20

- Créer un périphérique Windows To Go 10 ! par Blog de Jérémy Jeanson le 11-21-2014, 04:54

- RDV à Genève le 12 décembre pour l’évènement “SharePoint–Office 365 : des pratiques pour une meilleure productivité !” par Le blog de Patrick [MVP Office 365] le 11-19-2014, 10:40