1# Gesture Binding 2 3 4Different gesture events are bound to each component and the event response mode is designed. When gesture recognition is successful, the ArkUI framework notifies the component of the gesture recognition result through event callback. 5 6 7## gesture (Common Gesture Binding Method) 8 9 10```ts 11.gesture(gesture: GestureType, mask?: GestureMask) 12``` 13 14Binds a gesture to the specified component. **gesture** is a general gesture binding method. 15 16For example, the tap gesture TapGesture can be bound to the **\<Text>** component by using the **gesture** method. 17 18 19```ts 20// xxx.ets 21@Entry 22@Component 23struct Index { 24 build() { 25 Column() { 26 Text('Gesture').fontSize(28) 27 // Use the gesture method to bind the TapGesture. 28 .gesture( 29 TapGesture() 30 .onAction(() => { 31 console.info('TapGesture is onAction'); 32 })) 33 } 34 .height(200) 35 .width(250) 36 } 37} 38``` 39 40 41## priorityGesture (Gesture Binding Method with Priority) 42 43 44```ts 45.priorityGesture(gesture: GestureType, mask?: GestureMask) 46``` 47 48Binds gestures that are preferentially recognized to a component. 49 50By default, when a parent component and a child component use gesture to bind gestures of the same type, the child component preferentially identifies gestures bound by using gesture. When the parent component uses priorityGesture to bind gestures of the same type as the child component, the parent component preferentially identifies gestures bound through priorityGesture. 51 52For example, when the parent component Column and child component Text are bound to the TapGesture gesture at the same time, and the parent component is bound in the form of a priority gesture priorityGesture, the TapGesture bound to the parent component is preferentially responded. 53 54 55 56```ts 57// xxx.ets 58@Entry 59@Component 60struct Index { 61 build() { 62 Column() { 63 Text('Gesture').fontSize(28) 64 .gesture( 65 TapGesture() 66 .onAction(() => { 67 console.info('Text TapGesture is onAction'); 68 })) 69 } 70 .height(200) 71 .width(250) 72 // When this parameter is set to priorityGesture, the TapGesture gesture event of the Text component is ignored when the text area is tapped, and the TapGesture gesture event of the parent component Column is preferentially responded. 73 .priorityGesture( 74 TapGesture() 75 .onAction(() => { 76 console.info('Column TapGesture is onAction'); 77 }), GestureMask.IgnoreInternal) 78 } 79} 80``` 81 82 83## parallelGesture (Parallel Gesture Binding Method) 84 85 86```ts 87.parallelGesture(gesture: GestureType, mask?: GestureMask) 88``` 89 90Binds the same gesture that can be responded to at the same time to the parent and child components. 91 92By default, the gesture event does not bubble up. When a parent component and a child component are bound to a same gesture, the gesture events bound to the parent component and the child component compete with each other, and a gesture event of at most one component can be responded to. When the parent component is bound to parallel gesture parallelGesture, the same gesture events of the parent and child components can be triggered to implement a bubbling effect. 93 94 95 96```ts 97// xxx.ets 98@Entry 99@Component 100struct Index { 101 build() { 102 Column() { 103 Text('Gesture').fontSize(28) 104 .gesture( 105 TapGesture() 106 .onAction(() => { 107 console.info('Text TapGesture is onAction'); 108 })) 109 } 110 .height(200) 111 .width(250) 112 // If this parameter is set to parallelGesture, the TapGesture gesture events of the parent component Column and child component Text are responded when the text area is clicked. 113 .parallelGesture( 114 TapGesture() 115 .onAction(() => { 116 console.info('Column TapGesture is onAction'); 117 }), GestureMask.IgnoreInternal) 118 } 119} 120``` 121 122 123>**NOTE** 124> 125>When the parent component and the child component are bound to both the click gesture event and the double-click gesture event, both the parent component and the child component respond only to the click gesture event. 126