Door het GridView met de muis scrollen

Wanneer je naar het Start scherm van Windows 8 krijgt heeft deze een paar mooie unieke features die niet standaard met het GridView control meekomen.

 

Zo heb je type to search. Hiermee kan je gewoon gaan typen in het start scherm en vervolgens word de search geactiveerd. Hoe je dit in jouw app kan ontwikkelen heb ik hier beschreven: http://www.familie-smits.com/post/2012/08/12/Type-to-search-in-Windows-8.aspx

 

Een andere mooie feature is dat je in het startscherm kan scrollen door je muis aan de zijkant van scherm houden en dan de muis naar blijft bewegen wat dan het GridView laat scrollen.

 

Ik heb een uitbreiding gemaakt op het GridView dat dit mogelijk maakt in je eigen app, de code van het control:

 

public class VariableSizeGridView : GridView
{
    private ScrollViewer scrollViewer;

    public VariableSizeGridView()
    {
        MouseDevice.GetForCurrentView().MouseMoved += VariableSizeGridView_MouseMoved;
    }

    protected override void OnApplyTemplate()
    {
        base.OnApplyTemplate();
        scrollViewer = GetVisualChild<ScrollViewer>(this);
    }

    private void VariableSizeGridView_MouseMoved(MouseDevice sender, MouseEventArgs args)
    {
        if (Window.Current.CoreWindow.PointerPosition.X == Window.Current.CoreWindow.Bounds.Left)
        {
            if (args.MouseDelta.X < 0)
            {
                scrollViewer.ScrollToHorizontalOffset(scrollViewer.HorizontalOffset + args.MouseDelta.X);
            }
        }

        if (Window.Current.CoreWindow.PointerPosition.X == Window.Current.CoreWindow.Bounds.Right - 1)
        {
            if (args.MouseDelta.X > 0)
            {
                scrollViewer.ScrollToHorizontalOffset(scrollViewer.HorizontalOffset + args.MouseDelta.X);
            }
        }
    }

    private T GetVisualChild<T>(DependencyObject parent) where T : DependencyObject
    {
        T child = default(T);
        int numVisuals = VisualTreeHelper.GetChildrenCount(parent);
        for (int i = 0; i < numVisuals; i++)
        {
            DependencyObject v = (DependencyObject)VisualTreeHelper.GetChild(parent, i);
            child = v as T;
            if (child == null)
                child = GetVisualChild<T>(v);
            if (child != null)
                break;
        }
        return child;
    }
}

 

  •   cute how @MicrosoftTeams restart due a glitch when you close the app... makes me wonder what they think the glitch… https://t.co/2TwilGiy1F
  •   Goodie incoming :)
  •   @danhellem @AzureDevOps awesome! :)
  •   @sandeepchads @AzureDevOps it's not there anymore; the morning i had the feature had a banner in the top of the page that had a button "try"
  •   @sandeepchads @AzureDevOps I had the feature yesterday morning on my environment and in the evening it was gone again 😭
  •   @markscholman @windowsdev Thanks! Jij ook!
  •   Another year @windowsdev MVP #MVPBuzz https://t.co/blu1TMBO0E
  •   RT @kevintgallo: Check it out https://t.co/F9exR1pQMx
  •   RT @stanzillaz: The new Windows Terminal is now on the Store https://t.co/n8rjsg19dv #WindowsInsiders
  •   @tfsbuck maybe not that clear as i was using my phone. in the release note notification I still see the annoucement… https://t.co/tx8DDm36q8