Android fragment 转场动画

2024-02-27 17:44
文章标签 android 动画 fragment 转场

本文主要是介绍Android fragment 转场动画,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

fragment 动画

  • 使用 setCustomAnimations 绘制转场动画
  • 使用共享元素的动画
    • recyclerview in
  • 参考地址

使用 setCustomAnimations 绘制转场动画

概述

在 Android 中,可以使用 setCustomAnimations() 方法来绘制自定义的 Fragment 转场动画。该方法接受四个参数,分别对应四种类型的动画:

  • enter: 新 Fragment 进入时的动画
  • exit: 旧 Fragment 离开时的动画
  • popEnter: 从 Back Stack 中弹出 Fragment 时的动画
  • popExit: 将 Fragment 添加到 Back Stack 时的动画

步骤

  1. 创建动画资源文件。

    转场动画可以使用 XML 动画资源文件来定义。每个动画资源文件定义一种类型的动画,例如 enter.xmlexit.xmlpop_enter.xmlpop_exit.xml

    动画资源文件的格式与其他动画资源文件相同,可以使用各种动画属性来定义动画效果。例如,可以使用 alpha 属性来定义透明度变化,使用 translate 属性来定义位移变化,使用 scale 属性来定义缩放变化等等。

  2. 在 Fragment 中设置自定义动画。

    在 Fragment 中,可以使用 setCustomAnimations() 方法来设置自定义的转场动画。该方法接受四个参数,分别对应四个类型的动画资源文件的 ID。

    例如,以下代码设置了 Fragment 进入和离开时的自定义动画:

fragment.setCustomAnimations(R.anim.enter, R.anim.exit);

示例

以下是一个示例,演示如何使用 setCustomAnimations() 方法来绘制自定义的 Fragment 转场动画。

1. 创建动画资源文件

<set xmlns:android="http://schemas.android.com/apk/res/android"><alphaandroid:fromAlpha="0.0"android:toAlpha="1.0"android:duration="500" />
</set><set xmlns:android="http://schemas.android.com/apk/res/android"><alphaandroid:fromAlpha="1.0"android:toAlpha="0.0"android:duration="500" />
</set>

2. 在 Fragment 中设置自定义动画

public class MyFragment extends Fragment {@Overridepublic View onCreateView(LayoutInflater inflater, ViewGroup container,Bundle savedInstanceState) {// Inflate the layout for this fragmentView view = inflater.inflate(R.layout.fragment_my, container, false);// Set custom animationssetCustomAnimations(R.anim.enter, R.anim.exit);return view;}
}

效果

运行该示例后,可以看到 Fragment 进入和离开时都会播放自定义的动画效果。

注意事项

  • 使用 setCustomAnimations() 方法设置自定义动画时,必须在 Fragment 添加到 Activity 之前调用该方法。
  • 如果不设置自定义动画,则 Fragment 会使用系统默认的转场动画。

进阶

除了使用 XML 动画资源文件来定义动画效果之外,还可以使用代码来定义动画效果。例如,可以使用 ObjectAnimator 类来创建更加复杂的动画效果。

使用共享元素的动画

FirstFragment 中:

public class FirstFragment extends Fragment {@Overridepublic View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {return inflater.inflate(R.layout.fragment_first, container, false);}@Overridepublic void onViewCreated(View view, Bundle savedInstanceState) {super.onViewCreated(view, savedInstanceState);ImageView sharedImageView = view.findViewById(R.id.shared_image);sharedImageView.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {navigateToSecondFragment(sharedImageView);}});}private void navigateToSecondFragment(View sharedElement) {SecondFragment newFragment = new SecondFragment();FragmentTransaction transaction = getParentFragmentManager().beginTransaction();// 设置退出动画TransitionSet exitTransition = new TransitionSet();exitTransition.addTransition(new Fade());exitTransition.addTransition(new Slide(Gravity.START));newFragment.setExitTransition(exitTransition);// 设置共享元素退出动画TransitionSet sharedElementExitTransition = new TransitionSet();sharedElementExitTransition.addTransition(new ChangeBounds());sharedElementExitTransition.addTransition(new ChangeTransform());sharedElementExitTransition.addTransition(new ChangeImageTransform());newFragment.setSharedElementExitTransition(sharedElementExitTransition);// 设置进入动画TransitionSet enterTransition = new TransitionSet();enterTransition.addTransition(new Fade());enterTransition.addTransition(new Slide(Gravity.END));newFragment.setEnterTransition(enterTransition);// 设置共享元素进入动画TransitionSet sharedElementEnterTransition = new TransitionSet();sharedElementEnterTransition.addTransition(new ChangeBounds());sharedElementEnterTransition.addTransition(new ChangeTransform());sharedElementEnterTransition.addTransition(new ChangeImageTransform());newFragment.setSharedElementEnterTransition(sharedElementEnterTransition);// 添加共享元素 可以添加多个共享元素transaction.addSharedElement(sharedElement, sharedElement.getTransitionName());// 替换当前 Fragmenttransaction.replace(R.id.fragment_container_view, newFragment);transaction.addToBackStack(tag);transaction.commit();}
}

SecondFragment 中:

public class SecondFragment extends Fragment {@Overridepublic void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);}@Overridepublic View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {return inflater.inflate(R.layout.fragment_second, container, false);}
}

recyclerview in

对于在 RecyclerView 或 ListView 中使用共享元素的情况,你可以在适配器的 onBindViewHolder() 方法中为每个共享元素设置 transitionName 属性。

假设你有一个 RecyclerView,其中的每个项目包含一个 ImageView,并且你想要在这些 ImageView 之间应用共享元素动画。在 RecyclerView 的适配器中,你可以这样设置 transitionName

public class MyAdapter extends RecyclerView.Adapter<MyAdapter.ViewHolder> {private List<MyData> dataList;public MyAdapter(List<MyData> dataList) {this.dataList = dataList;}@NonNull@Overridepublic ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_layout, parent, false);return new ViewHolder(view);}@Overridepublic void onBindViewHolder(@NonNull ViewHolder holder, int position) {MyData data = dataList.get(position);// 设置 transitionNameholder.imageView.setTransitionName("shared_image_" + position);// 加载图片或其他数据// Glide.with(holder.imageView.getContext()).load(data.getImageUrl()).into(holder.imageView);}@Overridepublic int getItemCount() {return dataList.size();}public static class ViewHolder extends RecyclerView.ViewHolder {ImageView imageView;public ViewHolder(@NonNull View itemView) {super(itemView);imageView = itemView.findViewById(R.id.imageView);}}
}

在这个示例中,我们在适配器的 onBindViewHolder() 方法中为每个 ImageView 设置了唯一的 transitionName 属性,例如 "shared_image_" + position。这样做可以确保 RecyclerView 中的每个共享元素都具有唯一的 transitionName,以便在共享元素动画中正确识别和匹配它们。

参考地址

chatgpt

这篇关于Android fragment 转场动画的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/753135

相关文章

Android中Dialog的使用详解

《Android中Dialog的使用详解》Dialog(对话框)是Android中常用的UI组件,用于临时显示重要信息或获取用户输入,本文给大家介绍Android中Dialog的使用,感兴趣的朋友一起... 目录android中Dialog的使用详解1. 基本Dialog类型1.1 AlertDialog(

Android Kotlin 高阶函数详解及其在协程中的应用小结

《AndroidKotlin高阶函数详解及其在协程中的应用小结》高阶函数是Kotlin中的一个重要特性,它能够将函数作为一等公民(First-ClassCitizen),使得代码更加简洁、灵活和可... 目录1. 引言2. 什么是高阶函数?3. 高阶函数的基础用法3.1 传递函数作为参数3.2 Lambda

Android自定义Scrollbar的两种实现方式

《Android自定义Scrollbar的两种实现方式》本文介绍两种实现自定义滚动条的方法,分别通过ItemDecoration方案和独立View方案实现滚动条定制化,文章通过代码示例讲解的非常详细,... 目录方案一:ItemDecoration实现(推荐用于RecyclerView)实现原理完整代码实现

Android App安装列表获取方法(实践方案)

《AndroidApp安装列表获取方法(实践方案)》文章介绍了Android11及以上版本获取应用列表的方案调整,包括权限配置、白名单配置和action配置三种方式,并提供了相应的Java和Kotl... 目录前言实现方案         方案概述一、 androidManifest 三种配置方式

Android WebView无法加载H5页面的常见问题和解决方法

《AndroidWebView无法加载H5页面的常见问题和解决方法》AndroidWebView是一种视图组件,使得Android应用能够显示网页内容,它基于Chromium,具备现代浏览器的许多功... 目录1. WebView 简介2. 常见问题3. 网络权限设置4. 启用 JavaScript5. D

Android如何获取当前CPU频率和占用率

《Android如何获取当前CPU频率和占用率》最近在优化App的性能,需要获取当前CPU视频频率和占用率,所以本文小编就来和大家总结一下如何在Android中获取当前CPU频率和占用率吧... 最近在优化 App 的性能,需要获取当前 CPU视频频率和占用率,通过查询资料,大致思路如下:目前没有标准的

Android开发中gradle下载缓慢的问题级解决方法

《Android开发中gradle下载缓慢的问题级解决方法》本文介绍了解决Android开发中Gradle下载缓慢问题的几种方法,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、网络环境优化二、Gradle版本与配置优化三、其他优化措施针对android开发中Gradle下载缓慢的问

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

Android里面的Service种类以及启动方式

《Android里面的Service种类以及启动方式》Android中的Service分为前台服务和后台服务,前台服务需要亮身份牌并显示通知,后台服务则有启动方式选择,包括startService和b... 目录一句话总结:一、Service 的两种类型:1. 前台服务(必须亮身份牌)2. 后台服务(偷偷干

Android kotlin语言实现删除文件的解决方案

《Androidkotlin语言实现删除文件的解决方案》:本文主要介绍Androidkotlin语言实现删除文件的解决方案,在项目开发过程中,尤其是需要跨平台协作的项目,那么删除用户指定的文件的... 目录一、前言二、适用环境三、模板内容1.权限申请2.Activity中的模板一、前言在项目开发过程中,尤