W3Cschool
恭喜您成為首批注冊用戶
獲得88經(jīng)驗值獎勵
設置組件的觸摸測試類型。ArkUI開發(fā)框架在處理觸屏事件時,會在觸屏事件觸發(fā)前,進行按壓點和組件區(qū)域的觸摸測試來收集需要響應觸屏事件的組件,然后基于觸摸測試結(jié)果分發(fā)相應的觸屏事件。hitTestBehavior屬性可以設置不同的觸摸測試響應模式,影響組件的觸摸測試收集結(jié)果,最終影響后續(xù)的觸屏事件分發(fā),具體影響參考HitTestMode枚舉說明。
名稱 | 描述 |
---|---|
Default | 默認觸摸測試效果,自身和子節(jié)點都響應觸摸測試,但會阻塞兄弟節(jié)點的觸摸測試。 |
Block | 自身響應觸摸測試,阻塞子節(jié)點和兄弟節(jié)點的觸摸測試。 |
Transparent | 自身和子節(jié)點都響應觸摸測試,不會阻塞兄弟節(jié)點的觸摸測試。 |
None | 自身不響應觸摸測試,不會阻塞子節(jié)點和兄弟節(jié)點的觸摸測試。 |
Text組件設置hitTestBehavior為HitTestMode.Transparent,不會阻塞內(nèi)層Stack的觸摸測試,因此Text和內(nèi)層Stack的onTouch事件都會觸發(fā)。
內(nèi)層Stack設置hitTestBehavior為HitTestMode.Block,會阻塞子節(jié)點和外層Button進行觸摸測試,因此內(nèi)層Button和外層Button組件不會響應onTouch事件。
- // xxx.ets
- @Entry
- @Component
- struct HitTestBehaviorExample {
- build() {
- // outer stack
- Stack() {
- Button('outer button')
- .onTouch((event) => {
- console.info('outer button touched type: ' + event.type)
- })
- // inner stack
- Stack() {
- Button('inner button')
- .onTouch((event) => {
- console.info('inner button touched type: ' + event.type)
- })
- }
- .width("100%").height("100%")
- .hitTestBehavior(HitTestMode.Block)
- .onTouch((event) => {
- console.info('stack touched type: ' + event.type)
- })
- Text('Transparent')
- .hitTestBehavior(HitTestMode.Transparent)
- .width("100%").height("100%")
- .onTouch((event) => {
- console.info('text touched type: ' + event.type)
- })
- }.width(300).height(300)
- }
- }
Copyright©2021 w3cschool編程獅|閩ICP備15016281號-3|閩公網(wǎng)安備35020302033924號
違法和不良信息舉報電話:173-0602-2364|舉報郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號
聯(lián)系方式:
更多建議: