老婆出轨 发表于 2025-1-26 11:21:13

鸿蒙OpenHarmony【手势拦截加强】ArkTS组件手势处置惩罚

shouldBuiltInRecognizerParallelWith

shouldBuiltInRecognizerParallelWith(callback: ShouldBuiltInRecognizerParallelWithCallback): T
提供体系内置手势与响应链上其他组件的手势设置并行关系的回调变乱。
元服务API:  从API version 12开始,该接口支持在元服务中利用。
体系能力:  SystemCapability.ArkUI.ArkUI.Full
参数:
参数名参数范例必填参数描述callback是提供体系内置手势与响应链上其他组件的手势设置并行关系的回调变乱,当该组件做触摸碰撞测试时,会触发用户界说的回调来形成手势并行关系。 返回值:
范例说明T返回当前组件。 ShouldBuiltInRecognizerParallelWithCallback

type ShouldBuiltInRecognizerParallelWithCallback = (current: GestureRecognizer, others: Array) => GestureRecognizer
提供体系内置手势与响应链上其他组件的手势设置并行关系的回调变乱范例。
元服务API:  从API version 12开始,该接口支持在元服务中利用。
体系能力:  SystemCapability.ArkUI.ArkUI.Full
参数:
参数名范例必填说明current是当前组件的体系内置手势识别器,当前版本只提供内置的范例的手势识别器。othersArray<>是响应链上更高优先级的其他组件相同种别的手势识别器。 返回值:
范例说明与current识别器绑定并行关系的某个手势识别器。 GestureRecognizer

手势识别器对象。
getTag

getTag(): string
返回当前手势识别器的tag。
元服务API:  从API version 12开始,该接口支持在元服务中利用。
体系能力:  SystemCapability.ArkUI.ArkUI.Full
返回值:
范例说明string当前手势识别器的tag。 getType

getType(): GestureControl.GestureType
返回当前手势识别器的范例。
元服务API:  从API version 12开始,该接口支持在元服务中利用。
体系能力:  SystemCapability.ArkUI.ArkUI.Full
返回值:
范例说明当前手势识别器的范例。 isBuiltIn

isBuiltIn(): boolean
返回当前手势识别器是否为体系内置手势。
元服务API:  从API version 12开始,该接口支持在元服务中利用。
体系能力:  SystemCapability.ArkUI.ArkUI.Full
返回值:
范例说明boolean当前手势识别器是否为体系内置手势。 setEnabled

setEnabled(isEnabled: boolean): void
设置当前手势识别器的使能状态。
元服务API:  从API version 12开始,该接口支持在元服务中利用。
体系能力:  SystemCapability.ArkUI.ArkUI.Full
参数:
参数名范例必填说明isEnabledboolean是手势识别器的使能状态。 isEnabled

isEnabled(): boolean
返回当前手势识别器的使能状态。
元服务API:  从API version 12开始,该接口支持在元服务中利用。
体系能力:  SystemCapability.ArkUI.ArkUI.Full
返回值:
范例说明boolean当前手势识别器的使能状态。 getState

getState(): GestureRecognizerState
返回当前手势识别器的状态。
元服务API:  从API version 12开始,该接口支持在元服务中利用。
体系能力:  SystemCapability.ArkUI.ArkUI.Full
返回值:
范例说明当前手势识别器的状态。 getEventTargetInfo

getEventTargetInfo(): EventTargetInfo
返回当前手势识别器对应组件的信息。
元服务API:  从API version 12开始,该接口支持在元服务中利用。
体系能力:  SystemCapability.ArkUI.ArkUI.Full
返回值:
范例说明当前手势识别器对应组件的信息。 isValid

isValid(): boolean;
返回当前手势识别器是否有效。
元服务API:  从API version 12开始,该接口支持在元服务中利用。
体系能力:  SystemCapability.ArkUI.ArkUI.Full
返回值:
范例说明boolean当前手势识别器是否有效。当该识别器绑定的组件被析构或者该识别器不在响应链上时返回false。 GestureRecognizerState

界说手势识别器状态。
元服务API:  从API version 12开始,该接口支持在元服务中利用。
体系能力:  SystemCapability.ArkUI.ArkUI.Full
名称值描述READY0预备状态。DETECTING1检测状态。PENDING2等待状态。BLOCKED3阻塞状态。SUCCESSFUL4成功状态。FAILED5失败状态。 EventTargetInfo

手势识别器对应组件的信息。
getId

getId(): string
返回当前组件的组件标识。
元服务API:  从API version 12开始,该接口支持在元服务中利用。
体系能力:  SystemCapability.ArkUI.ArkUI.Full
返回值:
范例说明string当前组件的[组件标识]。 ScrollableTargetInfo

手势识别器对应的滚动类容器组件的信息,继承于。
isBegin

isBegin(): boolean
返回当前滚动类容器组件是否在顶部,假如为Swiper组件且在循环模式下返回false。
元服务API:  从API version 12开始,该接口支持在元服务中利用。
体系能力:  SystemCapability.ArkUI.ArkUI.Full
返回值:
范例说明boolean当前滚动类容器组件是否在顶部。 isEnd

isEnd(): boolean
返回当前滚动类容器组件是否在底部,假如为Swiper组件且在循环模式下返回false。
元服务API:  从API version 12开始,该接口支持在元服务中利用。
体系能力:  SystemCapability.ArkUI.ArkUI.Full
返回值:
范例说明boolean当前滚动类容器组件是否在底部。 PanRecognizer

拖动手势识别器对象,继承于。
getPanGestureOptions

getPanGestureOptions(): PanGestureOptions
返回当前拖动手势识别器的属性。
元服务API:  从API version 12开始,该接口支持在元服务中利用。
体系能力:  SystemCapability.ArkUI.ArkUI.Full
返回值:
范例说明当前拖动手势识别器的属性。 onGestureRecognizerJudgeBegin

onGestureRecognizerJudgeBegin(callback: GestureRecognizerJudgeBeginCallback): T
给组件绑定自界说手势识别器判定回调。
元服务API:  从API version 12开始,该接口支持在元服务中利用。
体系能力:  SystemCapability.ArkUI.ArkUI.Full
参数:
参数名参数范例必填参数描述callback是给组件绑定自界说手势识别器判定回调,当绑定到该组件的手势被接受时,会触发用户界说的回调来获取结果。 返回值:
范例说明T返回当前组件。 GestureRecognizerJudgeBeginCallback

type GestureRecognizerJudgeBeginCallback = (event: BaseGestureEvent, current: GestureRecognizer, recognizers: Array) => GestureJudgeResult
自界说手势识别器判定回调范例。
元服务API:  从API version 12开始,该接口支持在元服务中利用。
体系能力:  SystemCapability.ArkUI.ArkUI.Full
参数:
参数名范例必填说明event是当前根本手势变乱信息。current是当前即将要响应的识别器对象。othersArray<>是响应链上的其他手势识别器对象。 返回值:
范例说明手势是否裁决成功的判定结果。 示例

// xxx.ets
@Entry
@Component
struct FatherControlChild {
scroller: Scroller = new Scroller()
scroller2: Scroller = new Scroller()
private arr: number[] =
private childRecognizer: GestureRecognizer = new GestureRecognizer()
private currentRecognizer: GestureRecognizer = new GestureRecognizer()
private lastOffset: number = 0

build() {
    Stack({ alignContent: Alignment.TopStart }) {
      Scroll(this.scroller) { // 外部滚动容器
      Column() {
          Text("Scroll Area")
            .width('90%')
            .height(150)
            .backgroundColor(0xFFFFFF)
            .borderRadius(15)
            .fontSize(16)
            .textAlign(TextAlign.Center)
            .margin({ top: 10 })
          Scroll(this.scroller2) { // 内部滚动容器
            Column() {
            Text("Scroll Area2")
                .width('90%')
                .height(150)
                .backgroundColor(0xFFFFFF)
                .borderRadius(15)
                .fontSize(16)
                .textAlign(TextAlign.Center)
                .margin({ top: 10 })
            Column() {
                ForEach(this.arr, (item: number) => {
                  Text(item.toString())
                  .width('90%')
                  .height(150)
                  .backgroundColor(0xFFFFFF)
                  .borderRadius(15)
                  .fontSize(16)
                  .textAlign(TextAlign.Center)
                  .margin({ top: 10 })
                }, (item: string) => item)
            }.width('100%')
            }
          }
          .id("inner")
          .width('100%')
          .height(800)
      }.width('100%')
      }
      .id("outer")
      .height(600)
      .scrollable(ScrollDirection.Vertical) // 滚动方向纵向
      .scrollBar(BarState.On) // 滚动条常驻显示
      .scrollBarColor(Color.Gray) // 滚动条颜色
      .scrollBarWidth(10) // 滚动条宽度
      .edgeEffect(EdgeEffect.None)
      .shouldBuiltInRecognizerParallelWith((current: GestureRecognizer, others: Array<GestureRecognizer>) => {
      for (let i = 0; i < others.length; i++) {
          let target = others.getEventTargetInfo();
          if (target) {
            if (target.getId() == "inner" && others.isBuiltIn() && others.getType() == GestureControl.GestureType.PAN_GESTURE) { // 找到将要组成并行手势的识别器
            this.currentRecognizer = current; // 保存当前组件的识别器
            this.childRecognizer = others; // 保存将要组成并行手势的识别器
            return others; // 返回将要组成并行手势的识别器
            }
          }
      }
      return undefined;
      })
      .onGestureRecognizerJudgeBegin((event: BaseGestureEvent, current: GestureRecognizer, others: Array<GestureRecognizer>) => { // 在识别器即将要成功时,根据当前组件状态,设置识别器使能状态
      if (current) {
          let target = current.getEventTargetInfo();
          if (target) {
            if (target.getId() == "outer" && current.isBuiltIn() && current.getType() == GestureControl.GestureType.PAN_GESTURE) {
            if (others) {
                for (let i = 0; i < others.length; i++) {
                  let target = others.getEventTargetInfo() as ScrollableTargetInfo;
                  if (target instanceof ScrollableTargetInfo && target.getId() == "inner") { // 找到响应链上对应并行的识别器
                  let panEvent = event as PanGestureEvent;
                  if (target.isEnd()) { // 根据当前组件状态以及移动方向动态控制识别器使能状态
                      if (panEvent && panEvent.offsetY < 0) {
                        this.childRecognizer.setEnabled(false)
                        this.currentRecognizer.setEnabled(true)
                      } else {
                        this.childRecognizer.setEnabled(true)
                        this.currentRecognizer.setEnabled(false)
                      }
                  } else if (target.isBegin()) {
                      if (panEvent.offsetY > 0) {
                        this.childRecognizer.setEnabled(false)
                        this.currentRecognizer.setEnabled(true)
                      } else {
                        this.childRecognizer.setEnabled(true)
                        this.currentRecognizer.setEnabled(false)
                      }
                  } else {
                      this.childRecognizer.setEnabled(true)
                      this.currentRecognizer.setEnabled(false)
                  }
                  }
                }
            }
            }
          }
      }
      return GestureJudgeResult.CONTINUE;
      })
      .parallelGesture( // 绑定一个Pan手势作为动态控制器
      PanGesture()
          .onActionUpdate((event: GestureEvent)=>{
            if (this.childRecognizer.getState() != GestureRecognizerState.SUCCESSFUL || this.currentRecognizer.getState() != GestureRecognizerState.SUCCESSFUL) { // 如果识别器状态不是SUCCESSFUL,则不做控制
            return;
            }
            let target = this.childRecognizer.getEventTargetInfo() as ScrollableTargetInfo;
            let currentTarget = this.currentRecognizer.getEventTargetInfo() as ScrollableTargetInfo;
            if (target instanceof ScrollableTargetInfo && currentTarget instanceof ScrollableTargetInfo) {
            if (target.isEnd()) { // 在移动过程中实时根据当前组件状态,控制识别器的开闭状态
                if ((event.offsetY - this.lastOffset) < 0) {
                  this.childRecognizer.setEnabled(false)
                  if (currentTarget.isEnd()) {
                  this.currentRecognizer.setEnabled(false)
                  } else {
                  this.currentRecognizer.setEnabled(true)
                  }
                } else {
                  this.childRecognizer.setEnabled(true)
                  this.currentRecognizer.setEnabled(false)
                }
            } else if (target.isBegin()) {
                if ((event.offsetY - this.lastOffset) > 0) {
                  this.childRecognizer.setEnabled(false)
                  if (currentTarget.isBegin()) {
                  this.currentRecognizer.setEnabled(false)
                  } else {
                  this.currentRecognizer.setEnabled(true)
                  }
                } else {
                  this.childRecognizer.setEnabled(true)
                  this.currentRecognizer.setEnabled(false)
                }
            } else {
                this.childRecognizer.setEnabled(true)
                this.currentRecognizer.setEnabled(false)
            }
            }
            this.lastOffset = event.offsetY
          })
      )
    }.width('100%').height('100%').backgroundColor(0xDCDCDC)
}
}

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: 鸿蒙OpenHarmony【手势拦截加强】ArkTS组件手势处置惩罚