Android布局:两个固定宽度视图之间的可变宽度视图
如何水平布置3个视图,使外部2个视图具有固定宽度,中间视图填充剩余的可用水平空间?我所有这样做的尝试都导致最右边的视图被从屏幕上推出。我花了一段时间努力让它正常工作,并找到了如何使用Android布局:两个固定宽度视图之间的可变宽度视图,android,android-layout,android-relativelayout,Android,Android Layout,Android Relativelayout,如何水平布置3个视图,使外部2个视图具有固定宽度,中间视图填充剩余的可用水平空间?我所有这样做的尝试都导致最右边的视图被从屏幕上推出。我花了一段时间努力让它正常工作,并找到了如何使用RelativeLayout实现它。请参阅下面的代码示例,并密切注意layout\u-toRightOf、layout\u-toLeftOf和layout\u-alignParentRight <RelativeLayout xmlns:android="http://schemas.android.com/a
RelativeLayout
实现它。请参阅下面的代码示例,并密切注意layout\u-toRightOf
、layout\u-toLeftOf
和layout\u-alignParentRight
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="@dimen/eventDetailSectionHeight"
android:background="@color/grayout">
<SomeFixedWidthView
android:id="@+id/leftFixedWidthView"
android:layout_width="100dp"
android:layout_height="match_parent"/>
<SomeVariableWidthView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_toRightOf="@id/leftFixedWidthView"
android:layout_toLeftOf="@+id/rightFixedWidthView"/>
<SomeFixedWidthView
android:id="@+id/rightFixedWidthView"
android:layout_width="100dp"
android:layout_height="match_parent"
android:layout_alignParentRight="true"/>
</RelativeLayout>
尝试根据要求为每个孩子设置布局重量
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:orientation="horizontal"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:weightSum="1">
<View
android:id="@+id/leftView"
android:layout_width="0dp"
android:layout_weight="0.4"
android:layout_height="match_parent"
android:background="#ff0000"/>
<View
android:id="@+id/middleView"
android:layout_width="0dp"
android:layout_weight="0.2"
android:layout_height="match_parent"
android:background="#33cc33"/>
<View
android:id="@+id/rightView"
android:layout_width="0dp"
android:layout_weight="0.4"
android:layout_height="match_parent"
android:background="#ff0000"/>/>
</LinearLayout>
/>
使用下面的代码获得您想要的结果
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:orientation="horizontal"
android:layout_width="match_parent"
android:layout_height="match_parent">
<View
android:id="@+id/leftView"
android:layout_width="100dp"
android:layout_height="match_parent"
android:background="#ff0000"/>
<View
android:id="@+id/middleView"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1"
android:background="#33cc33"/>
<View
android:id="@+id/rightView"
android:layout_width="100dp"
android:layout_height="match_parent"
android:background="#ff0000"/>
</LinearLayout>