Android 全屏展示

在Android 4.4以后,引入了Translucent System Bar的系特性,用于解決系統(tǒng)通知欄問題。


image.png

image.png

系統(tǒng)的通知欄和app界面融為一體,不再是孤立通知欄了。
但是這兩個是有點區(qū)別的下面細說。

具體操作 方法一

(系統(tǒng)狀態(tài)欄一般25dp)

  • 主要修改的操作在 style.xml 文件中。

  • 要在Activity中使用 Translucent System Bar 特性,首先需要到AndroidManifest中為指定的Activity設(shè)置Theme, 注意 不能直接在values/style.xml直接去自定義 Translucet System Bar 的Theme,因為特性具有SDK版本 的限制,所以要分別創(chuàng)建values、values-v19/style.xml、values-v21/style.xml文件然后就可以操作了。在對應SDK版本中定制對應的樣式了。

  • 在Android 4.4之前的版本上運行,直接跟隨系統(tǒng)主題

<style name="StatusTheme" parent="AppTheme">
</style>

  • 在Android 4.4 版本上運行 values-v19/style.xml
<style name="StatusTheme" parent="Theme.AppCompat.Light.DarkActionBar">
    <!--設(shè)置為true這狀態(tài)欄會變成深灰色-->
        <item name="android:windowTranslucentStatus">false</item>
        <!--設(shè)置為只有在上面的設(shè)置為true時 此true 下面會顯示一個系統(tǒng)狀態(tài)欄同上面-->
        <item name="android:windowTranslucentNavigation">false</item>
</style>
  • 在Android 5.0 版本及以上上運行 values-v21/style.xml
<style name="StatusTheme" parent="Theme.AppCompat.Light.DarkActionBar">
     <!--設(shè)置為true這狀態(tài)欄會變成深灰色-->
        <item name="android:windowTranslucentStatus">false</item>
        <!--設(shè)置為只有在上面的設(shè)置為true時 此true 下面會顯示一個系統(tǒng)狀態(tài)欄同上面-->
        <item name="android:windowTranslucentNavigation">false</item>
        <!--Android 5.x開始需要把顏色設(shè)置透明,否則導航欄會呈現(xiàn)系統(tǒng)默認的淺灰色-->
        <item name="android:statusBarColor">@android:color/transparent</item>
</style>

注意,這三個文件中的values/style.mxl對應的主題theme名稱要相同。

第一個圖片樣式

在AndroidManifest.xml中對指定Activity的theme樣式
并在此activity的根布局中加入:
android:fitsSystemWindows="true"
把背景替換為要演示的圖片即可

第二種圖片樣式

Tab欄和系統(tǒng)導航欄分開來設(shè)置。

<style name="StatusTheme" parent="Theme.AppCompat.Light.DarkActionBar">
    <!--設(shè)置為true這狀態(tài)欄會變成深灰色-->
        <item name="android:windowTranslucentStatus">false</item>
        <!--設(shè)置為只有在上面的設(shè)置為true時 此true 下面會顯示一個系統(tǒng)狀態(tài)欄同上面-->
        <item name="android:windowTranslucentNavigation">false</item>
        <!--Android 5.x開始需要把顏色設(shè)置透明,否則導航欄會呈現(xiàn)系統(tǒng)默認的淺灰色-->
        <item name="android:statusBarColor">@android:color/transparent</item>
</style>

方法二 代碼方式實現(xiàn)

通過代碼獲取系統(tǒng)狀態(tài)欄并對其修改

public class TestActivity extends AppCompatActivity {
  //在Activity的setContentView后進行修改系統(tǒng)狀態(tài)欄
    @Override
    public void setContentView(int layoutResID) {
        super.setContentView(layoutResID);
        setStatusBar();
    }
    // 為狀態(tài)欄添加默認樣式
    protected void setStatusBar(int color, int statusBarAlpha) {
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { // 版本號大于5.0
            getWindow().addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS);
            getWindow().clearFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
            getWindow().setStatusBarColor(calculateStatusColor(color, statusBarAlpha));
        } else if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) { // 版本號大于4.4
            getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
            ViewGroup decorView = (ViewGroup) getWindow().getDecorView();
            View fakeStatusBarView = decorView.findViewById(FAKE_STATUS_BAR_VIEW_ID);
            if (fakeStatusBarView != null) {
                if (fakeStatusBarView.getVisibility() == View.GONE) {
                    fakeStatusBarView.setVisibility(View.VISIBLE);
                }
                fakeStatusBarView.setBackgroundColor(calculateStatusColor(color, statusBarAlpha));
            } else {
                decorView.addView(createStatusBarView(this, color, statusBarAlpha));
            }
            setRootView(this);
        } 
    }

    /**
     * 生成一個和狀態(tài)欄大小相同的半透明矩形條
     * @param activity 需要設(shè)置的activity
     * @param color    狀態(tài)欄顏色值
     * @param alpha    透明值
     * @return 狀態(tài)欄矩形條
     */
    private static View createStatusBarView(@ColorInt int color, int alpha) {
        // 獲得狀態(tài)欄高度
        int resourceId = getResources().getIdentifier("status_bar_height", "dimen", "android");
        // 繪制一個和狀態(tài)欄一樣高的矩形
        View statusBarView = new View(this);
        LinearLayout.LayoutParams params =
            new LinearLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, getResources().getDimensionPixelSize(resourceId));
        statusBarView.setLayoutParams(params);
        statusBarView.setBackgroundColor(calculateStatusColor(color, alpha));
        statusBarView.setId(FAKE_STATUS_BAR_VIEW_ID);
        return statusBarView;
    }

    // 設(shè)置根布局參數(shù)
    private static void setRootView() {
        ViewGroup parent = (ViewGroup) findViewById(android.R.id.content);
        for (int i = 0, count = parent.getChildCount(); i < count; i++) {
            View childView = parent.getChildAt(i);
            if (childView instanceof ViewGroup) {
                childView.setFitsSystemWindows(true);
                ((ViewGroup) childView).setClipToPadding(true);
            }
        }
    }

    /**
     * 計算狀態(tài)欄顏色
     * @param color color值
     * @param alpha alpha值
     * @return 最終的狀態(tài)欄顏色
     */
    private static int calculateStatusColor(@ColorInt int color, int alpha) {
        if (alpha == 0) {
            return color;
        }
        float a = 1 - alpha / 255f;
        int red = color >> 16 & 0xff;
        int green = color >> 8 & 0xff;
        int blue = color & 0xff;
        red = (int) (red * a + 0.5);
        green = (int) (green * a + 0.5);
        blue = (int) (blue * a + 0.5);
        return 0xff << 24 | red << 16 | green << 8 | blue;
    }
}

首先在一個BaseActivity中做些工作

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容