ArkTS-页面转场动画

news2025/1/12 6:54:38

在这里插入图片描述

页面转场动画

在全局pageTransition方法内配置页面入场和页面退场时的自定义转场动效

两个页面间发生跳转,一个页面消失,另一个页面出现,这时可以配置各自页面的页面转场参数实现自定义的页面转场效果。页面转场效果写在pageTransition函数中,通过PageTransitionEnterPageTransitionExit指定页面进入和退出的动画效果。

TransitionPage1

import router from '@ohos.router'
@Entry
@Component
struct TransitionPage1 {
  @State scaleValue: number = 1
  @State opacityValue: number = 1

  build() {
    Column() {
      Image($r('app.media.pic1'))
        .width('100%')
        .height('100%')
        .scale({ x: this.scaleValue })
        .opacity(this.opacityValue)
    }
    .width('100%')
    .height('100%')
    .onClick(() => {
      router.pushUrl({
        url:'pages/TransitionPage2'
      })
    })
  }

  pageTransition() {
    PageTransitionEnter({}).onEnter((type: RouteType, progress: number) => {
      this.scaleValue = 1
      this.opacityValue = progress
    })
    PageTransitionExit({}).onExit((type: RouteType, progress: number) => {
      this.scaleValue = 1 - progress
      this.opacityValue = 1 - progress
    })
  }
}

TransitionPage2

import router from '@ohos.router'
@Entry
@Component
struct TransitionPage2 {
  @State scaleValue: number = 1
  @State opacityValue: number = 1

  build() {
    Column() {
      Image($r('app.media.pic2'))
        .width('100%')
        .height('100%')
        .scale({ x: this.scaleValue })
        .opacity(this.opacityValue)
    }
    .width('100%')
    .height('100%')
    .onClick(() => {
      router.back()
    })
  }

  pageTransition() {
    PageTransitionEnter({}).onEnter((type: RouteType, progress: number) => {
      this.scaleValue = progress
      this.opacityValue = progress
    })
    PageTransitionExit({}).onExit((type: RouteType, progress: number) => {
      this.scaleValue = 1 - progress
      this.opacityValue = 1 - progress
    })
  }
}

type配置为RouteType.None

type为RouteType.None表示对页面栈的push、pop操作均生效,type的默认值为RouteType.None。

// page A
pageTransition() {
  // 定义页面进入时的效果,从左侧滑入,时长为1200ms,无论页面栈发生push还是pop操作均可生效
  PageTransitionEnter({ type: RouteType.None, duration: 1200 })
    .slide(SlideEffect.Left)
  // 定义页面退出时的效果,向左侧滑出,时长为1000ms,无论页面栈发生push还是pop操作均可生效
  PageTransitionExit({ type: RouteType.None, duration: 1000 })
    .slide(SlideEffect.Left)
}
// page B
pageTransition() {
  // 定义页面进入时的效果,从右侧滑入,时长为1000ms,无论页面栈发生push还是pop操作均可生效
  PageTransitionEnter({ type: RouteType.None, duration: 1000 })
    .slide(SlideEffect.Right)
  // 定义页面退出时的效果,向右侧滑出,时长为1200ms,无论页面栈发生push还是pop操作均可生效
  PageTransitionExit({ type: RouteType.None, duration: 1200 })
    .slide(SlideEffect.Right)
}

禁用某页面的页面转场

通过设置页面转场的时长为0,可使该页面无页面转场动画。

pageTransition() {
  PageTransitionEnter({ type: RouteType.None, duration: 0 })
  PageTransitionExit({ type: RouteType.None, duration: 0 })
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1261747.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Non-constant range: argument must be an integer literal 警告的解决方法

升级Xcode以后,在SwiftUI开发过程中,使用ForEach语句的时候,遇到一个“Non-constant range: argument must be an integer literal ”的警告。如下图 其解决方法比较简单。在之后加上id:\.self 。 至于为什么这么加没有找到原因。姑且做个记录…

如何确定先做哪件事情。

问题描述:工作或者生活中,有许多件事情,我们应该先做那件事情。 解决办法:重要紧急的四象限法则。具体如下所示: -----------------------------------------------------------------------------------------------…

ubuntu22.04新机使用(换源,下载软件,安装显卡驱动)

换源 国内有很多Ubuntu的镜像源,包括阿里的、网易的,还有很多教育网的源,比如:清华源、中科大源。推荐使用中科大源,快得很。 /etc/apt/sources.list编辑/etc/apt/sources.list文件, 在文件最前面添加以下条目(操作前…

npm-工具包

npm-工具包 npm 介绍 npm&#xff08;Node Package Manager&#xff09;是用于管理和共享Node.js包&#xff08;包括代码、工具和资源&#xff09;的包管理工具 常用命令 局部安装包 npm install <package-name>: 安装指定的包 npm install <package-name> --save…

共聚陆丰 共参“清峰公益 凝聚慈善力量 共创美好生活”公益项目

11月25日&#xff0c;在广东省陆丰市万国大酒店&#xff0c;一场众人期待已久的“清峰公益 凝聚慈善力量 共创美好生活”公益项目正式启动&#xff0c;当地各界人士鼎力相助&#xff0c;出席活动有陆丰市潭西镇常务副镇长林济廷、陆丰市潭西镇镇府公共服务办主任陈学琳、潭西镇…

Java 简易版王者荣耀

所有包和类 GameFrame类 package newKingOfHonor;import java.awt.*; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.awt.event.KeyAdapter; import java.awt.event.KeyEvent; import java.io.File; import java.util.ArrayList;im…

串口波形延时问题再次故障测试分析

先放电路图吧 这个延时问题测试了很多天&#xff0c;怎么感觉总是有没有想到的问题可以测试&#xff0c;总是有原件可以替换改善问题&#xff0c;再次测试了三极管的C脚波形&#xff1a; 从上到下的3个波形分别是MCU出来的波形&#xff0c;经过三极管反向的波形&#xff0c;…

idea创建不了spring2.X版本,无法使用JDK8,最低支持JDK17 , 如何用idea创建spring2.X版本,使用JDK8解决方案

&#x1f9f8;欢迎来到dream_ready的博客&#xff0c;&#x1f4dc;相信您对博主首页也很感兴趣o (ˉ▽ˉ&#xff1b;) &#x1f4dc;jdk17安装全方位手把手安装教程 / 已有jdk8了&#xff0c;安装JDK17后如何配置环境变量 / 多个不同版本的JDK&#xff0c;如何配置环境变量&a…

Spark---SparkCore(三)

一、Spark广播变量和累加器 1、广播变量 1&#xff09;、广播变量理解图 2&#xff09;、广播变量使用 val conf new SparkConf() conf.setMaster("local").setAppName("brocast") val sc new SparkContext(conf) val broadCast sc.broadcast(list) …

Ilya Sutskever:师从Hinton,“驱逐”奥特曼,一个改变AI世界的天才科学

ChatGPT 已经在全球爆火&#xff0c;但大众在两周之前似乎更熟悉Sam Altman&#xff0c;而对另一位创始人 Ilya Sutskever 却了解不多。 直到前几天因为OpenA眼花缭乱的政权争夺大戏&#xff0c;OpenAI 的首席科学家Ilya Sutskever的名字逐渐被世人所知。 Ilya Sutskever在科…

利略版本的发布标志着EndeavourOS从Xfce转向KDE Plasma

导读EndeavourOS&#xff0c;一个基于 Arch Linux 的滚动发行版&#xff0c;今日发布了其最新版本——伽利略&#xff08;Galileo&#xff09;。这次更新带来了一些重大变革&#xff0c;令其用户群体充满期待。 伽利略版本除了采用最新、优质的 Linux 6.6 LTS 内核系列外&…

什么是企业数字化转型?如何利用数字化工具加快转型速度?

企业数字化转型是指将数字技术整合到所有业务领域&#xff0c;从根本上改变业务运作和为客户提供价值的方式。它包括采用新的工具、过程和策略来提高效率、创新和客户满意度。数字化转型可以帮助公司在基础层面上规划、实施和管理业务流程。它提供了员工和客户所期望的先进体验…

企业内部社区在促进员工之间的合作与共建

企业内部社区作为一种新兴的企业管理工具&#xff0c;在企业管理中展现出了巨大的价值和作用。它为企业内部员工提供了一个良好的交流互动平台&#xff0c;促进了信息共享、知识传递和团队协作&#xff0c;提升了企业的创新能力和竞争力。 企业内部社区通过问卷收集功能&#…

DjiTello + YoloV5的无人机的抽烟检测

一、效果展示 注&#xff1a;此项目纯作者自己原创&#xff0c;创作不易&#xff0c;不经同意不给予搬运权限&#xff0c;转发前请联系我&#xff0c;源码较大需要者评论获取&#xff0c;谢谢配合&#xff01; 1、未启动飞行模型无人机的目标检测。 DjiTello YOLOV5抽烟检测 …

“职场中的‘特色人物’:与‘个性’领导和同事的碰撞与成长“

文章目录 每日一句正能量前言程序员是怎么和产品经理battle的&#xff1f;科班程序员非科班程序员 程序员的团队合作密码&#xff1a;协作与领导的艺术职场人际关系的技巧后记 每日一句正能量 乌云的背后是阳光&#xff0c;阳光的背后是彩虹。 前言 在职场中&#xff0c;我们都…

护眼灯什么价位的好?好用又实惠的护眼台灯推荐

我国8&#xff5e;12岁的小学生中&#xff0c;约有47个儿童就有一个近视眼&#xff0c;近视发病率约为23%&#xff0c;中学生约为55%&#xff0c;大学生约为76%&#xff0c;全国近视眼约为3亿人&#xff0c;其中青少年约为2亿人。全国近视眼发病人数位居世界首位&#xff0c;发…

PostgreSQL 数据脱敏方式盘点

数据脱敏是一种广泛采用的保护敏感数据&#xff08;如信用卡&#xff0c;社保卡&#xff0c;地址等信息&#xff09;的方法。脱敏数据不仅仅是为了保护你和客户的数据安全&#xff0c;在一些情况下&#xff0c;法律也有相应要求&#xff0c;最著名的例子就是 GDPR。 市面上也有…

docker-compose部署zabbix+grafana

1.引言 1.1目的 zabbixgrafana实现图形化监控 2.部署环境 服务器ip服务版本192.168.5.137zabbix-server6.0.21192.168.5.137grafana10.2.2192.168.5.152zabbix-client6.0.21 3.部署zabbix-server 3.1 创建zabbix目录 mkdir zabbix3.2 编写docker-compose文件 cd zabbix…

医学影像PACS源码:PACS系统的基础知识(DICOM、HL7、SWF)

1、PACS PACS是Picture Archiving and Communication Systems首字母缩写&#xff0c;全称为影像储存和传输系统&#xff0c;涉及放射医学、计算机技术、通讯技术及数字图像技术等&#xff0c;是医院信息系统的重要组成部分&#xff0c;是将数字医疗设备(如X线、CT、MRI、超声、…

P8A110-A120经典赛题

Web应用程序SQL Inject安全攻防 任务环境说明&#xff1a; 服务器场景&#xff1a;WebServ2003&#xff08;用户名&#xff1a;administrator&#xff1b;密码&#xff1a;空&#xff09;服务器场景操作系统&#xff1a;Microsoft Windows2003 Server 服务器场景安装服务/工…