1# Combined Gestures 2 3 4A combined gesture consists of multiple single gestures. Different GestureModes are used in GestureGroup to declare the type of the combined gesture. [Continuous recognition](#continuous-recognition), [parallel recognition](#parallel-recognition), and [exclusive recognition](#exclusive-recognition) are supported for a group of gestures. 5 6 7 8```ts 9GestureGroup(mode:GestureMode, ...gesture:GestureType[]) 10``` 11 12 13- **mode**: declare a type of the combined gesture. This parameter is mandatory and belongs to the GestureMode enumeration class. 14 15- **gesture**: array consisting of multiple gestures. This parameter is mandatory. . 16 17 18## Continuous Recognition 19 20For continuous recognition, **GestureMode** corresponding to the combined gesture is **Sequence**. Continuous recognition of combined gestures will recognize gestures according to the registration sequence of gestures until all gestures are recognized successfully. When one gesture in the continuously recognized combined gestures fails to be recognized, all gestures fail to be recognized. 21 22A continuous gesture formed by combining a touch-and-hold gesture and a drag gesture is used as an example. 23 24The translate attribute is bound to a Column component. You can modify the attribute to move the component. Then, bind the sequence gesture combined by LongPressGesture and PanGesture to the component. When LongPressGesture is triggered, the displayed number is updated. When a user drags a widget after touching and holding the widget, the widget is dragged based on the callback function of the drag gesture. 25 26 27 28```ts 29// xxx.ets 30@Entry 31@Component 32struct Index { 33 @State offsetX: number = 0; 34 @State offsetY: number = 0; 35 @State count: number = 0; 36 @State positionX: number = 0; 37 @State positionY: number = 0; 38 @State borderStyles: BorderStyle = BorderStyle.Solid 39 40 build() { 41 Column() { 42 Text('sequence gesture\n' + 'LongPress onAction:' + this.count + '\nPanGesture offset:\nX: ' + this.offsetX + '\n' + 'Y: ' + this.offsetY) 43 .fontSize(28) 44 } 45 //Bind the translate attribute to move the component. 46 .translate({ x: this.offsetX, y: this.offsetY, z: 0 }) 47 .height(250) 48 .width(300) 49 // The following combined gestures are identified in sequence. When the touch and hold gesture event is not triggered normally, the drag gesture event is not triggered. 50 .gesture( 51 // Declare that the type of the combined gesture is the Sequence type. 52 GestureGroup(GestureMode.Sequence, 53 // The first gesture triggered by the combined gesture is a touch-and-hold gesture, and the touch-and-hold gesture can be responded to for multiple times. 54 LongPressGesture({ repeat: true }) 55 // Increase the count displayed on the Text component when the touch and hold gesture is successfully recognized. 56 .onAction((event: GestureEvent) => { 57 if (event.repeat) { 58 this.count++; 59 } 60 console.info('LongPress onAction'); 61 }) 62 .onActionEnd(() => { 63 console.info('LongPress end'); 64 }), 65 // The PanGesture gesture is triggered when you drag the slider after touching and holding the slider. 66 PanGesture() 67 .onActionStart(() => { 68 this.borderStyles = BorderStyle.Dashed; 69 console.info('pan start'); 70 }) 71 // When the gesture is triggered, the dragging distance is obtained according to the callback, and the displacement distance of the component is modified to move the component. 72 .onActionUpdate((event: GestureEvent) => { 73 this.offsetX = this.positionX + event.offsetX; 74 this.offsetY = this.positionY + event.offsetY; 75 console.info('pan update'); 76 }) 77 .onActionEnd(() => { 78 this.positionX = this.offsetX; 79 this.positionY = this.offsetY; 80 this.borderStyles = BorderStyle.Solid; 81 }) 82 ) 83 ) 84 } 85} 86``` 87 88 89![sequence](figures/sequence.gif) 90 91 92>**NOTE** 93> 94>The drag event is a typical continuous recognition combined gesture event, and is formed by combining a touch and hold gesture event and a slide gesture event. The drag event is triggered only when the user touches and holds the gesture for a preset period of time. If the touch and hold event is not reached or the slider is not performed after the touch and hold event, the drag event fails to be identified. 95 96 97## Parallel Recognition 98 99For parallel recognition, **GestureMode** corresponding to the combined gesture is **Parallel**. Parallel recognition of gestures registered in the combined gestures will be recognized at the same time until all gestures are recognized. The gestures in the gesture combination are recognized in parallel without affecting each other. 100 101For example, a parallel recognition gesture formed by a tap gesture and a double-tap gesture is bound to a Column component. Because the tap gesture and the double-tap gesture are recognized in parallel, the two gestures may be recognized at the same time, and the two gestures do not interfere with each other. 102 103 104 105```ts 106// xxx.ets 107@Entry 108@Component 109struct Index { 110 @State count1: number = 0; 111 @State count2: number = 0; 112 113 build() { 114 Column() { 115 Text('parallel gesture\n' + 'tapGesture count is 1:' + this.count1 + '\ntapGesture count is 2:' + this.count2 + '\n') 116 .fontSize(28) 117 } 118 .height(200) 119 .width(250) 120 // The following combined gestures are parallel. After the tap gesture is recognized successfully, if you tap the gesture again within the specified time, the double-tap gesture will also be recognized successfully. 121 .gesture( 122 GestureGroup(GestureMode.Parallel, 123 TapGesture({ count: 1 }) 124 .onAction(() => { 125 this.count1++; 126 }), 127 TapGesture({ count: 2 }) 128 .onAction(() => { 129 this.count2++; 130 }) 131 ) 132 ) 133 } 134} 135``` 136 137 138![parallel](figures/parallel.gif) 139 140 141>**NOTE** 142> 143>After a tap gesture and a double-tap gesture form a parallel recognition combined gesture, when a tap is performed in an area, the tap gesture and the double-tap gesture are recognized at the same time. 144> 145>When there is only a single tap, the tap gesture is recognized successfully, but the double-tap gesture fails to be recognized. 146> 147>When there are two clicks, if the interval between the two clicks is within a specified period (300 ms by default), two click events and one double-click event are triggered. 148> 149>When there are two clicks, if the interval between the two clicks exceeds the specified time, the two clicks are triggered but the double-click event is not triggered. 150 151 152## Exclusive Recognition 153 154For exclusive recognition, **GestureMode** corresponding to the combined gesture is **Exclusive**. The gestures registered in the mutually exclusive recognition combination gesture are recognized at the same time. If one gesture is recognized successfully, the gesture recognition ends, and all other gestures fail to be recognized. 155 156A mutually exclusive recognition combination gesture formed by binding a click gesture and a double-tap gesture to a Column component is used as an example. Because a click gesture can be triggered only once and a double-tap gesture needs to be triggered twice, each click event is consumed by the click gesture and cannot be accumulated into a double-tap gesture, the double-tap gesture cannot be triggered. 157 158 159 160```ts 161// xxx.ets 162@Entry 163@Component 164struct Index { 165 @State count1: number = 0; 166 @State count2: number = 0; 167 168 build() { 169 Column() { 170 Text('parallel gesture\n' + 'tapGesture count is 1:' + this.count1 + '\ntapGesture count is 2:' + this.count2 + '\n') 171 .fontSize(28) 172 } 173 .height(200) 174 .width(250) 175 //The following combined gestures are mutually exclusive. After the tap gesture is recognized successfully, the double-tap gesture fails to be recognized. 176 .gesture( 177 GestureGroup(GestureMode.Exclusive, 178 TapGesture({ count: 1 }) 179 .onAction(() => { 180 this.count1++; 181 }), 182 TapGesture({ count: 2 }) 183 .onAction(() => { 184 this.count2++; 185 }) 186 ) 187 ) 188 } 189} 190``` 191 192 193![exclusive](figures/exclusive.gif) 194 195 196>**NOTE** 197> 198>After the tapping gesture and the double-tap gesture form a mutually exclusive recognition combination gesture, when tapping is performed in the area, the tapping gesture and the double-tap gesture are recognized at the same time. 199> 200>When there is only a single tap, the tap gesture is recognized successfully, but the double-tap gesture fails to be recognized. 201> 202>When there are two taps, the tap gesture declares that the recognition is successful when the tap gesture is tapped for the first time. In this case, the double-tap gesture has failed. Even if the second tap is performed within the specified time, the double-tap gesture event is not responded. In this case, the second recognition success of the tap gesture event is triggered. 203