Android 让Activity部分透明、并作出流畅的进场动画

2024-03-27 23:50

本文主要是介绍Android 让Activity部分透明、并作出流畅的进场动画,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

让一个界面部分透明现在已经比较常见的了,比如网易云下面界面:
在这里插入图片描述
“歌单详情”这个View大概占屏幕高的3/4,界面除了这个view其他部分则变成了半透明状态。

怎么实现这个View呢?我自己主要研究了三套做法,并用实际开发项目的情况做了测试,作出下面的小结:

  1. 把这个界面做成一个PopWindow
    优势:完全能够满足任意动画要求,其实算是最好解决Activity半透明方案了。
    劣势:PopWindow内部不能做一些依赖性比较高的网络请求,如果我们要在这个界面请求数据或者一直监听外面Activity的数据,那么PopWindow做不到。
  2. 将该界面做成一个Dialog形式
    优势:和PopWindow一样,能够完成任意动画要求
    劣势:适配有问题,非常依赖外部Activty,如果我们切入到后台,把屏幕在全面屏和有虚拟键盘的屏来回切,那么再回到该界面中,Dialog可能会出现适配问题,而且为了这么一个Dialog去读 小米、华为的全面屏适配文档,很伤。(测试们很喜欢这么玩的)
  3. 将该界面做成一个Activity
    优势:可以完全解决上述两种情况劣势带来的问题,Activity在功能上比PopWindow和Dialog更多元更强大
    劣势:动画要自己琢磨,进场动画如果不处理的话会很僵硬。

综上所述,我使用第三种方案来做这个界面。

第一步:设置Activity的入场、出场动画(我们用View动画来做):

//进场动画  anim/bottom_in
<set xmlns:android="http://schemas.android.com/apk/res/android"><translateandroid:duration="300"android:fromYDelta="100%p"android:toYDelta="0" /></set>
//出场动画 anim/bottom_out
<set xmlns:android="http://schemas.android.com/apk/res/android"><translateandroid:duration="300"android:fromYDelta="25"android:toYDelta="100%p" />
</set>

然后在代码中布置好动画:

      Intent intent = new Intent(BeforeActivity.this, AfterActivity.class);startActivity(intent);overridePendingTransition(R.anim.bottom_in,R.anim.bottom_silent);

第二步:写activity的manifest配置:

//我们要将其设置为可以透明显示的<activityandroid:name=".XXXActivity"android:theme="@style/XXXTheme"><meta-dataandroid:name="android.max_aspect"android:value="ratio_float" />
</activity><style name="XXXTheme" parent="Theme.AppCompat"><item name="android:windowIsTranslucent">true</item><item name="android:windowBackground">@android:color/transparent</item><item name="windowNoTitle">true</item><item name="android:windowAnimationStyle">@null</item></style>

第三步,在Activity的代码中设置状态栏透明:

//XXXActivity@Overrideprotected void onCreateView(Bundle savedInstanceState) {supportRequestWindowFeature(Window.FEATURE_NO_TITLE);setContentView(R.layout.activity_song_detail);getWindow().setLayout(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT);getWindow().setFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS,WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);}

第四步:设置Activity的布局XML文件:

<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"tools:context=".song.mvp.view.SongDetailActivity">//View用来铺整个View,因为我们的RelativeLayout会用到background,这样的话如果有圆角,会出现很僵硬的白色//我们也是根据这个view来做透明<Viewandroid:id="@+id/view"android:layout_width="match_parent"android:layout_height="match_parent"android:background="#636363"/><RelativeLayoutandroid:layout_width="match_parent"android:layout_height="match_parent"><Viewandroid:layout_width="match_parent"android:layout_height="wrap_content"android:layout_above="@+id/rl_bottom" /><RelativeLayoutandroid:id="@+id/rl_bottom"android:layout_width="match_parent"android:layout_height="wrap_content"android:background="#ffffff"android:layout_alignParentBottom="true">....</RelativeLayout></RelativeLayout>
</FrameLayout>

其实到这里已经差不多,但是Activity的出现会带一块黑黑的屏(就是我们透明view)进来,效果不太好
所以我们要让一开始这个view是透明的,在动画完成后该view变成半透明的

通过写alpha动画:

//view的透明变半透明动画
//view_to_translate
<set xmlns:android="http://schemas.android.com/apk/res/android"><alphaandroid:duration="200"android:fromAlpha="0"android:toAlpha="0.7"/>
</set>

然后在Activity onStart的时候执行这个动画:

//设置延迟开始的时间还蛮关键的,能决定动画是否平滑@Overrideprotected void onStart() {super.onStart();if (toTranslateIn == null) {toTranslateIn = AnimationUtils.loadAnimation(this, R.anim.view_to_translate_in);toTranslateIn.setFillAfter(true);toTranslateIn.setStartOffset(200);}findViewById(R.id.view).startAnimation(toTranslateIn);}

效果如下:
在这里插入图片描述

这篇关于Android 让Activity部分透明、并作出流畅的进场动画的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

Android ClassLoader加载机制详解

《AndroidClassLoader加载机制详解》Android的ClassLoader负责加载.dex文件,基于双亲委派模型,支持热修复和插件化,需注意类冲突、内存泄漏和兼容性问题,本文给大家介... 目录一、ClassLoader概述1.1 类加载的基本概念1.2 android与Java Class

Android DataBinding 与 MVVM使用详解

《AndroidDataBinding与MVVM使用详解》本文介绍AndroidDataBinding库,其通过绑定UI组件与数据源实现自动更新,支持双向绑定和逻辑运算,减少模板代码,结合MV... 目录一、DataBinding 核心概念二、配置与基础使用1. 启用 DataBinding 2. 基础布局

Android ViewBinding使用流程

《AndroidViewBinding使用流程》AndroidViewBinding是Jetpack组件,替代findViewById,提供类型安全、空安全和编译时检查,代码简洁且性能优化,相比Da... 目录一、核心概念二、ViewBinding优点三、使用流程1. 启用 ViewBinding (模块级

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

Kotlin Compose Button 实现长按监听并实现动画效果(完整代码)

《KotlinComposeButton实现长按监听并实现动画效果(完整代码)》想要实现长按按钮开始录音,松开发送的功能,因此为了实现这些功能就需要自己写一个Button来解决问题,下面小编给大... 目录Button 实现原理1. Surface 的作用(关键)2. InteractionSource3.

使用WPF实现窗口抖动动画效果

《使用WPF实现窗口抖动动画效果》在用户界面设计中,适当的动画反馈可以提升用户体验,尤其是在错误提示、操作失败等场景下,窗口抖动作为一种常见且直观的视觉反馈方式,常用于提醒用户注意当前状态,本文将详细... 目录前言实现思路概述核心代码实现1、 获取目标窗口2、初始化基础位置值3、创建抖动动画4、动画完成后

使用animation.css库快速实现CSS3旋转动画效果

《使用animation.css库快速实现CSS3旋转动画效果》随着Web技术的不断发展,动画效果已经成为了网页设计中不可或缺的一部分,本文将深入探讨animation.css的工作原理,如何使用以及... 目录1. css3动画技术简介2. animation.css库介绍2.1 animation.cs

Android NDK版本迭代与FFmpeg交叉编译完全指南

《AndroidNDK版本迭代与FFmpeg交叉编译完全指南》在Android开发中,使用NDK进行原生代码开发是一项常见需求,特别是当我们需要集成FFmpeg这样的多媒体处理库时,本文将深入分析A... 目录一、android NDK版本迭代分界线二、FFmpeg交叉编译关键注意事项三、完整编译脚本示例四

Android与iOS设备MAC地址生成原理及Java实现详解

《Android与iOS设备MAC地址生成原理及Java实现详解》在无线网络通信中,MAC(MediaAccessControl)地址是设备的唯一网络标识符,本文主要介绍了Android与iOS设备M... 目录引言1. MAC地址基础1.1 MAC地址的组成1.2 MAC地址的分类2. android与I