AppBarLayout 和工具栏在 Android 4.x 上不可见
AppBarLayout and Toolbar invisible on Android 4.x
我正在使用 v22 设计支持库中的新 AppbarLayout 和 Toolbar。但它们在 4.x 设备上似乎是不可见的。这是一个已知的问题?我该如何解决?
这是我的 XML:
<android.support.design.widget.AppBarLayout
android:id="@+id/appbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:background="?attr/colorPrimary"
app:title="inSight Source"
app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
app:layout_scrollFlags="scroll|enterAlways"/>
</android.support.design.widget.AppBarLayout>
它们处于相对布局中。将它们移动到 CoordinatorLayout 中并没有解决问题。
AppbarLayout 和 Toolbar 在那里,因为当你拉动底层滚动视图时有一个 'shade',但它们是不可见的。
我的完整布局:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/main_content"
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.design.widget.AppBarLayout
android:id="@+id/setting_appbar"
android:layout_width="match_parent"
android:layout_height="wrap_content">
<android.support.v7.widget.Toolbar
android:id="@+id/setting_toolbar"
android:layout_width="match_parent"
android:layout_height="50dp"
android:background="#fff"
app:title="inSight Source" />
</android.support.design.widget.AppBarLayout>
<ImageView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/setting_bg_img"
android:layout_centerVertical="true"
android:layout_centerHorizontal="true"
android:src="@drawable/baseimg"
android:scaleType="centerCrop" />
<ScrollView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_below="@+id/setting_appbar" >
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:padding="10dp">
<com.devspark.robototextview.widget.RobotoTextView
android:id="@+id/login_insight_label"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
app:typeface="roboto_thin"
android:text="inSight Source"
android:textSize="40dp"
android:textColor="#fff"
android:layout_marginTop="20dp"
android:layout_gravity="center_horizontal" />
<com.devspark.robototextview.widget.RobotoTextView
android:id="@+id/login_companion_label"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
app:typeface="roboto_thin"
android:text="companion app"
android:textSize="20dp"
android:layout_marginTop="6dp"
android:textColor="#fff"
android:layout_below="@id/login_insight_label"
android:layout_gravity="center_horizontal" />
<!-- invisible view for margin -->
<View
android:layout_width="match_parent"
android:layout_height="30dp" />
<include
android:id="@+id/setting_card_driver"
layout="@layout/include_setting_card" />
<!-- invisible view for margin -->
<View
android:layout_width="match_parent"
android:layout_height="30dp" />
<include
android:id="@+id/setting_card_vehicle"
layout="@layout/include_setting_card" />
<!-- invisible view for margin -->
<View
android:layout_width="match_parent"
android:layout_height="30dp" />
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:padding="10dp"
android:background="#fff" >
<com.devspark.robototextview.widget.RobotoTextView
android:id="@+id/setting_info_label"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
app:typeface="roboto_regular"
android:text="Deze instellingen kunt u aanpassen in inSight Source"
android:textSize="13dp"
android:layout_marginTop="6dp"
android:textColor="@color/insight_antraciet"
android:layout_centerInParent="true" />
</RelativeLayout>
<Button
android:id="@+id/setting_logout_button"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="20dp"
android:text="LOG UIT"
android:theme="@style/ButtonStyle"
android:textColor="#fff"
android:layout_marginBottom="5dp"/>
</LinearLayout>
</ScrollView>
</RelativeLayout>
我也试过将 AppBarLayout 放在 CoordinatorLayout 中,但这并没有解决问题。
为什么要在 AppBarLayout
上使用主题?如果您删除它,您的 Toolbar
可能会再次出现。您可以将主题移动到工具栏:
app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
编辑
将此添加到您的 ImageView:
android:layout_below="@id/setting_appbar"
您的 ImageView
高于您的 Toolbar
,所以您看不到它。您可以做的另一件事是将 Toolbar
放在布局的底部,使其出现在 ImageView
.
上方
我正在使用 v22 设计支持库中的新 AppbarLayout 和 Toolbar。但它们在 4.x 设备上似乎是不可见的。这是一个已知的问题?我该如何解决?
这是我的 XML:
<android.support.design.widget.AppBarLayout
android:id="@+id/appbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:background="?attr/colorPrimary"
app:title="inSight Source"
app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
app:layout_scrollFlags="scroll|enterAlways"/>
</android.support.design.widget.AppBarLayout>
它们处于相对布局中。将它们移动到 CoordinatorLayout 中并没有解决问题。
AppbarLayout 和 Toolbar 在那里,因为当你拉动底层滚动视图时有一个 'shade',但它们是不可见的。
我的完整布局:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/main_content"
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.design.widget.AppBarLayout
android:id="@+id/setting_appbar"
android:layout_width="match_parent"
android:layout_height="wrap_content">
<android.support.v7.widget.Toolbar
android:id="@+id/setting_toolbar"
android:layout_width="match_parent"
android:layout_height="50dp"
android:background="#fff"
app:title="inSight Source" />
</android.support.design.widget.AppBarLayout>
<ImageView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/setting_bg_img"
android:layout_centerVertical="true"
android:layout_centerHorizontal="true"
android:src="@drawable/baseimg"
android:scaleType="centerCrop" />
<ScrollView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_below="@+id/setting_appbar" >
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:padding="10dp">
<com.devspark.robototextview.widget.RobotoTextView
android:id="@+id/login_insight_label"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
app:typeface="roboto_thin"
android:text="inSight Source"
android:textSize="40dp"
android:textColor="#fff"
android:layout_marginTop="20dp"
android:layout_gravity="center_horizontal" />
<com.devspark.robototextview.widget.RobotoTextView
android:id="@+id/login_companion_label"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
app:typeface="roboto_thin"
android:text="companion app"
android:textSize="20dp"
android:layout_marginTop="6dp"
android:textColor="#fff"
android:layout_below="@id/login_insight_label"
android:layout_gravity="center_horizontal" />
<!-- invisible view for margin -->
<View
android:layout_width="match_parent"
android:layout_height="30dp" />
<include
android:id="@+id/setting_card_driver"
layout="@layout/include_setting_card" />
<!-- invisible view for margin -->
<View
android:layout_width="match_parent"
android:layout_height="30dp" />
<include
android:id="@+id/setting_card_vehicle"
layout="@layout/include_setting_card" />
<!-- invisible view for margin -->
<View
android:layout_width="match_parent"
android:layout_height="30dp" />
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:padding="10dp"
android:background="#fff" >
<com.devspark.robototextview.widget.RobotoTextView
android:id="@+id/setting_info_label"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
app:typeface="roboto_regular"
android:text="Deze instellingen kunt u aanpassen in inSight Source"
android:textSize="13dp"
android:layout_marginTop="6dp"
android:textColor="@color/insight_antraciet"
android:layout_centerInParent="true" />
</RelativeLayout>
<Button
android:id="@+id/setting_logout_button"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="20dp"
android:text="LOG UIT"
android:theme="@style/ButtonStyle"
android:textColor="#fff"
android:layout_marginBottom="5dp"/>
</LinearLayout>
</ScrollView>
</RelativeLayout>
我也试过将 AppBarLayout 放在 CoordinatorLayout 中,但这并没有解决问题。
为什么要在 AppBarLayout
上使用主题?如果您删除它,您的 Toolbar
可能会再次出现。您可以将主题移动到工具栏:
app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
编辑
将此添加到您的 ImageView:
android:layout_below="@id/setting_appbar"
您的 ImageView
高于您的 Toolbar
,所以您看不到它。您可以做的另一件事是将 Toolbar
放在布局的底部,使其出现在 ImageView
.