我在线性布局中有2个图像视图,如下所示:
<LinearLayout
style="@style/home_icon_row"
android:orientation="horizontal">
<ImageView
android:id="@+id/ibtn_home_bus"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/ico_bus_selector" />
<ImageView
android:id="@+id/ibtn_home_butoday"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/ico_butoday_selector" />
</LinearLayout>
如何对齐两个图像,使它们均匀放置在线性布局中。类似于&#34;合理的文字&#34;因此它在图像的左右两侧具有相等的间距和屏幕的边界。
答案 0 :(得分:2)
这不是最好的解决方案,但应该有效:
<LinearLayout
style="@style/home_icon_row"
android:orientation="horizontal">
<View
android:layout_width="0dp"
android:layout_weight="1"
android:layout_height="0dp"
android:enable="false"
android:focussable="false"
android:clickable="false"
/>
<ImageView
android:id="@+id/ibtn_home_bus"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/ico_bus_selector" />
<View
android:layout_width="0dp"
android:layout_weight="1"
android:layout_height="0dp"
android:enable="false"
android:focussable="false"
android:clickable="false" />
<ImageView
android:id="@+id/ibtn_home_butoday"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/ico_butoday_selector" />
<View
android:layout_width="0dp"
android:layout_weight="1"
android:layout_height="0dp"
android:enable="false"
android:focussable="false"
android:clickable="false" />
</LinearLayout>
如果这是用于某种着陆,那就没关系,但如果它是一个难以使用的布局,请考虑通过javacode实现它以使其更快。
编辑:我添加了3个属性(启用,可聚焦,可点击)以禁用placehodler视图,以便仅在度量/布局时考虑它们,但在事件处理期间不会考虑它们。
答案 1 :(得分:1)
// try this way here is alternative to use two sub linear layout rather three View.
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
style="@style/home_icon_row"
android:layout_width="match_parent"
android:layout_height="wrap_content">
<LinearLayout
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:gravity="center">
<ImageView
android:id="@+id/ibtn_home_bus"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/ico_bus_selector" />
</LinearLayout>
<LinearLayout
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:gravity="center">
<ImageView
android:id="@+id/ibtn_home_butoday"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/ico_butoday_selector" />
</LinearLayout>
</LinearLayout>
答案 2 :(得分:0)
对于两个ImageView,您应该可以使用layout_width="0dp"
,layout_weight="1"
和scaleType="centerInside"
来获得类似的效果。
唯一的区别是图像之间的空间可能更大。
答案 3 :(得分:0)
<LinearLayout
style="@style/home_icon_row"
android:orientation="horizontal"
android:padding="@dimen/padding">
<ImageView
android:id="@+id/ibtn_home_bus"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/ico_bus_selector"
android:layout_marginRight="@dimen/padding"/>
<ImageView
android:id="@+id/ibtn_home_butoday"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/ico_butoday_selector" />
</LinearLayout>