0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

鴻蒙ArkTS聲明式開發(fā):跨平臺(tái)支持列表PanGesture之基礎(chǔ)手勢(shì)

jf_46214456 ? 來(lái)源:jf_46214456 ? 作者:jf_46214456 ? 2024-06-17 15:03 ? 次閱讀

PanGesture

用于觸發(fā)拖動(dòng)手勢(shì)事件,滑動(dòng)的最小距離為5vp時(shí)拖動(dòng)手勢(shì)識(shí)別成功。

說(shuō)明:
開發(fā)前請(qǐng)熟悉鴻蒙開發(fā)指導(dǎo)文檔 :[gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md]

從API Version 7開始支持。后續(xù)版本如有新增內(nèi)容,則采用上角標(biāo)單獨(dú)標(biāo)記該內(nèi)容的起始版本。

接口

PanGesture(value?: { fingers?: number; direction?: PanDirection; distance?: number } | [PanGestureOptions])

參數(shù):

參數(shù)名稱參數(shù)類型必填參數(shù)描述
fingersnumber觸發(fā)拖動(dòng)的最少手指數(shù),最小為1指, 最大取值為10指。 默認(rèn)值:1 取值范圍:[1,10]**說(shuō)明:**當(dāng)設(shè)置的值小于1或不設(shè)置時(shí),會(huì)被轉(zhuǎn)化為默認(rèn)值。
directionPanDirection觸發(fā)拖動(dòng)的手勢(shì)方向,此枚舉值支持邏輯與(&)和邏輯或(
distancenumber最小拖動(dòng)識(shí)別距離,單位為vp。 默認(rèn)值:5 說(shuō)明: [Tabs組件]滑動(dòng)與該拖動(dòng)手勢(shì)事件同時(shí)存在時(shí),可將distance值設(shè)為1,使拖動(dòng)更靈敏,避免造成事件錯(cuò)亂。 當(dāng)拖動(dòng)距離的值小于等于0時(shí),會(huì)被轉(zhuǎn)化為默認(rèn)值。

PanDirection枚舉說(shuō)明

名稱描述
All所有方向。
Horizontal水平方向。
Vertical豎直方向。
Left向左拖動(dòng)。
Right向右拖動(dòng)。
Up向上拖動(dòng)。
Down向下拖動(dòng)。
None任何方向都不可觸發(fā)拖動(dòng)手勢(shì)事件。

PanGestureOptions

通過(guò)PanGestureOptions對(duì)象接口可以動(dòng)態(tài)修改滑動(dòng)手勢(shì)識(shí)別器的屬性,從而避免通過(guò)狀態(tài)變量修改屬性(狀態(tài)變量修改會(huì)導(dǎo)致UI刷新)。

PanGestureOptions(value?: { fingers?: number; direction?: PanDirection; distance?: number })

參數(shù):

參數(shù)名稱參數(shù)類型必填參數(shù)描述
fingersnumber觸發(fā)滑動(dòng)的最少手指數(shù),最小為1指, 最大取值為10指。 默認(rèn)值:1
directionPanDirection設(shè)置滑動(dòng)方向,此枚舉值支持邏輯與(&)和邏輯或(
distancenumber最小滑動(dòng)識(shí)別距離,單位為vp。 默認(rèn)值:5.0 說(shuō)明: [Tabs組件]滑動(dòng)與該拖動(dòng)手勢(shì)事件同時(shí)存在時(shí),可將distance值設(shè)為1,使拖動(dòng)更靈敏,避免造成事件錯(cuò)亂。 當(dāng)拖動(dòng)距離的值小于等于0時(shí),會(huì)被轉(zhuǎn)化為默認(rèn)值。

接口

名稱功能描述
setDirection(value: PanDirection)設(shè)置direction屬性。
setDistance(value: number)設(shè)置distance屬性。
setFingers(value: number)設(shè)置fingers屬性。

事件

名稱功能描述
onActionStart(event: (event?: [GestureEvent]) => void)Pan手勢(shì)識(shí)別成功回調(diào)。
onActionUpdate(event: (event?: [GestureEvent]) => void)Pan手勢(shì)移動(dòng)過(guò)程中回調(diào)。
onActionEnd(event: (event?: [GestureEvent]) => void)Pan手勢(shì)識(shí)別成功,手指抬起后觸發(fā)回調(diào)。
onActionCancel(event: () => void)Pan手勢(shì)識(shí)別成功,接收到觸摸取消事件觸發(fā)回調(diào)。

示例

// xxx.ets
@Entry
@Component
struct PanGestureExample {
  @State offsetX: number = 0
  @State offsetY: number = 0
  @State positionX: number = 0
  @State positionY: number = 0
  private panOption: PanGestureOptions = new PanGestureOptions({ direction: PanDirection.Left | PanDirection.Right })

  build() {
    Column() {
      Column() {
        Text('PanGesture offset:nX: ' + this.offsetX + 'n' + 'Y: ' + this.offsetY)
      }
      .height(200)
      .width(300)
      .padding(20)
      .border({ width: 3 })
      .margin(50)
      .translate({ x: this.offsetX, y: this.offsetY, z: 0 }) // 以組件左上角為坐標(biāo)原點(diǎn)進(jìn)行移動(dòng)
      // 左右拖動(dòng)觸發(fā)該手勢(shì)事件
      .gesture(
      PanGesture(this.panOption)
        .onActionStart((event?: GestureEvent) = > {
          console.info('Pan start')
        })
        .onActionUpdate((event?: GestureEvent) = > {
          if (event) {
            this.offsetX = this.positionX + event.offsetX
            this.offsetY = this.positionY + event.offsetY
          }
        })
        .onActionEnd(() = > {
          this.positionX = this.offsetX
          this.positionY = this.offsetY
          console.info('Pan end')
        })
      )

      Button('修改PanGesture觸發(fā)條件')
        .onClick(() = > {
          // 將PanGesture手勢(shì)事件觸發(fā)條件改為雙指以任意方向拖動(dòng)
          this.panOption.setDirection(PanDirection.All)
          this.panOption.setFingers(2)
        })
    }
  }
}

`HarmonyOSOpenHarmony鴻蒙文檔籽料:mau123789v直接拿`

新文檔.png

示意圖:

向左拖動(dòng):

zh-cn_image_0000001174264374

點(diǎn)擊按鈕修改PanGesture觸發(fā)條件,雙指向左下方拖動(dòng):

zh-cn_image1_0000001174264374

審核編輯 黃宇

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 鴻蒙
    +關(guān)注

    關(guān)注

    59

    文章

    2525

    瀏覽量

    43772
收藏 人收藏

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    HarmonyOS/OpenHarmony應(yīng)用開發(fā)-ArkTS聲明開發(fā)范式

    基于ArkTS聲明開發(fā)范式的方舟開發(fā)框架是一套開發(fā)極簡(jiǎn)、高性能、
    發(fā)表于 01-17 15:09

    鴻蒙開發(fā)ArkTS基礎(chǔ)知識(shí)

    一、ArkTS簡(jiǎn)介 ArkTS是HarmonyOS優(yōu)選的主力應(yīng)用開發(fā)語(yǔ)言。它在TypeScript(簡(jiǎn)稱TS)的基礎(chǔ)上,匹配了鴻蒙的ArkUI框架,擴(kuò)展了
    的頭像 發(fā)表于 01-24 16:44 ?3056次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>開發(fā)</b><b class='flag-5'>之</b><b class='flag-5'>ArkTS</b>基礎(chǔ)知識(shí)

    鴻蒙ArkTS聲明開發(fā)平臺(tái)支持列表【觸摸事件】

    當(dāng)手指在組件上按下、滑動(dòng)、抬起時(shí)觸發(fā)。
    的頭像 發(fā)表于 05-27 09:34 ?764次閱讀
    <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'>平臺(tái)</b><b class='flag-5'>支持</b><b class='flag-5'>列表</b>【觸摸事件】

    鴻蒙ArkTS聲明開發(fā)平臺(tái)支持列表【顯隱控制】 通用屬性

    控制當(dāng)前組件顯示或隱藏。注意,即使組件處于隱藏狀態(tài),在頁(yè)面刷新時(shí)仍存在重新創(chuàng)建過(guò)程,因此當(dāng)對(duì)性能有嚴(yán)格要求時(shí)建議使用[條件渲染]代替。 默認(rèn)值:Visibility.Visible 從API version 9開始,該接口支持ArkTS卡片中使用。
    的頭像 發(fā)表于 06-03 14:46 ?864次閱讀
    <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'>平臺(tái)</b><b class='flag-5'>支持</b><b class='flag-5'>列表</b>【顯隱控制】 通用屬性

    鴻蒙ArkTS聲明開發(fā)平臺(tái)支持列表【形狀裁剪】 通用屬性

    參數(shù)為相應(yīng)類型的組件,按指定的形狀對(duì)當(dāng)前組件進(jìn)行裁剪;參數(shù)為boolean類型時(shí),設(shè)置是否按照父容器邊緣輪廓進(jìn)行裁剪。 默認(rèn)值:false 從API version 9開始,該接口支持ArkTS卡片中使用。
    的頭像 發(fā)表于 06-04 15:22 ?696次閱讀
    <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'>平臺(tái)</b><b class='flag-5'>支持</b><b class='flag-5'>列表</b>【形狀裁剪】 通用屬性

    鴻蒙ArkTS聲明開發(fā)平臺(tái)支持列表【菜單控制】 通用屬性

    為組件綁定彈出菜單,彈出菜單以垂直列表形式顯示菜單項(xiàng),可通過(guò)長(zhǎng)按、點(diǎn)擊或鼠標(biāo)右鍵觸發(fā)。
    的頭像 發(fā)表于 06-06 09:17 ?1145次閱讀
    <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'>平臺(tái)</b><b class='flag-5'>支持</b><b class='flag-5'>列表</b>【菜單控制】 通用屬性

    鴻蒙ArkTS聲明開發(fā)平臺(tái)支持列表【多態(tài)樣式】 通用屬性

    設(shè)置組件不同狀態(tài)的樣式。 從API version 9開始,該接口支持ArkTS卡片中使用。
    的頭像 發(fā)表于 06-07 09:48 ?672次閱讀
    <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'>平臺(tái)</b><b class='flag-5'>支持</b><b class='flag-5'>列表</b>【多態(tài)樣式】 通用屬性

    鴻蒙ArkTS聲明開發(fā)平臺(tái)支持列表【觸摸熱區(qū)設(shè)置】觸摸交互控制

    適用于支持通用點(diǎn)擊事件、通用觸摸事件、通用手勢(shì)處理的組件。
    的頭像 發(fā)表于 06-13 10:33 ?717次閱讀
    <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'>平臺(tái)</b><b class='flag-5'>支持</b><b class='flag-5'>列表</b>【觸摸熱區(qū)設(shè)置】觸摸交互控制

    鴻蒙ArkTS聲明開發(fā)平臺(tái)支持列表【綁定手勢(shì)方法】 手勢(shì)處理

    為組件綁定不同類型的手勢(shì)事件,并設(shè)置事件的響應(yīng)方法。
    的頭像 發(fā)表于 06-15 09:17 ?1400次閱讀
    <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'>平臺(tái)</b><b class='flag-5'>支持</b><b class='flag-5'>列表</b>【綁定<b class='flag-5'>手勢(shì)</b>方法】 <b class='flag-5'>手勢(shì)</b>處理

    鴻蒙ArkTS聲明開發(fā)平臺(tái)支持列表【TapGesture】 基礎(chǔ)手勢(shì)

    支持單擊、雙擊和多次點(diǎn)擊事件的識(shí)別。
    的頭像 發(fā)表于 06-17 14:19 ?607次閱讀
    <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'>平臺(tái)</b><b class='flag-5'>支持</b><b class='flag-5'>列表</b>【TapGesture】 基礎(chǔ)<b class='flag-5'>手勢(shì)</b>

    鴻蒙ArkTS聲明開發(fā)平臺(tái)支持列表LongPressGesture基礎(chǔ)手勢(shì)

    用于觸發(fā)長(zhǎng)按手勢(shì)事件,觸發(fā)長(zhǎng)按手勢(shì)的最少手指數(shù)為1,最短長(zhǎng)按時(shí)間為500毫秒。
    的頭像 發(fā)表于 06-17 09:59 ?777次閱讀
    <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'>平臺(tái)</b><b class='flag-5'>支持</b><b class='flag-5'>列表</b>LongPressGesture<b class='flag-5'>之</b>基礎(chǔ)<b class='flag-5'>手勢(shì)</b>

    鴻蒙ArkTS聲明開發(fā)平臺(tái)支持列表PinchGesture基礎(chǔ)手勢(shì)

    用于觸發(fā)捏合手勢(shì),觸發(fā)捏合手勢(shì)的最少手指為2指,最大為5指,最小識(shí)別距離為3vp。
    的頭像 發(fā)表于 06-18 09:33 ?637次閱讀
    <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'>平臺(tái)</b><b class='flag-5'>支持</b><b class='flag-5'>列表</b>PinchGesture<b class='flag-5'>之</b>基礎(chǔ)<b class='flag-5'>手勢(shì)</b>

    鴻蒙ArkTS聲明開發(fā)平臺(tái)支持列表RotationGesture基礎(chǔ)手勢(shì)

    用于觸發(fā)旋轉(zhuǎn)手勢(shì)事件,觸發(fā)旋轉(zhuǎn)手勢(shì)的最少手指為2指,最大為5指,最小改變度數(shù)為1度。
    的頭像 發(fā)表于 06-18 09:27 ?542次閱讀
    <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'>平臺(tái)</b><b class='flag-5'>支持</b><b class='flag-5'>列表</b>RotationGesture<b class='flag-5'>之</b>基礎(chǔ)<b class='flag-5'>手勢(shì)</b>

    鴻蒙ArkTS聲明開發(fā)平臺(tái)支持列表 SwipeGesture基礎(chǔ)手勢(shì)

    用于觸發(fā)滑動(dòng)事件,滑動(dòng)速度大于100vp/s時(shí)可識(shí)別成功。
    的頭像 發(fā)表于 06-18 14:59 ?562次閱讀
    <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'>平臺(tái)</b><b class='flag-5'>支持</b><b class='flag-5'>列表</b> SwipeGesture<b class='flag-5'>之</b>基礎(chǔ)<b class='flag-5'>手勢(shì)</b>

    鴻蒙ArkTS聲明開發(fā)平臺(tái)支持列表 組合手勢(shì)

    手勢(shì)識(shí)別組合,即多種手勢(shì)組合為復(fù)合手勢(shì),支持連續(xù)識(shí)別、并行識(shí)別和互斥識(shí)別。
    的頭像 發(fā)表于 06-19 09:33 ?687次閱讀
    <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'>平臺(tái)</b><b class='flag-5'>支持</b><b class='flag-5'>列表</b> 組合<b class='flag-5'>手勢(shì)</b>

    電子發(fā)燒友

    中國(guó)電子工程師最喜歡的網(wǎng)站

    • 2931785位工程師會(huì)員交流學(xué)習(xí)
    • 獲取您個(gè)性化的科技前沿技術(shù)信息
    • 參加活動(dòng)獲取豐厚的禮品