新西兰服务器

Android中怎么创建类似Instagram的渐变背景效果


Android中怎么创建类似Instagram的渐变背景效果

发布时间:2022-04-07 17:29:50 来源:高防服务器网 阅读:76 作者:iii 栏目:编程语言

本篇内容介绍了“Android中怎么创建类似Instagram的渐变背景效果”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

效果图:

1. 在drawable文件夹创建一些渐变颜色的资源

color1.xml

<?xml version="1.0" encoding="utf-8"?>  <shape xmlns:android="http://schemas.android.com/apk/res/android">    <gradient      android:startColor="#614385"      android:endColor="#516395"      android:angle="0"/>  </shape>

color2.xml

<?xml version="1.0" encoding="utf-8"?>  <shape xmlns:android="http://schemas.android.com/apk/res/android">    <gradient      android:startColor="#5f2c82"      android:endColor="#49a09d"      android:angle="45"/>  </shape>

color3.xml

<?xml version="1.0" encoding="utf-8"?>  <shape xmlns:android="http://schemas.android.com/apk/res/android">    <gradient      android:startColor="#4776E6"      android:endColor="#8E54E9"      android:angle="90"/>  </shape>

color4.xml

<?xml version="1.0" encoding="utf-8"?>  <shape xmlns:android="http://schemas.android.com/apk/res/android">    <gradient      android:startColor="#7141e2"      android:endColor="#d46cb3"      android:angle="135"/>  </shape>

2. 创建一个用到上面创建的渐变色的动画序列,命名为animation_list.xml,放进去drawable文件夹

<?xml version="1.0" encoding="utf-8"?>  <animation-list xmlns:android="http://schemas.android.com/apk/res/android">    <item      android:drawable="@drawable/color1"      android:duration="10000" />    <item      android:drawable="@drawable/color2"      android:duration="10000" />    <item      android:drawable="@drawable/color3"      android:duration="10000" />    <item      android:drawable="@drawable/color4"      android:duration="10000" />  </animation-list>

3. 将上面已经创建好的动画序列应用到你layout的背景顶层的view中

<?xml version="1.0" encoding="utf-8"?>  <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    xmlns:tools="http://schemas.android.com/tools"    android:layout_width="match_parent"    android:layout_height="match_parent"    android:orientation="vertical"    android:background="@drawable/animation_list"    android:id="@+id/container">    <!-- Child Views -->  </LinearLayout>

4.在你的activity中用AnimationDrawable去实现过渡效果

LinearLayout container = (LinearLayout) findViewById(R.id.container);  AnimationDrawable anim = (AnimationDrawable) container.getBackground();  anim.setEnterFadeDuration(6000);  anim.setExitFadeDuration(2000);    // 开始播放动画:在onResume方法中开始播放渐变动画  @Override  protected void onResume() {    super.onResume();    if (anim != null && !anim.isRunning())      anim.start();  }       // 停止播放动画:在onPause方法中停止播放渐变动画  @Override  protected void onPause() {    super.onPause();    if (anim != null && anim.isRunning())      anim.stop();  }

将状态栏设置透明(去除状态栏)

values/styles.xml

<resources>     <style name="Theme.AppTheme.TranslucentStatusBar" parent="Theme.AppCompat.Light.NoActionBar" />   </resources>

values-v19/styles.xml

<resources>     <style name="Theme.AppTheme.TranslucentStatusBar" parent="Theme.AppCompat.Light.NoActionBar">       <item name="android:windowTranslucentStatus">true</item>     </style>   </resources>

values-v21/styles.xml

<resources>     <style name="Theme.AppTheme.TranslucentStatusBar" parent="Theme.AppCompat.Light.NoActionBar">       <item name="android:statusBarColor">@android:color/transparent</item>     </style>   </resources>

values-v23/styles.xml

<resources>     <style name="Theme.AppTheme.TranslucentStatusBar" parent="Theme.AppCompat.Light.NoActionBar">       <item name="android:statusBarColor">@android:color/transparent</item>       <item name="android:windowLightStatusBar">true</item>     </style>   </resources>
public class MainActivity extends AppCompatActivity {     @Override     protected void onCreate(Bundle savedInstanceState) {       super.onCreate(savedInstanceState);        // 加入下面的代码      if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {         findViewById(android.R.id.content).setSystemUiVisibility(             View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN | View.SYSTEM_UI_FLAG_LAYOUT_STABLE);       }          setContentView(R.layout.activity_splash);     }   }   <activity     android:name=".MainActivity"  android:theme="@style/Theme.AppTheme.TranslucentStatusBar" />

“Android中怎么创建类似Instagram的渐变背景效果”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注高防服务器网网站,小编将为大家输出更多高质量的实用文章!

[微信提示:高防服务器能助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。

[图文来源于网络,不代表本站立场,如有侵权,请联系高防服务器网删除]
[