1 #ifndef DALI_INTERNAL_EVENT_PINCH_GESTURE_RECOGNIZER_H
2 #define DALI_INTERNAL_EVENT_PINCH_GESTURE_RECOGNIZER_H
5 * Copyright (c) 2020 Samsung Electronics Co., Ltd.
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
11 * http://www.apache.org/licenses/LICENSE-2.0
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
22 #include <dali/public-api/common/vector-wrapper.h>
25 #include <dali/internal/event/events/gesture-recognizer.h>
26 #include <dali/internal/event/events/pinch-gesture/pinch-gesture-event.h>
40 * When given a set of touch events, this detector attempts to determine if a pinch gesture has taken place.
42 class PinchGestureRecognizer : public GestureRecognizer
46 using Observer = RecognizerObserver<PinchGestureEvent>;
50 * @param[in] screenSize The size of the screen.
51 * @param[in] screenDpi The dpi value of the screen
52 * @param[in] minimumPinchDistance in pixels
53 * @param[in] minimumTouchEvents The number of touch events required
54 * @param[in] minimumTouchEventsAfterStart The number of touch events required after a gesture started
56 PinchGestureRecognizer( Observer& observer, Vector2 screenSize, Vector2 screenDpi, float minimumPinchDistance, uint32_t minimumTouchEvents, uint32_t minimumTouchEventsAfterStart );
61 virtual ~PinchGestureRecognizer();
65 void SetMinimumPinchDistance(float value);
68 * Sets the minimum touch events required before a pinch can be started
69 * @param[in] value The number of touch events
71 void SetMinimumTouchEvents( uint32_t value );
74 * Sets the minimum touch events required after a pinch started
75 * @param[in] value The number of touch events
77 void SetMinimumTouchEventsAfterStart( uint32_t value );
80 * @copydoc Dali::Internal::GestureDetector::SendEvent(const Integration::TouchEvent&)
82 virtual void SendEvent(const Integration::TouchEvent& event);
85 * @copydoc Dali::Internal::GestureDetector::Update(const Integration::GestureRequest&)
87 virtual void Update(const GestureRequest& request);
92 * Emits the pinch gesture event to the core.
93 * @param[in] state The state of the pinch (whether it's starting, continuing or finished).
94 * @param[in] currentEvent The latest touch event.
96 void SendPinch(GestureState state, const Integration::TouchEvent& currentEvent);
100 // Reference to the gesture processor for this recognizer
104 * Internal state machine.
108 CLEAR, ///< No gesture detected.
109 POSSIBLE, ///< The current touch event data suggests that a gesture is possible.
110 STARTED, ///< A gesture has been detected.
113 State mState; ///< The current state of the detector.
114 std::vector<Integration::TouchEvent> mTouchEvents; ///< The touch events since initial touch down.
116 float mDefaultMinimumDistanceDelta; ///< The default value of the mMinimumDistanceDelta.
118 float mMinimumDistanceDelta; ///< The minimum distance before a pinch is applicable.
120 float mStartingDistance; ///< The distance between the two touch points when the pinch is first detected.
122 uint32_t mMinimumTouchEvents; ///< The minimum touch events required before a pinch can be started.
124 uint32_t mMinimumTouchEventsAfterStart; ///< The minimum touch events required after a pinch started.
127 } // namespace Internal
131 #endif // DALI_INTERNAL_EVENT_PINCH_GESTURE_RECOGNIZER_H