web-dev-qa-db-ja.com

レイアウトの左右にテキストビューを配置するにはどうすればよいですか?

レイアウトの右側と左側にテキストビューを配置したいのですが、それらは互いに積み重なっています。

<LinearLayout
        Android:layout_width="0dip"
        Android:layout_weight="1"
        Android:layout_height="fill_parent" Android:orientation="horizontal">
        <TextView
            Android:id="@+id/lefttext"
            Android:layout_width="fill_parent"
            Android:layout_height="0dip"
            Android:layout_weight="1"
            Android:text="Symbol"/>
       <TextView
            Android:id="@+id/righttext"
            Android:layout_width="fill_parent"
            Android:layout_height="0dip"
            Android:layout_weight="1"
            Android:text="Price"/>
    </LinearLayout>
11
Sheehan Alam

これを試して:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
    Android:layout_width="fill_parent"
    Android:layout_height="fill_parent"
    Android:orientation="horizontal"
    >
    <TextView
        Android:id="@+id/left_text"
        Android:layout_width="fill_parent"
        Android:layout_height="wrap_content"
        Android:layout_weight="1"
        Android:gravity="center"
        Android:text="Symbol"
        />
    <TextView
        Android:id="@+id/right_text"
        Android:layout_width="fill_parent"
        Android:layout_height="wrap_content"
        Android:layout_weight="1"
        Android:gravity="center"
        Android:text="Price"
        />
</LinearLayout>

これらの高さに0dipを指定するのはなぜですか?

側面の記号の場合:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
    Android:layout_width="fill_parent"
    Android:layout_height="fill_parent"
    Android:orientation="horizontal"
    >
    <TextView
        Android:id="@+id/left_text"
        Android:layout_width="fill_parent"
        Android:layout_height="wrap_content"
        Android:layout_weight="1"
        Android:padding="5dip"
        Android:gravity="left"
        Android:text="Symbol"
        />
    <TextView
        Android:id="@+id/right_text"
        Android:layout_width="fill_parent"
        Android:layout_height="wrap_content"
        Android:layout_weight="1"
        Android:padding="5dip"
        Android:gravity="right"
        Android:text="Price"
        />
</LinearLayout>

そしてRelativeLayoutで行われます:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
    Android:layout_width="fill_parent"
    Android:layout_height="fill_parent"
    >   
    <TextView
        Android:id="@+id/left_text"
        Android:layout_width="wrap_content"
        Android:layout_height="wrap_content"
        Android:padding="5dip"
        Android:layout_alignParentLeft="true"
        Android:text="Code"
        />
    <TextView
        Android:id="@+id/right_text"
        Android:layout_width="fill_parent"
        Android:layout_height="wrap_content"
        Android:padding="5dip"
        Android:layout_toRightOf="@+id/left_text"
        Android:gravity="right"     
        Android:text="Company Name"
        />  
</RelativeLayout>
20
Kevin Coppock

使用する Android:layout_alignParentLeft="true"およびAndroid:layout_alignParentRight="true"RelaytiveLayout内のビューでこのように

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
    Android:layout_width="fill_parent"
    Android:layout_height="wrap_content"
    >
    <TextView
        Android:id="@+id/left_text"
        Android:layout_width="wrap_content"
        Android:layout_height="wrap_content"
        Android:layout_alignParentLeft="true"
        Android:gravity="left|center_vertical"
        Android:text="Symbol"
        />
    <TextView
        Android:id="@+id/right_text"
        Android:layout_width="wrap_content"
        Android:layout_height="wrap_content"
        Android:layout_alignParentRight="true"
        Android:gravity="right|center_vertical"
        Android:text="Price"
        />
</RelativeLayout>

または、TableLayoutstretchColumnに設定して使用し、2番目の列を親のサイズに拡大することもできます。

4
RobGThai

LinearLayoutを使用して、それらの間に重みを付けて空のTextViewを配置するだけです。

<LinearLayout
    Android:layout_width="match_parent"
    Android:layout_height="wrap_content"
    Android:orientation="horizontal">
    <TextView
        Android:id="@+id/lefttext"
        Android:layout_width="match_parent"
        Android:layout_height="match_parent"
        Android:text="Symbol"/>
   <TextView
        Android:layout_width="0dp"
        Android:layout_height="wrap_content"
        Android:layout_weight="1"
        />
   <TextView
        Android:id="@+id/righttext"
        Android:layout_width="match_parent"
        Android:layout_height="match_parent"
        Android:text="Price"/>
</LinearLayout>
3
AppiDevo