【问题标题】:How do I make AppBarLayout 25% of screen whilst it's in a CoordinatorLayout?如何在 CoordinatorLayout 中使 AppBarLayout 占屏幕的 25%?
【发布时间】:2021-03-30 15:29:32
【问题描述】:

我有一个AppBarLayout,我想占据屏幕的 25%。如果我在没有Coordinator layoutConstraintLayout 的情况下执行此操作,我可以简单地使用具有25% 的Guideline,但是父布局是一个协调器,所以我不确定在这里做什么。我想这样做而不在 DP 中设置高度,例如150dp,并在纯 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>

【问题讨论】:

    标签: android android-layout android-coordinatorlayout android-appbarlayout


    【解决方案1】:

    在不破坏 AppBarLayout 的某些功能的情况下,我看不到任何可能的方法在 XML 中执行此操作

    但您可以通过编程方式获得所需的结果

    val appbar: AppBarLayout = findViewById(R.id.fragprofile_app_bar)
    val lp = appbar.layoutParams as CoordinatorLayout.LayoutParams
    lp.height = (resources.displayMetrics.heightPixels * 0.25).toInt()
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2015-08-24
      • 2015-12-07
      • 2016-03-10
      • 2019-02-27
      • 1970-01-01
      • 2017-05-20
      相关资源
      最近更新 更多