嵌套的linearlayout无法正常工作

时间:2014-01-31 17:50:38

标签: android

我想在一行中编辑文本和发送按钮,但在另一行中发送图像...但是使用此代码编辑文本,发送按钮和图像显示在一行..你能告诉我该怎么做才能显示另一行中的图像

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:tools="http://schemas.android.com/tools"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:paddingBottom="@dimen/activity_vertical_margin"
        android:paddingLeft="@dimen/activity_horizontal_margin"
        android:paddingRight="@dimen/activity_horizontal_margin"
        android:paddingTop="@dimen/activity_vertical_margin"
        android:orientation="horizontal"
        tools:context=".MainActivity" >
    <EditText
        android:id="@+id/edit_message "
        android:layout_weight="1" 
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:hint="@string/edit_message"/>

    <Button 
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/button_send"
        android:onClick="sendMessage" />

    <LinearLayout
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical" >

    <ImageView
            android:id="@+id/imageView1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:src="@drawable/logo" />

    </LinearLayout>


    </LinearLayout>

3 个答案:

答案 0 :(得分:2)

您可以将EditTextButton包裹在LinearLayout

<LinearLayout
    android:orientation="vertical"
    ...>
    <LinearLayout
        ...>
        <EditText
           .../>
       <Button
          .../>
   </LinearLayout>
   <ImageView
     .../>
</LinearLayout>

但我可能会使用RelativeLayout

<RelativeLayout
    ...>
   <EditText
       android:id="@+id/et"
       .../>
   <Button
     android:layout_toRightOf="@id/et"
     .../>
   <ImageView
      android:layout_below="@id/et"
      .../>
</RelativeLayout>

但这也取决于你想要的确切位置。

答案 1 :(得分:2)

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    android:orientation="vertical"
    tools:context=".MainActivity" >

<LinearLayout
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="horizontal" >

<EditText
    android:id="@+id/edit_message "
    android:layout_weight="1" 
    android:layout_width="0dp"
    android:layout_height="wrap_content"
    android:hint="@string/edit_message"/>

<Button 
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="@string/button_send"
    android:onClick="sendMessage" />

</LinearLayout>

<ImageView
        android:id="@+id/imageView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:src="@drawable/logo" />

</LinearLayout>

答案 2 :(得分:0)

要使ImageView在EditText和Button下方的行中显示,您需要将外部LinearLayout的方向设置为Vertical,然后将EditText和Button包装为具有水平方向的Linear布局。