HarmonyOS NEXT应用开发之多模态页面转场动效实现案例_鸿蒙开发中什么是模态转场(3)

[复制链接]
发表于 2026-2-23 14:41:09 | 显示全部楼层 |阅读模式
先容

本示例先容多模态页面转场动效实现:通过半模态转场实现半模态登录界面, 与全屏模态和组件转场连合实现多模态组合登录场景,此中手机验证码登录与账号暗码登录都为组件, 通过TransitionEffect.move()实现组件间转场到达近似页面转场的效果。
效果图预览


利用分析
登录方式有两种,验证码登录和账号暗码登录

  • 点击主页"点击跳转半模态登录页"按钮
  • 在半模态窗口中选中同意协议键,并点击获取验证码按钮,跳转至手机验证码登录页面。
  • 通过点击手机验证码登录页面中的"账号暗码登录",向右切换跳转至账号暗码登录页面。
  • 通过点击账号暗码登录页面中的"手机验证码登录",向左切换跳转至手机验证码登录页面。
实现思绪

场景:半模态转场至验证码登录,验证码登录和账户登录可以相互切换

登录方式有两种,验证码登录和账户,必要在一个全屏模态窗口CaptureLogin中切换,利用if举行条件渲染。
1、通过bindSheet属性为主页的button绑定半模态页面
Button(                              r                               (                         ′                              a                      p                      p                      .                      s                      t                      r                      i                      n                      g                      .                      h                      a                      l                               f                         s                              c                      r                      e                      e                               n                         m                              o                      d                      a                               l                         l                              o                      g                      i                               n                         d                              e                      s                      c                      r                      i                      p                      t                      i                      o                               n                         ′                              )                      )                      .                      b                      i                      n                      d                      S                      h                      e                      e                      t                      (                          r('app.string.half_screen_modal_login_description')) .bindSheet(               r(′app.string.halfs​creenm​odall​ogind​escription′)).bindSheet($this.isPresent, this.halfModalLogin(), { // 按钮绑定半模态转场
height: this.sheetHeight, // 半模态高度
dragBar: this.showDragBar, // 是否表现控制条
backgroundColor: “#FEFEFE”,
showClose:true, // 是否表现关闭图标
shouldDismiss(sheetDismiss: SheetDismiss)=> { // 半模态页面交互式关闭回调函数
console.log(“bind sheet shouldDismiss”)
sheetDismiss.dismiss()
})
})
2、在半模态页面中的验证码登录按钮绑定全屏模态转场,并将对应的全屏模态转场殊效置空。
@Builder
halfModalLogin() { // 半模态窗口页面
Button(“验证码登录”)
.bindContentCover(this.isPresentInLoginView,this.defaultLogin(),{ modalTransition: ModalTransition.NONE}) // 全屏模态转场
.onClick(() => {
if (this.isConfirmed) { // 判断是否同意协议
// 半模态页面中跳转全屏模态登录页
this.isPresentInLoginView = true;
}
})
}
3、通过点击第二步中的按钮跳转到全屏模态组件(CaptureLogin),并通过isDefaultLogin控制两种登录组件的条件渲染:true(手机验证码登录),false(二维码登录),同时通过TransitionEffect.move()实现组件间转场, 从而实现组件转场类似页面转场的效果。
build() {
Stack({ alignContent: Alignment.TopStart }) {
if (this.isDefaultLogin) {
CaptchaLogin() // 手机验证码登录
.transition(TransitionEffect.move(TransitionEdge.START).animation({ duration: EffectDuration, curve: Curve.Linear })) // 从左边推出
} else {
AccountLogin() // 账号暗码登录
.transition(TransitionEffect.move(TransitionEdge.END).animation({ duration: EffectDuration, curve: Curve.Linear })) // 从右边推出
}
}
}
性能知识点

容器限定条件渲染组件的革新范围
工程布局&模块范例

multimodaltransition // har范例
|—src/main/ets/view
| |—HalfModalWindow.ets // 视图层-主页
|—src/main/ets/model
| |—AccountLogin.ets // 模子层-账号暗码登录页
自我先容一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里不绝到如今。
深知大多数HarmonyOS鸿蒙开发工程师,想要提拔技能,通常是本身探索发展大概是报班学习,但对于培训机构动则几千的学费,着实压力不小。本身不成体系的自学效果低效又漫长,而且极易遇到天花板技能故步自封!
因此网络整理了一份《2024年HarmonyOS鸿蒙开发全套学习资料》,初志也很简朴,就是渴望可以大概资助到想自学提拔又不知道该从何学起的朋侪,同时减轻各人的负担。



既有恰当小白学习的零根本资料,也有恰当3年以上履历的小搭档深入学习提拔的进阶课程,根本涵盖了95%以上HarmonyOS鸿蒙开发知识点,真正体系化!
由于文件比力大,这里只是将部分目次大纲截图出来,每个节点内里都包罗大厂面经、学习条记、源码讲义、实战项目、讲授视频,而且会连续更新
如果你以为这些内容对你有资助,可以添加VX:vip204888 (备注鸿蒙获取)

一个人可以走的很快,但一群人才气走的更远。岂论你是正从事IT行业的老鸟或是对IT行业感爱好的新人,都接待扫码到场我们的的圈子(技能交换、学习资源、职场吐槽、大厂内推、口试辅导),让我们一起学习发展!
5-1712664315681)]
一个人可以走的很快,但一群人才气走的更远。岂论你是正从事IT行业的老鸟或是对IT行业感爱好的新人,都接待扫码到场我们的的圈子(技能交换、学习资源、职场吐槽、大厂内推、口试辅导),让我们一起学习发展!

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!qidao123.com:ToB企服之家,中国第一个企服评测及软件市场,开放入驻,技术点评得现金

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

×
回复

使用道具 举报

登录后关闭弹窗

登录参与点评抽奖  加入IT实名职场社区
去登录
快速回复 返回顶部 返回列表