像 Uber 一样透明的操作栏和状态栏

Posted

技术标签:

【中文标题】像 Uber 一样透明的操作栏和状态栏【英文标题】:Transparent action bar and status bar like Uber 【发布时间】:2017-10-12 12:27:29 【问题描述】:

我已经对此主题进行了一些研究,但我找不到适合我的应用程序/活动的解决方案。

    我试图获得一个透明的操作栏。

首先,我尝试更改 androidManifest.xml 中的主题:

values/styles.xml:

<style name="AppTheme.ActionBar.Transparent" parent="AppTheme">
    <item name="android:windowContentOverlay">@null</item>
    <item name="windowActionBarOverlay">true</item>
    <item name="colorPrimary">@android:color/transparent</item>

values-v21/styles.xml:

  <style name="AppTheme.ActionBar.Transparent" parent="AppTheme">
        <item name="colorPrimary">@android:color/transparent</item>
    </style>

结果就是这样:

所以我只得到一些浅灰色的操作栏,左侧/右侧有一些间隙。

其次,我尝试在我的布局中使用fitsSystemWindow="true"android:background="@android:color/transparent",但它也没有解决问题。

 <?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout
    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_
    android:layout_
    android:fitsSystemWindows="true"
    tools:context="com.example.poweranimal.letsgo.Application.MainActivity">

    <android.support.design.widget.AppBarLayout
        android:layout_
        android:layout_
        android:background="@android:color/transparent">

        <android.support.v7.widget.Toolbar
            android:id="@+id/toolbar"
            android:layout_
            android:layout_/>


    </android.support.design.widget.AppBarLayout>

    <include layout="@layout/content_main" />

    </android.support.design.widget.CoordinatorLayout>

但我得到与以前相同的输出:( 2. 此外,我还尝试了获取透明状态栏:

getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);

<item name="android:statusBarColor">@android:color/transparent</item>

但这也不起作用(没有任何改变)。

我真正想要的是这样的:

如果有人对我有可能的解决方案,那就太酷了。

提前致谢。

【问题讨论】:

【参考方案1】:

1. 首先,您必须更改layout 结构以在透明ToolbarStatusBar 下显示MAP,并从现有的gap 中删除左右gap Toolbar

activity_main.xml:

<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout
    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_
    android:layout_
    android:fitsSystemWindows="false">

    <RelativeLayout
        android:layout_
        android:layout_>

        <android.support.v7.widget.Toolbar
            android:id="@+id/toolbar"
            android:layout_
            android:layout_
            android:layout_marginTop="24dp"
            android:elevation="1dp" />

        <LinearLayout
            android:layout_
            android:layout_
            android:background="@drawable/sample_map">

            <!-- put your content here -->

        </LinearLayout>
    </RelativeLayout>
</android.support.design.widget.CoordinatorLayout>

2. 在您的MainActivity 中,执行以下操作以初始化Toolbar 并使ToolbarStatusBartransparent

@Override
protected void onCreate(Bundle savedInstanceState) 
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);

    // Toolbar :: Transparent
    toolbar.setBackgroundColor(Color.TRANSPARENT);

    setSupportActionBar(toolbar);
    getSupportActionBar().setTitle("***");
    getSupportActionBar().setDisplayHomeAsUpEnabled(true);

    // Status bar :: Transparent
    Window window = this.getWindow();

    if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP)
    
        window.addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS);
        window.addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
        window.setStatusBarColor(Color.TRANSPARENT);
    

    ...........
    .................. 

3. 将以下主题应用到您的MainActivity

values/styles.xml:

<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
    .......
    ...........

</style>

<style name="AppTheme.NoActionBar">
    <item name="windowActionBar">false</item>
    <item name="windowNoTitle">true</item>
</style>

AndroidManifest.xml:

<activity
    android:name=".EmptyActivity"
    android:theme="@style/AppTheme.NoActionBar">

</activity>

输出:

仅供参考,我刚刚在我的内容LinearLayout 中使用了地图的示例图像来显示行为。对于您的情况,将您的所有内容(searchbar, map)放入其中。

希望对你有帮助~

【讨论】:

@FAT 它给了我一个透明的状态栏,但它不像 Uber 那样完全透明。 经过10页的搜索终于找到了这个答案。太好了!【参考方案2】:

试试这个。

将以下代码添加到您的活动中以将状态栏设置为透明,对于操作栏,您应该尝试使用透明背景的自定义操作栏。

  private void settingStatusBarTransparent() 

        if (Build.VERSION.SDK_INT == Build.VERSION_CODES.KITKAT) 
            Window w = getWindow(); // in Activity's onCreate() for instance
            w.setFlags(WindowManager.LayoutParams.FLAG_LAYOUT_NO_LIMITS, WindowManager.LayoutParams.FLAG_LAYOUT_NO_LIMITS);
            getWindow().getDecorView().setSystemUiVisibility(
                    View.SYSTEM_UI_FLAG_LAYOUT_STABLE
                            | View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN);
            w.setFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_NAVIGATION, WindowManager.LayoutParams.FLAG_TRANSLUCENT_NAVIGATION);
            w.setFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS, WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
        


        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) 
            getWindow().setNavigationBarColor(Color.BLACK);
            getWindow().setFlags(WindowManager.LayoutParams.FLAG_LAYOUT_NO_LIMITS, WindowManager.LayoutParams.FLAG_LAYOUT_NO_LIMITS);
            getWindow().getDecorView().setSystemUiVisibility(
                    View.SYSTEM_UI_FLAG_LAYOUT_STABLE
                            | View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN);
            getWindow().setStatusBarColor(Color.TRANSPARENT);
            //setStatusBarTranslucent(true);
        
    

【讨论】:

这是唯一对我有用的解决方案。谢谢。 底部导航栏也变得透明。我的按钮与系统按钮重叠【参考方案3】:

试试这个:

首先在colors.xml 中添加自定义颜色,如下所示:

<color name="transparent_white">#80FFFFFF</color>

然后将此颜色设置为Where to? xml 文件主布局的背景。

在这一行中#80 是颜色的不透明度(简而言之,与透明相反)。

颜色前面的前两个字母:

    '#00' - 全透明色 '#FF'没有任何定义 - 完全不透明的颜色

用下面的XML更改并尝试

<android.support.design.widget.AppBarLayout
    android:layout_
    android:layout_
    android:background="@color/transparent_white">

希望这能解决你的问题。

【讨论】:

【参考方案4】:

试试这个:在你的活动中:设置全屏标志

    @TargetApi(Build.VERSION_CODES.LOLLIPOP)
    @Override
    protected void onCreate(Bundle savedInstanceState) 
        getWindow().getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_STABLE | View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN);
        if (android.os.Build.VERSION.SDK_INT >= 21)
            getWindow().setStatusBarColor(Color.TRANSPARENT);
        super.onCreate(savedInstanceState);
    

现在在清单中:应用主题

<activity
        android:name=".YourActivity"
        android:label="@string/app_name"
        android:screenOrientation="portrait"
        android:theme="@style/AppTheme.ActionBar.Transparent"/>

在 res/styles.xml 中

<style name="AppTheme.ActionBar.Transparent" parent="AppTheme">
    <item name="colorPrimary">@android:color/transparent</item>
    <item name="windowActionBarOverlay">false</item>
    <item name="android:windowContentOverlay">@null</item>
    <item name="android:windowActionBarOverlay">false</item>
</style>

并在您的CoordinatorLayout 中设置android:fitsSystemWindows="false"

fitsSystemWindows="false" : 正常绘制视图,状态下 bar 因为你设置了窗口标志。

fitsSystemWindows="true" : 绘制状态下的视图 bar 因为您设置了窗口标志,但添加了一个顶部 填充,以便在状态栏下方绘制内容并且它们不会 重叠。

【讨论】:

不幸的是,您的解决方案没有任何变化。如果我设置android:fitsSystemWindows="false"状态栏就会消失。 statusbar disappears?它会变得透明。!顺便说一句..我使用代码,它对我很有效..然后你应该检查其他答案【参考方案5】:

首先我的观点是,您创建自定义操作栏并将操作栏的背景设置为透明。

<?xml version="1.0" encoding="utf-8"?>
<android.support.v7.widget.Toolbar xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_
    android:layout_
    android:background="@android:color/transparent"
    android:id="@+id/toolBar"
    android:minHeight="?attr/actionBarSize"
    app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
    app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">

    <ImageButton
        android:background="@android:color/transparent"
        android:id="@+id/btnBackButton"
        android:layout_
        android:layout_
        android:src="@drawable/back" />


   <ImageView
       android:layout_
       android:layout_
       android:layout_gravity="center_vertical|center_horizontal"
       android:id="@+id/toolbar_image"
       android:background="@android:color/transparent"
       android:src="@drawable/logo_header_new"
       android:visibility="visible"
       />
</android.support.v7.widget.Toolbar>

【讨论】:

【参考方案6】:

您需要做的就是在您的主题中设置这些属性:

<item name="android:windowTranslucentStatus">true</item>
<item name="android:windowTranslucentNavigation">true</item>

您希望拥有透明状态栏的活动/容器布局需要此属性集:

android:fitsSystemWindows=”true”

希望对你有帮助

【讨论】:

以上是关于像 Uber 一样透明的操作栏和状态栏的主要内容,如果未能解决你的问题,请参考以下文章

iOS 7,状态栏和导航栏:像 Reeder 一样使用侧面板隐藏或滑动

Android透明状态栏和沉浸式的实现

棒棒糖上完全透明的状态栏和导航栏

在 Swift iOS 8 中设置透明导航栏和状态栏的图像底图

半透明状态栏和工具栏

点击设备时如何隐藏状态栏和导航栏