欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android之沉浸式狀態(tài)欄的實現(xiàn)方法、狀態(tài)欄透明

 更新時間:2017年02月03日 15:01:05   作者:peterXu00800  
本篇文章主要介紹了Android之沉浸式狀態(tài)欄的實現(xiàn)方法、狀態(tài)欄透明,具有一定的參考價值,有興趣的可以了解一下。

現(xiàn)在越來越多的軟件都開始使用沉浸式狀態(tài)欄了,下面總結(jié)一下沉浸式狀態(tài)欄的兩種使用方法

注意!沉浸式狀態(tài)欄只支持安卓4.4及以上的版本

狀態(tài)欄:4.4上是漸變色,5.0上是完全透明,本文模擬器為4.4演示

效果圖:

這里寫圖片描述

注意!兩種方法的區(qū)別:

第一種:為頂部欄跟隨當前activity的布局文件的背景的顏色,使用方便,不過也有點問題就是,如果有底部虛擬導航鍵的話,導航鍵的背景跟頂部的顏色一樣,比如:

這里寫圖片描述 

第二種:是通過設置頂部欄的顏色來顯示的,可以解決第一種的不足,比如:

這里寫圖片描述

第一種使用方法:

第一、首先在values、values-v19、values-v21文件夾下的styles.xml都設置一個 Translucent System Bar 風格的Theme,如下圖:

這里寫圖片描述

values/style.xml:

<style name="TranslucentTheme" parent="AppTheme">
  <!--在Android 4.4之前的版本上運行,直接跟隨系統(tǒng)主題-->
</style>

values-v19/style.xml:

<style name="TranslucentTheme" parent="Theme.AppCompat.Light.DarkActionBar">
  <item name="android:windowTranslucentStatus">true</item>
  <item name="android:windowTranslucentNavigation">true</item>
</style>

values-v21/style.xml:

<style name="TranslucentTheme" parent="Theme.AppCompat.Light.DarkActionBar">
  <item name="android:windowTranslucentStatus">false</item>
  <item name="android:windowTranslucentNavigation">true</item>
  <!--Android 5.x開始需要把顏色設置透明,否則導航欄會呈現(xiàn)系統(tǒng)默認的淺灰色-->
  <item name="android:statusBarColor">@android:color/transparent</item>
</style>

第二、在清單文件中配置需要沉浸式狀態(tài)欄的activity加入theme

<activity android:name=".ImageActivity" android:theme="@style/TranslucentTheme" />
<activity android:name=".ColorActivity" android:theme="@style/TranslucentTheme" />

第三、在Activity的布局文件中的跟布局加入“android:fitsSystemWindows=”true””,但是,這里需要區(qū)分一下,就是背景是圖片還是純色:

1.當背景為圖片時,布局可以這么寫:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:background="@drawable/imgs_bj"
  android:fitsSystemWindows="true">

</RelativeLayout>

效果:

2.當背景為純色,我們需要對布局劃分一下,標題布局與內(nèi)容布局,先把根布局背景設置成標題布局的背景色,然后標題背景色可以不用設置直接使用根布局的背景色,最后內(nèi)容布局背景色設置為白色

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:background="@color/colorPrimary" //根布局背景設置成“標題布局”想要的顏色
  android:fitsSystemWindows="true"
  android:orientation="vertical">

  <!--標題布局-->
  <RelativeLayout
    android:layout_width="match_parent"
    android:layout_height="55dp"
    android:background="@color/color_31c27c">

    <TextView
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_centerInParent="true"
      android:text="這是標題"
      android:textColor="@android:color/white"
      android:textSize="20sp" />

  </RelativeLayout>

  <!--內(nèi)容布局-->
  <LinearLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@android:color/white" //內(nèi)容區(qū)域背景設置成白色
    android:gravity="center"
    android:orientation="vertical">

    <Button
      android:layout_marginTop="120dp"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:padding="8dp"
      android:text="顯示信息"
      android:onClick="showMsg"
      />
  </LinearLayout>

</LinearLayout>

效果圖:

這里寫圖片描述

好了,以上就是沉浸式狀態(tài)欄實現(xiàn)的全過程,但是還有一點值得注意的就是,如果我們activity比較多,每一個頁面都添加Android:fitsSystemWindows="true" 比較麻煩,我們需要改動一下:

寫一個基類BaseColorActivity.class,代碼如下:

public abstract class BaseColorActivity extends AppCompatActivity {

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    //這一行注意!看本文最后的說明?。。?!
    supportRequestWindowFeature(Window.FEATURE_NO_TITLE);

    setContentView(getLayoutResId());//把設置布局文件的操作交給繼承的子類

    ViewGroup contentFrameLayout = (ViewGroup) findViewById(Window.ID_ANDROID_CONTENT);
    View parentView = contentFrameLayout.getChildAt(0);
    if (parentView != null && Build.VERSION.SDK_INT >= 14) {
      parentView.setFitsSystemWindows(true);
    }
  }

  /**
   * 返回當前Activity布局文件的id
   *
   * @return
   */
  abstract protected int getLayoutResId();

}

然后需要沉浸狀態(tài)欄的activity繼承該基類:

public class ColorActivity extends BaseColorActivity {

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    //這里不需要寫setContentView()!
  }

  @Override
  protected int getLayoutResId() {
    //onCreate的方法中不需要寫setContentView(),直接把當前activity的布局文件在這里返回就行了!
    return R.layout.activity_color;
  }
}

然后需要沉浸狀態(tài)欄的activity的布局文件中就可以把android:fitsSystemWindows="true"這行代碼給省略了!

第二種使用方法(未完):

這里寫圖片描述 

寫個工具類StatusBarCompat.class:

public class StatusBarCompat {

  private static final int INVALID_VAL = -1;
  private static final int COLOR_DEFAULT = Color.parseColor("#20000000");

  @TargetApi(Build.VERSION_CODES.LOLLIPOP)
  public static void compat(Activity activity, int statusColor)
  {

    //當前手機版本為5.0及以上 
    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP)
    {
      if (statusColor != INVALID_VAL)
      {
        activity.getWindow().setStatusBarColor(statusColor);
      }
      return;
    }

    //當前手機版本為4.4
    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT && Build.VERSION.SDK_INT < Build.VERSION_CODES.LOLLIPOP)
    {
      int color = COLOR_DEFAULT;
      ViewGroup contentView = (ViewGroup) activity.findViewById(android.R.id.content);
      if (statusColor != INVALID_VAL)
      {
        color = statusColor;
      }
      View statusBarView = new View(activity);
      ViewGroup.LayoutParams lp = new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT,
          getStatusBarHeight(activity));
      statusBarView.setBackgroundColor(color);
      contentView.addView(statusBarView, lp);
    }

  }

  public static void compat(Activity activity)
  {
    compat(activity, INVALID_VAL);
  }


  public static int getStatusBarHeight(Context context)
  {
    int result = 0;
    int resourceId = context.getResources().getIdentifier("status_bar_height", "dimen", "android");
    if (resourceId > 0)
    {
      result = context.getResources().getDimensionPixelSize(resourceId);
    }
    return result;
  }

}

使用方法:

在當前activity的onCreate中,調(diào)用方法StatusBarCompat.compat就可以了:

//第二個參數(shù)是想要設置的顏色
StatusBarCompat.compat(this, Color.RED);

如果嫌每個activity都要寫有點麻煩,那就寫個基類來完成這一步:

public class BaseActivity extends AppCompatActivity {

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    supportRequestWindowFeature(Window.FEATURE_NO_TITLE);
    super.onCreate(savedInstanceState);

    StatusBarCompat.compat(this, Color.RED);
  }
}

然后每個activity的頁面繼承該BaseActivity就可以了!

關于上面代碼中提示注意的那個地方的說明:

隱藏系統(tǒng)title注意的兩點:

1、繼承AppCompatActivity時使用:

supportRequestWindowFeature(Window.FEATURENOTITLE)

2、繼承activity時使用:

requestWindowFeature(Window.FEATURENOTITLE) 

文本相關下載:點擊免費下載源碼及apk文件

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • 詳解Kotlin協(xié)程的異常處理機制

    詳解Kotlin協(xié)程的異常處理機制

    協(xié)程會遇到各種異常情況,比如協(xié)程被取消、協(xié)程內(nèi)部發(fā)生錯誤、協(xié)程之間的異常傳播等,這些異常情況需要我們正確地處理,否則可能會導致程序崩潰、資源泄露或者邏輯錯誤,本文將介紹 Kotlin 協(xié)程的異常處理機制,需要的朋友可以參考下
    2023-09-09
  • Android應用開發(fā)中CardView的初步使用指南

    Android應用開發(fā)中CardView的初步使用指南

    這篇文章主要介紹了Android應用開發(fā)中CardView的初步使用指南,CardView主要處理一些卡片型的視圖布局,需要的朋友可以參考下
    2016-02-02
  • 淺談android nexus私服的使用

    淺談android nexus私服的使用

    這篇文章主要介紹了淺談android nexus私服的使用,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-12-12
  • android 屏幕亮度調(diào)節(jié)方法詳解

    android 屏幕亮度調(diào)節(jié)方法詳解

    分析一下自動調(diào)節(jié)屏幕亮度手機隨著光線的強度自我調(diào)節(jié),也就是在亮的光線下屏幕自動亮一些,暗的時候就自動調(diào)暗一些,本文將詳細介紹android 屏幕亮度調(diào)節(jié)
    2012-11-11
  • Android自定義button點擊效果的兩種方式

    Android自定義button點擊效果的兩種方式

    這篇文章主要為大家詳細介紹了Android自定義button點擊效果的兩種方式,感興趣的小伙伴們可以參考一下
    2016-05-05
  • TabLayout+ViewPager2的簡單使用詳解

    TabLayout+ViewPager2的簡單使用詳解

    這篇文章主要為大家詳細介紹了TabLayout+ViewPager2的簡單使用,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-09-09
  • Android實現(xiàn)一鍵鎖屏功能

    Android實現(xiàn)一鍵鎖屏功能

    這篇文章主要介紹了Android實現(xiàn)一鍵鎖屏,在xml中創(chuàng)建device_admin.xml,在manifest中加入詳細文件,本文結(jié)合示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-10-10
  • Android 解決WebView多進程崩潰的方法

    Android 解決WebView多進程崩潰的方法

    這篇文章主要介紹了Android 解決WebView多進程崩潰的方法,幫助大家更好的理解和學習使用Android開發(fā),感興趣的朋友可以了解下
    2021-03-03
  • android xml實現(xiàn)按鈕的圓角、陰影效果及按下變化效果的實現(xiàn)代碼

    android xml實現(xiàn)按鈕的圓角、陰影效果及按下變化效果的實現(xiàn)代碼

    這篇文章主要介紹了android xml實現(xiàn)按鈕的圓角、陰影效果以及按下變化效果,通過五個xml文件實現(xiàn)按鈕的圓角陰影效果,代碼也很簡單,需要的朋友可以參考下
    2021-05-05
  • Flutter實現(xiàn)掃二維碼功能

    Flutter實現(xiàn)掃二維碼功能

    這篇文章主要為大家詳細介紹了Flutter實現(xiàn)掃二維碼功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03

最新評論