Android CoordinatorLayout - Android 版本之间的不一致
Android CoordinatorLayout - Inconsistencies between Android versions
-
android
-
android-support-library
-
android-coordinatorlayout
-
android-collapsingtoolbarlayout
-
android-tablayout
我使用 Android 支持设计库为我正在开发的应用构建配置文件视图。
个人资料由一张header背景和一张header图片组成,中间有一张圆形的个人资料图片。另外,header.
的底角有个小view
header 下方是带有 tablayout 的 viewpager。
我面临的问题是 Android 5.1.1 和 5.0.2 及以下版本之间存在不一致。
配置文件在装有 5.1.1 Android 的 Nexus 5 上的显示方式如下:
配置文件在 Xperia Z2 5.0.2 Android 上的显示方式如下:
代码如下:
<FrameLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
android:background="@color/white">
<android.support.design.widget.CoordinatorLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true">
<android.support.design.widget.AppBarLayout
android:id="@+id/appbar"
android:layout_height="250dp"
android:layout_width="match_parent"
android:fitsSystemWindows="true"
android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">
<android.support.design.widget.CollapsingToolbarLayout
android:id="@+id/profile_collapsingtoolbar"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
app:layout_scrollFlags="scroll|exitUntilCollapsed">
<ImageView
android:id="@+id/profile_header"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
android:scaleType="centerCrop"
app:layout_collapseMode="parallax"
app:layout_scrollFlags="scroll|enterAlways"/>
<com.makeramen.roundedimageview.RoundedImageView
android:id="@+id/profile_image"
android:layout_width="90dp"
android:layout_height="90dp"
app:riv_corner_radius="45dp"
app:riv_border_color="@color/red"
app:riv_border_width="1dp"
android:layout_gravity="center"
app:layout_collapseMode="none"
app:layout_scrollFlags="scroll|enterAlways" />
<FrameLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:padding="10dp"
android:layout_margin="5dp"
android:layout_gravity="bottom|right"
android:background="@drawable/shape_usertype_background">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textSize="12sp"
android:textColor="@color/white"
android:text="Professional"/>
</FrameLayout>
<android.support.v7.widget.Toolbar
android:id="@+id/profile_toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
app:layout_collapseMode="pin"
app:layout_scrollFlags="scroll|enterAlways"
app:popupTheme="@style/ThemeOverlay.AppCompat.Light"/>
</android.support.design.widget.CollapsingToolbarLayout>
</android.support.design.widget.AppBarLayout>
<android.support.v4.view.ViewPager
android:id="@+id/profile_pager"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
android:paddingTop="45dp"/>
<android.support.design.widget.TabLayout
android:id="@+id/profile_tablayout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="bottom"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
app:tabGravity="center"
app:tabMode="scrollable"
app:tabIndicatorColor="@color/red"
app:tabTextColor="@color/main_dark"
app:tabSelectedTextColor="@color/red"
android:fitsSystemWindows="true"
app:layout_anchor="@id/appbar"
app:layout_anchorGravity="bottom"
android:background="@color/white"
/>
<android.support.design.widget.FloatingActionButton
android:id="@+id/profile_floatingbutton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_margin="16dp"
android:clickable="true"
android:src="@android:drawable/ic_menu_share"
app:backgroundTint="@color/red"
app:layout_anchor="@id/profile_pager"
app:layout_anchorGravity="bottom|right|end"
app:rippleColor="@android:color/darker_gray"
app:borderWidth="0dp"/>
</android.support.design.widget.CoordinatorLayout>
</FrameLayout>
那么,有人知道如何解决这个问题吗?
谢谢!
不幸的是,Design Library 有很多问题,应该考虑 "beta" 而不是生产就绪。根据您的应用 运行 所使用的 Android 版本,它的外观和行为会有所不同,我发现的问题不仅与 CoordinatorLayout
有关,甚至像 TextInputLayout
这样相对简单的小部件也不是到处都以同样的方式工作。知道设计库是相当新鲜的产品,我不确定是否值得花自己的时间解决(不修复)Google 错误。我只是等待库的下一次迭代,期待改进和错误修复。
android
android-support-library
android-coordinatorlayout
android-collapsingtoolbarlayout
android-tablayout
我使用 Android 支持设计库为我正在开发的应用构建配置文件视图。
个人资料由一张header背景和一张header图片组成,中间有一张圆形的个人资料图片。另外,header.
的底角有个小viewheader 下方是带有 tablayout 的 viewpager。
我面临的问题是 Android 5.1.1 和 5.0.2 及以下版本之间存在不一致。
配置文件在装有 5.1.1 Android 的 Nexus 5 上的显示方式如下:
配置文件在 Xperia Z2 5.0.2 Android 上的显示方式如下:
代码如下:
<FrameLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
android:background="@color/white">
<android.support.design.widget.CoordinatorLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true">
<android.support.design.widget.AppBarLayout
android:id="@+id/appbar"
android:layout_height="250dp"
android:layout_width="match_parent"
android:fitsSystemWindows="true"
android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">
<android.support.design.widget.CollapsingToolbarLayout
android:id="@+id/profile_collapsingtoolbar"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
app:layout_scrollFlags="scroll|exitUntilCollapsed">
<ImageView
android:id="@+id/profile_header"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
android:scaleType="centerCrop"
app:layout_collapseMode="parallax"
app:layout_scrollFlags="scroll|enterAlways"/>
<com.makeramen.roundedimageview.RoundedImageView
android:id="@+id/profile_image"
android:layout_width="90dp"
android:layout_height="90dp"
app:riv_corner_radius="45dp"
app:riv_border_color="@color/red"
app:riv_border_width="1dp"
android:layout_gravity="center"
app:layout_collapseMode="none"
app:layout_scrollFlags="scroll|enterAlways" />
<FrameLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:padding="10dp"
android:layout_margin="5dp"
android:layout_gravity="bottom|right"
android:background="@drawable/shape_usertype_background">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textSize="12sp"
android:textColor="@color/white"
android:text="Professional"/>
</FrameLayout>
<android.support.v7.widget.Toolbar
android:id="@+id/profile_toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
app:layout_collapseMode="pin"
app:layout_scrollFlags="scroll|enterAlways"
app:popupTheme="@style/ThemeOverlay.AppCompat.Light"/>
</android.support.design.widget.CollapsingToolbarLayout>
</android.support.design.widget.AppBarLayout>
<android.support.v4.view.ViewPager
android:id="@+id/profile_pager"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
android:paddingTop="45dp"/>
<android.support.design.widget.TabLayout
android:id="@+id/profile_tablayout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="bottom"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
app:tabGravity="center"
app:tabMode="scrollable"
app:tabIndicatorColor="@color/red"
app:tabTextColor="@color/main_dark"
app:tabSelectedTextColor="@color/red"
android:fitsSystemWindows="true"
app:layout_anchor="@id/appbar"
app:layout_anchorGravity="bottom"
android:background="@color/white"
/>
<android.support.design.widget.FloatingActionButton
android:id="@+id/profile_floatingbutton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_margin="16dp"
android:clickable="true"
android:src="@android:drawable/ic_menu_share"
app:backgroundTint="@color/red"
app:layout_anchor="@id/profile_pager"
app:layout_anchorGravity="bottom|right|end"
app:rippleColor="@android:color/darker_gray"
app:borderWidth="0dp"/>
</android.support.design.widget.CoordinatorLayout>
</FrameLayout>
那么,有人知道如何解决这个问题吗?
谢谢!
Design Library 有很多问题,应该考虑 "beta" 而不是生产就绪。根据您的应用 运行 所使用的 Android 版本,它的外观和行为会有所不同,我发现的问题不仅与 CoordinatorLayout
有关,甚至像 TextInputLayout
这样相对简单的小部件也不是到处都以同样的方式工作。知道设计库是相当新鲜的产品,我不确定是否值得花自己的时间解决(不修复)Google 错误。我只是等待库的下一次迭代,期待改进和错误修复。