android 状态栏标题栏设置成渐变,Android透明状态栏或者渐变色状态栏

一、透明状态栏:

我们应用的正常状态栏都是黑乎乎的,就像下面这样(模拟器版本Android4.4.2):

93069ac0154e367fc6c23d78182cd74f.png

不好看,我们希望的是向这样的:

522c3ef9e556751ae73269e190879903.png

这样感觉比黑黑的statusBar好看多了。

实现方法:

1.去/res/values/styles.xml里找到你activity或者application使用的theme,theme一定要使用NoActionBar的随便一种;

2.因为这种效果是Android4.4+才推出的效果,所以我们需要在代码里判断当前的手机操作系统是否在19以上,如果是才去设置全屏显示,代码如下:

if(Build.VERSION.SDK_INT>= Build.VERSION_CODES.KITKAT) {

getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_NAVIGATION);} 只需要在你的activity的setContentView下边执行上面的代码就好了,就可以实现上图的效果了,我用Android5.1.1的真机和6.0的真机测试效果如下:

e206dcde3dd8cc2e64e1591d7938ac7d.png(Android5.1.1)90dacfebc1e7844b2d584db71918489e.png(Android6.0.1)

备注:

网上很多会说还要在布局的时候设置

android:fitsSystemWindows="true"

android:clipToPadding="true"但是我的布局里并没有加这两个属性,我看郭霖大神写的时候使用的是

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

if (Build.VERSION.SDK_INT >= 21) {

View decorView = getWindow().getDecorView();

int option = View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION

| View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN

| View.SYSTEM_UI_FLAG_LAYOUT_STABLE;

decorView.setSystemUiVisibility(option);

getWindow().setNavigationBarColor(Color.TRANSPARENT);

getWindow().setStatusBarColor(Color.TRANSPARENT);

}

上面这种方法,这样写的话是必须在Android21以上才能使用,因为setNavigationBarColor和setStatusBarColor是21才有的方法,而上面那些参数配置,其实我上面写的两行代码底层也是做了一样的设置,所以原理是一样的,都是通过设置全屏等来实现,不过我试了一下郭神的方法theme必须继承Theme.AppCompat或者他的子类才能正常显示,否则无效。不过如果是Android21以上的版本还是用郭神的方法效果更好,效果和6.0的一致不会有黑边。

二、渐变状态栏:

我们平时还经常可以看到下面这种颜色渐变的状态栏:

9bb46549005bde882d91871e65c158d4.png

其实这个也很简单,只需要你的activity继承自v7包里的AppCompatActivity,theme使用

其他什么都不需要设置,不过这个效果是只能在Android5.0+的机型上才有上边的效果。

好了,就先介绍这些了,我把代码也上传一下点击下载

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您好!针对您的问题,您可以使用 Android 中的 Toolbar 控件来实现滑动渐变标题。 具体实现步骤如下: 1. 在布局文件中添加 Toolbar 控件,并设置其高度为 wrap_content。 2. 在代码中通过 findViewById 获取 Toolbar 对象,并调用 setSupportActionBar 方法将其设置为当前 Activity 的 ActionBar。 3. 在 Activity 的 onCreate 方法中,通过 getSupportActionBar().setDisplayHomeAsUpEnabled(true) 设置标题左侧显示返回按钮。 4. 在滑动时,通过监听 RecyclerView 的滚动事件,动态改变标题的背景颜色和透明度,实现滑动渐变效果。 5. 在 onScrollStateChanged 方法中,根据当前滚动状态判断是否需要执行动画效果。 下面是一个简单的示例代码: ```java // 获取 Toolbar 对象 Toolbar toolbar = findViewById(R.id.toolbar); // 将 Toolbar 设置为当前 Activity 的 ActionBar setSupportActionBar(toolbar); // 显示返回按钮 getSupportActionBar().setDisplayHomeAsUpEnabled(true); // 监听 RecyclerView 的滚动事件 recyclerView.addOnScrollListener(new RecyclerView.OnScrollListener() { @Override public void onScrollStateChanged(@NonNull RecyclerView recyclerView, int newState) { super.onScrollStateChanged(recyclerView, newState); if (newState == RecyclerView.SCROLL_STATE_IDLE) { // 滑动停止时执行动画效果 animateToolbarColor(0xFF0000FF, 0x00000000); } } @Override public void onScrolled(@NonNull RecyclerView recyclerView, int dx, int dy) { super.onScrolled(recyclerView, dx, dy); // 获取当前 RecyclerView 的滚动位置 int scrollY = recyclerView.computeVerticalScrollOffset(); // 计算标题透明度 int alpha = Math.min(255, scrollY * 2); // 执行动画效果 animateToolbarColor(Color.argb(alpha, 0xFF, 0x00, 0x00), Color.argb(0, 0x00, 0x00, 0x00)); } }); // 改变标题背景颜色和透明度的动画效果 private void animateToolbarColor(int fromColor, int toColor) { ValueAnimator colorAnimation = ValueAnimator.ofObject(new ArgbEvaluator(), fromColor, toColor); colorAnimation.setDuration(250); colorAnimation.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() { @Override public void onAnimationUpdate(ValueAnimator animator) { toolbar.setBackgroundColor((int) animator.getAnimatedValue()); } }); colorAnimation.start(); } ``` 希望这个示例能够对您有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值