觸摸測試控制
設置組件的觸摸測試類型。ArkUI開發(fā)框架在處理觸屏事件時,會在觸屏事件觸發(fā)前,進行按壓點和組件區(qū)域的觸摸測試來收集需要響應觸屏事件的組件,然后基于觸摸測試結果分發(fā)相應的觸屏事件。hitTestBehavior屬性可以設置不同的觸摸測試響應模式,影響組件的觸摸測試收集結果,最終影響后續(xù)的觸屏事件分發(fā),具體影響參考[HitTestMode]枚舉說明。
說明:
屬性
名稱 | 參數類型 | 描述 |
---|---|---|
hitTestBehavior | [HitTestMode] | 設置當前組件的觸摸測試類型。 默認值: HitTestMode.Default |
HitTestMode枚舉說明
名稱 | 描述 |
---|---|
Default | 默認觸摸測試效果,自身和子節(jié)點都響應觸摸測試,但會阻塞兄弟節(jié)點的觸摸測試。 |
Block | 自身響應觸摸測試,阻塞子節(jié)點和兄弟節(jié)點的觸摸測試。 |
Transparent | 自身和子節(jié)點都響應觸摸測試,不會阻塞兄弟節(jié)點的觸摸測試。 |
None | 自身不響應觸摸測試,不會阻塞子節(jié)點和兄弟節(jié)點的觸摸測試。 |
示例
Text組件設置hitTestBehavior為HitTestMode.Transparent,不會阻塞內層Stack的觸摸測試,因此Text和內層Stack的onTouch事件都會觸發(fā)。
內層Stack設置hitTestBehavior為HitTestMode.Block,會阻塞子節(jié)點和外層Button進行觸摸測試,因此內層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)
}
}
審核編輯 黃宇
-
測試
+關注
關注
8文章
5377瀏覽量
127063 -
觸摸
+關注
關注
7文章
199瀏覽量
64490 -
組件
+關注
關注
1文章
518瀏覽量
17925 -
交互控制
+關注
關注
0文章
6瀏覽量
7035
發(fā)布評論請先 登錄
相關推薦
鴻蒙ArkTS的起源和簡介
HarmonyOS/OpenHarmony應用開發(fā)-ArkTS的聲明式開發(fā)范式
鴻蒙開發(fā)之ArkTS基礎知識
![<b class='flag-5'>鴻蒙</b><b class='flag-5'>開發(fā)</b>之<b class='flag-5'>ArkTS</b>基礎知識](https://file1.elecfans.com/web2/M00/BE/20/wKgZomWwzX-AJPj6AADx7A07NIA465.png)
鴻蒙ArkTS聲明式開發(fā):跨平臺支持列表【按鍵事件】
![<b class='flag-5'>鴻蒙</b><b class='flag-5'>ArkTS</b><b class='flag-5'>聲明</b><b class='flag-5'>式</b><b class='flag-5'>開發(fā)</b>:<b class='flag-5'>跨</b><b class='flag-5'>平臺</b><b class='flag-5'>支持</b><b class='flag-5'>列表</b>【按鍵事件】](https://file1.elecfans.com/web2/M00/C5/CD/wKgZomYCdwyAIFf5AAB_7E1pFms943.jpg)
鴻蒙ArkTS聲明式開發(fā):跨平臺支持列表【顯隱控制】 通用屬性
![<b class='flag-5'>鴻蒙</b><b class='flag-5'>ArkTS</b><b class='flag-5'>聲明</b><b class='flag-5'>式</b><b class='flag-5'>開發(fā)</b>:<b class='flag-5'>跨</b><b class='flag-5'>平臺</b><b class='flag-5'>支持</b><b class='flag-5'>列表</b>【顯隱<b class='flag-5'>控制</b>】 通用屬性](https://file1.elecfans.com/web2/M00/EB/2D/wKgZomZdZsOAPO5rAACQtOvBUOY300.png)
鴻蒙ArkTS聲明式開發(fā):跨平臺支持列表【形狀裁剪】 通用屬性
![<b class='flag-5'>鴻蒙</b><b class='flag-5'>ArkTS</b><b class='flag-5'>聲明</b><b class='flag-5'>式</b><b class='flag-5'>開發(fā)</b>:<b class='flag-5'>跨</b><b class='flag-5'>平臺</b><b class='flag-5'>支持</b><b class='flag-5'>列表</b>【形狀裁剪】 通用屬性](https://file1.elecfans.com/web2/M00/EB/98/wKgZomZewfuAbiTWAACFRsepasU509.png)
評論