如何设置 FrameLayout 高度以匹配子组件之一
How to set FrameLayout height to match one of the child component
我有以下框架布局,其中包含 TextView
和 ProgressBar
。在一个给定时间,只显示其中一个。 hideText
标志最初设置为 false。
<FrameLayout
android:layout_width="match_parent"
android:layout_height="wrap_content">
<TextView
android:id="@+id/textview_detail_title"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="@{model.text}"
android:visibility="@{model.hideText}" />
<ProgressBar
android:id="@+id/progress_loader"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:visibility="@{!model.hideText}" />
</FrameLayout>
TextView
中的文本是动态获取的,因此该组件的高度在运行前是未知的。当我将 hideText
标志设置为 true
时,框架布局的高度缩小以匹配进度条。但是,我希望框架布局保持其初始高度(即 TextView
的高度并在中间显示进度条。
有没有办法指定 ProgressBar
的 android:layout_height
属性 以匹配 TextView 的高度?
您需要将视图导入布局文件。
<data>
<import type="android.view.View"/>
...
</data>
而对于文本则这样:
android:visibility="@{model.hideText == true ? View.INVISIBLE : View.VISIBLE}"
对于 ProgressBar 这个:
android:visibility="@{model.hideText == true ? View.VISIBLE : View.INVISIBLE}"
我有以下框架布局,其中包含 TextView
和 ProgressBar
。在一个给定时间,只显示其中一个。 hideText
标志最初设置为 false。
<FrameLayout
android:layout_width="match_parent"
android:layout_height="wrap_content">
<TextView
android:id="@+id/textview_detail_title"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="@{model.text}"
android:visibility="@{model.hideText}" />
<ProgressBar
android:id="@+id/progress_loader"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:visibility="@{!model.hideText}" />
</FrameLayout>
TextView
中的文本是动态获取的,因此该组件的高度在运行前是未知的。当我将 hideText
标志设置为 true
时,框架布局的高度缩小以匹配进度条。但是,我希望框架布局保持其初始高度(即 TextView
的高度并在中间显示进度条。
有没有办法指定 ProgressBar
的 android:layout_height
属性 以匹配 TextView 的高度?
您需要将视图导入布局文件。
<data>
<import type="android.view.View"/>
...
</data>
而对于文本则这样:
android:visibility="@{model.hideText == true ? View.INVISIBLE : View.VISIBLE}"
对于 ProgressBar 这个:
android:visibility="@{model.hideText == true ? View.VISIBLE : View.INVISIBLE}"