Ағылшын тілінде оқу

Бөлісу құралы:


TouchFrameEventArgs Класс

Определение

Предоставляет данные о событии FrameReported.

public sealed class TouchFrameEventArgs : EventArgs
Наследование
TouchFrameEventArgs

Примеры

В следующем примере выполняется обработка FrameReported события и доступ к сенсорным данным в TouchFrameEventArgs. При нажатии касания на Canvasобъект TouchDevice захватывается Canvasв . При снятии TouchDevice касания объект освобождается. При перемещении сенсорного Canvasввода по объекту Id проверяется . Если перемещение произошло при первом касании, его расположение записывается. Если перемещение произошло от второго касания, линия рисуется от позиции первого касания до позиции второго касания.

Этот пример является частью более крупного примера, доступного в обзоре Touch класса.

public partial class MainWindow : Window
{
    // Variables for tracking the position of two points.
    Point pt1, pt2 = new Point();
    
    public MainWindow()
    {
        InitializeComponent();
        Touch.FrameReported += new TouchFrameEventHandler(Touch_FrameReported);
    }

    void Touch_FrameReported(object sender, TouchFrameEventArgs e)
    {
        if (this.canvas1 != null)
        {
            foreach (TouchPoint _touchPoint in e.GetTouchPoints(this.canvas1))
            {
                if (_touchPoint.Action == TouchAction.Down)
                {
                    // Clear the canvas and capture the touch to it.
                    this.canvas1.Children.Clear();
                    _touchPoint.TouchDevice.Capture(this.canvas1);
                }

                else if (_touchPoint.Action == TouchAction.Move && e.GetPrimaryTouchPoint(this.canvas1) != null)
                {   
                    // This is the first (primary) touch point. Just record its position.
                    if (_touchPoint.TouchDevice.Id == e.GetPrimaryTouchPoint(this.canvas1).TouchDevice.Id)
                    {
                        pt1.X = _touchPoint.Position.X;
                        pt1.Y = _touchPoint.Position.Y;
                    }

                    // This is not the first touch point. Draw a line from the first point to this one.
                    else if (_touchPoint.TouchDevice.Id != e.GetPrimaryTouchPoint(this.canvas1).TouchDevice.Id)
                    {
                        pt2.X = _touchPoint.Position.X;
                        pt2.Y = _touchPoint.Position.Y;

                        Line _line = new Line();
                        _line.Stroke = new RadialGradientBrush(Colors.White, Colors.Black);
                        _line.X1 = pt1.X;
                        _line.X2 = pt2.X;
                        _line.Y1 = pt1.Y;
                        _line.Y2 = pt2.Y;
                        _line.StrokeThickness = 2;
                        this.canvas1.Children.Add(_line);
                    }
                }

                else if (_touchPoint.Action == TouchAction.Up)
                {
                    // If this touch is captured to the canvas, release it.
                    if (_touchPoint.TouchDevice.Captured == this.canvas1)
                    {
                        this.canvas1.ReleaseTouchCapture(_touchPoint.TouchDevice);
                    }
                }
            }                        
        }
    }
}

Комментарии

Событие FrameReported включается в Windows Presentation Foundation (WPF) для поддержки совместимости с Silverlight. Если вам не нужно обеспечивать совместимость с Silverlight, используйте события касания, такие как TouchDown и TouchMove, в UIElement, UIElement3Dили ContentElement.

Используйте для TouchFrameEventArgs получения значений TouchPoint , относящихся к событию сенсорного ввода. С помощью TouchPointможно получить Position объект сенсорного ввода и определить, было Downли TouchAction действие , Moveили Up . Вы также можете использовать для TouchPoint получения TouchDevice. С помощью TouchDeviceможно определить устройство Id и получить сведения об элементе, к которому относится.

Свойства

Timestamp

Получает отметку времени данного события.

Методы

Equals(Object)

Определяет, равен ли указанный объект текущему объекту.

(Унаследовано от Object)
GetHashCode()

Служит хэш-функцией по умолчанию.

(Унаследовано от Object)
GetPrimaryTouchPoint(IInputElement)

Возвращает текущую сенсорную точку основного сенсорного устройства относительно заданного элемента.

GetTouchPoints(IInputElement)

Возвращает коллекцию, которая содержит текущую сенсорную точку для каждого активного сенсорного устройства, имеющего отношение к заданному элементу.

GetType()

Возвращает объект Type для текущего экземпляра.

(Унаследовано от Object)
MemberwiseClone()

Создает неполную копию текущего объекта Object.

(Унаследовано от Object)
SuspendMousePromotionUntilTouchUp()

Этот член не реализован.

ToString()

Возвращает строку, представляющую текущий объект.

(Унаследовано от Object)

Применяется к

Өнім Нұсқалар
.NET Framework 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
Windows Desktop 3.0, 3.1, 5, 6, 7, 8, 9