将我的线性布局置于android中

时间:2014-03-31 01:18:55

标签: java android android-layout

我试图实现这一定位:

enter image description here

我有两行EditText和TextView彼此相邻。

版本textview固定在屏幕底部,但占据整个宽度,文本居中。

我当前的布局文件是:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:layout_centerInParent="true"
    android:orientation="vertical"
    android:gravity="center_vertical"
    tools:context="com.example.mp.MainActivity$PlaceholderFragment" >

     <LinearLayout 
            android:layout_width="fill_parent" 
            android:layout_height="wrap_content">
                <EditText
                    android:id="@+id/edittext1"
                    android:layout_width="250dip"
                    android:layout_height="wrap_content" />

                <TextView
                    android:id="@+id/textview1"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:text="NEW"
                    android:textColor="#444444"
                    android:paddingLeft="5dip"
                    android:textSize="10pt" />

    </LinearLayout>

     <LinearLayout 
            android:layout_width="fill_parent" 
            android:layout_height="wrap_content">

                <EditText
                    android:id="@+id/edittext2"
                    android:layout_width="250dip"
                    android:layout_height="wrap_content" />

                <TextView
                    android:id="@+id/textview2"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:text="NEW"
                    android:textColor="#444444"
                    android:paddingLeft="5dip"
                    android:textSize="10pt" />

    </LinearLayout>


    <RelativeLayout 
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:paddingTop="5dip"
        android:gravity="bottom">


                <TextView
                    android:id="@+id/textview3"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:text="Version 1.0"
                    android:textColor="#444444"
                    android:paddingLeft="5dip"
                    android:textSize="10pt" />

    </RelativeLayout>

</LinearLayout>

但是,两行EditText和TextView位于屏幕中间,而Version textview位于EditText和TextView两行的下方,而不是锚定在底部。

2 个答案:

答案 0 :(得分:2)

我建议使用RelativeLayout作为根布局,并使用属性android:layout_alignParentBottom="true"作为“版本”。然后将另一个Views包裹在LinearLayout中。像

这样的东西
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"/>
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_centerVertical="true"
        android:orientation="vertical"/>
        <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
            <EditText
                android:id="@+id/edittext1"
                android:layout_width="0dp"
                android:layout_weight="3"
                android:layout_height="wrap_content" />

            <TextView
                android:id="@+id/textview1"
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_weight="2"
                android:text="NEW"
                android:textColor="#444444"
                android:paddingLeft="5dip"
                android:textSize="10pt" />
        </LinearLayout>
        <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"/>
            <EditText
                android:id="@+id/edittext2"
                android:layout_width="0dp"
                android:layout_weight="3"
                android:layout_height="wrap_content" />

            <TextView
                android:id="@+id/textview2"
                android:layout_width="0dp"
                android:layout_weight="2"
                android:layout_height="wrap_content"
                android:text="NEW"
                android:textColor="#444444"
                android:paddingLeft="5dip"
                android:textSize="10pt" />
          </LinearLayout>
        </LinearLayout>
         <TextView
                android:id="@+id/textview3"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="Version 1.0"
                android:textColor="#444444"
                android:paddingLeft="5dip"
                android:textSize="10pt"
                android:layout_alignParentBottom="true"
                android:layout_centerHorizontal="true" />
</RelativeLayout>

我没有机会真正测试它,但这应该让你非常接近。我将Views中的两组LinearLayout包裹在LinearLayout中,然后为每个weight分配,以便他们可以使用LinearLayout(您可以根据自己的需要进行调整) )。父Views居中垂直,以便那4 {{1}}将以我认为您想要的方式居中。

答案 1 :(得分:0)

<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:orientation="vertical"
 android:gravity="center">//hope this will work for you

<LinearLayout
    android:id="@+id/alltextfield"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"`enter code here`
    android:orientation="horizontal" >

    <EditText
        android:id="@+id/editText1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:hint="EditText" />

    <TextView
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="New" />
</LinearLayout>

<LinearLayout
    android:id="@+id/alltextfield"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="horizontal" >

    <EditText
        android:id="@+id/editText1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:hint="EditText" />

    <TextView
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="New" />
</LinearLayout>