如何在 CoordinatorLayout 中使 AppBarLayout 占屏幕的 25%?
How do I make AppBarLayout 25% of screen whilst it's in a CoordinatorLayout?
我有一个 AppBarLayout
,我想占屏幕的 25%。如果我在没有 Coordinator layout
和 ConstraintLayout
的情况下这样做,我可以简单地使用一个 Guideline
和 25%,但是父布局是一个协调器,所以我不确定在这里做什么。我想在 150dp
等 DP 中不设置高度并在纯 XML.
中进行设置
<?xml version="1.0" encoding="utf-8"?>
<androidx.coordinatorlayout.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_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<com.google.android.material.appbar.AppBarLayout
android:id="@+id/fragprofile_app_bar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@drawable/background_gradient"
android:orientation="vertical">
<TextView
android:id="@+id/tv_app_name"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:drawablePadding="3dp"
android:fontFamily="@font/concert_one"
android:gravity="center"
android:layout_gravity="center"
android:textColor="@color/colorWhite"
android:textSize="24sp"
app:layout_constraintBottom_toTopOf="@+id/tablayout"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_scrollFlags="scroll|enterAlways"
app:layout_constraintTop_toTopOf="parent" />
<com.google.android.material.tabs.TabLayout
android:id="@+id/tablayout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:layout_constraintBottom_toBottomOf="parent"
app:tabIndicatorColor="@color/colorWhite"
app:tabIndicatorHeight="3dp"
app:tabSelectedTextColor="@color/colorWhite"
app:tabTextColor="@color/colorWhite60PercentOpacity" />
</com.google.android.material.appbar.AppBarLayout>
<androidx.viewpager.widget.ViewPager
android:id="@+id/viewpager"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/colorWhite"
app:layout_behavior="@string/appbar_scrolling_view_behavior" />
</androidx.coordinatorlayout.widget.CoordinatorLayout>
我在 XML 中看不出有任何可能的方法可以在不破坏 AppBarLayout
的某些功能的情况下执行此操作
但您可以通过编程方式获得所需的结果
val appbar: AppBarLayout = findViewById(R.id.fragprofile_app_bar)
val lp = appbar.layoutParams as CoordinatorLayout.LayoutParams
lp.height = (resources.displayMetrics.heightPixels * 0.25).toInt()
我有一个 AppBarLayout
,我想占屏幕的 25%。如果我在没有 Coordinator layout
和 ConstraintLayout
的情况下这样做,我可以简单地使用一个 Guideline
和 25%,但是父布局是一个协调器,所以我不确定在这里做什么。我想在 150dp
等 DP 中不设置高度并在纯 XML.
<?xml version="1.0" encoding="utf-8"?>
<androidx.coordinatorlayout.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_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<com.google.android.material.appbar.AppBarLayout
android:id="@+id/fragprofile_app_bar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@drawable/background_gradient"
android:orientation="vertical">
<TextView
android:id="@+id/tv_app_name"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:drawablePadding="3dp"
android:fontFamily="@font/concert_one"
android:gravity="center"
android:layout_gravity="center"
android:textColor="@color/colorWhite"
android:textSize="24sp"
app:layout_constraintBottom_toTopOf="@+id/tablayout"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_scrollFlags="scroll|enterAlways"
app:layout_constraintTop_toTopOf="parent" />
<com.google.android.material.tabs.TabLayout
android:id="@+id/tablayout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:layout_constraintBottom_toBottomOf="parent"
app:tabIndicatorColor="@color/colorWhite"
app:tabIndicatorHeight="3dp"
app:tabSelectedTextColor="@color/colorWhite"
app:tabTextColor="@color/colorWhite60PercentOpacity" />
</com.google.android.material.appbar.AppBarLayout>
<androidx.viewpager.widget.ViewPager
android:id="@+id/viewpager"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/colorWhite"
app:layout_behavior="@string/appbar_scrolling_view_behavior" />
</androidx.coordinatorlayout.widget.CoordinatorLayout>
我在 XML 中看不出有任何可能的方法可以在不破坏 AppBarLayout
但您可以通过编程方式获得所需的结果
val appbar: AppBarLayout = findViewById(R.id.fragprofile_app_bar)
val lp = appbar.layoutParams as CoordinatorLayout.LayoutParams
lp.height = (resources.displayMetrics.heightPixels * 0.25).toInt()