• 2018-11-15-UWP-how-to-get-the-touch-width


    title author date CreateTime categories
    UWP how to get the touch width
    lindexi
    2018-11-15 18:49:12 +0800
    2018-11-06 09:25:23 +0800
    UWP

    The touch width can help us to make a gorgeous application. This article tells you how to get the touch width from the PointEvent in UWP.

    Opening the VisualStudio and create an empty UWP application.

    We should open the MainPage.xaml and add the background in the Grid to make the Grid can get the PointMove event.

        <Grid Background="Transparent">
    
        </Grid>

    Then we can open the MainPage.xaml.cs to write the code to get the PointerMove event.

            public MainPage()
            {
                InitializeComponent();
    
                Content.PointerMoved += MainPage_PointerMoved;
            }
    
            private void MainPage_PointerMoved(object sender, PointerRoutedEventArgs e)
            {
    
            }

    We can use GetCurrentPoint to get the PointerPoint.

            private void MainPage_PointerMoved(object sender, PointerRoutedEventArgs e)
            {
                var point = e.GetCurrentPoint(this);
            }

    And we can find the ContactRect in Properties. We can get the touch width from ContactRect.

            private void MainPage_PointerMoved(object sender, PointerRoutedEventArgs e)
            {
                var point = e.GetCurrentPoint(this);
                Rect rect = point.Properties.ContactRect;
            }

    To get the touch width.

            private void MainPage_PointerMoved(object sender, PointerRoutedEventArgs e)
            {
                var point = e.GetCurrentPoint(this);
                Rect rect = point.Properties.ContactRect;
                Debug.WriteLine($"Touch rect width={rect.Width},height={rect.Height}");
            }

    We also can use ContactRectRaw in Properties.

            private void MainPage_PointerMoved(object sender, PointerRoutedEventArgs e)
            {
                var point = e.GetCurrentPoint(this);
                Rect rect = point.Properties.ContactRect;
                Debug.WriteLine($"Touch rect width={rect.Width},height={rect.Height}");
                rect = point.Properties.ContactRectRaw;
                Debug.WriteLine($"Touch raw rect width={rect.Width},height={rect.Height}");
            }

    Try to run the code and touch the application and you can watch the output windows that prints the touch width.

  • 相关阅读:
    面向对象设计模式之Facade外观模式(结构型)
    Android 多线程:使用Thread和Handler
    Android源码分析之Handler
    Android View的几个位置坐标关系
    LinearLayout布局问题
    Android app被系统kill的场景
    改变Activity启动时的默认动画
    ViewStub源码分析
    Android measure过程分析
    点击ViewGroup时其子控件也变成pressed状态的原因分析及解决办法
  • 原文地址:https://www.cnblogs.com/lindexi/p/12085609.html
Copyright © 2020-2023  润新知