在RelativeLayout中防止视图重叠

13

我正在尝试开发一个Android应用程序,但GUI设计方面遇到了一些问题。以下是截图的一部分,其中红色和蓝色线条是由Android调试选项生成的。

我的问题

这是代码:

<RelativeLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_alignLeft="@+id/caption"
    android:layout_below="@+id/caption" >

    <ImageButton
        android:id="@+id/button_edit"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerVertical="true"
        android:layout_alignParentRight="true"
        android:src="@drawable/content_edit"
        style="?android:attr/borderlessButtonStyle" />

    <TextView
        android:id="@+id/myText"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_centerVertical="true"
        android:text="@string/num_placeholder"
        android:textAppearance="?android:attr/textAppearanceLarge" />


</RelativeLayout>

如您所见,TextView“myText”与ImageButton“button_edit”重叠。一个简单的解决方案是使用LinearLayout代替RelativeLayout。但问题在于:

  1. 我需要右侧的编辑按钮
  2. 我需要文本填充布局的其余部分(显然是在编辑按钮的左侧)

我也尝试将“myText”的layout_width设置为“fill_parent”,但它会在编辑按钮左侧将整个屏幕全部填满。

期望的行为应该是“myText”增加其高度(成为两行TextView),而不是覆盖“button_edit”。

是否有人可以帮助我?谢谢。


为什么要使用RelativeLayout,而不是用LinearLayout就可以实现呢? - sriramramani
2个回答

19

在TextView布局中使用layout_toLeftOf,例如:

<RelativeLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignLeft="@+id/caption"
android:layout_below="@+id/caption" >

<ImageButton
    android:id="@+id/button_edit"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_centerVertical="true"
    android:layout_alignParentRight="true"
    android:src="@drawable/content_edit"
    style="?android:attr/borderlessButtonStyle" />

<TextView
    android:id="@+id/myText"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignParentLeft="true"
    android:layout_centerVertical="true"
    android:text="@string/num_placeholder"
    android:textAppearance="?android:attr/textAppearanceLarge"
    android:layout_toLeftOf="@+id/button_edit" />

:该标签用于HTML文档中定义段落。

如果我们想要通过动态创建视图来实现它,该怎么办? - Tushar Gogna

0
另一种方法是使用android:layout_toEndOf属性。

<ImageButton
    android:id="@+id/button_edit"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_centerVertical="true"
    android:layout_alignParentRight="true"
    android:src="@drawable/content_edit"
    style="?android:attr/borderlessButtonStyle"
    android:layout_toEndOf="@+id/myText" />

<TextView
    android:id="@+id/myText"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignParentLeft="true"
    android:layout_centerVertical="true"
    android:text="@string/num_placeholder"
    android:textAppearance="?android:attr/textAppearanceLarge" />


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接