1

すべての要素が各リストビュー項目に対して同じ寸法で、レイアウト全体が画面の幅全体を占める複雑なリストビュー項目レイアウトを構築しようとしています。これまでのところ、linearlayout を使用してこれを実行しようとしましたが、これが間違ったアプローチであることがわかりました。次に、相対レイアウトを使用しようとしましたが、これはうまくいきませんでした。誰かがこれを機能させる方法を指摘してくれることを願っています。

これが私が構築しようとしているものの図です。 ListView アイテムのレイアウト

ダイアグラムの詳細は次のとおりです。

  • 要素 5 と 6 だけが、すべてのリスト項目で同じ内容を持っています。残りの要素はすべて異なるテキストになりますが、レイアウトは常に同じサイズにする必要があります。

  • 要素 4 は 2 行のみにする必要があります。要素 1、2、および 3 は 1
    行のみにする必要があります。

  • 要素 2 は左に配置し、要素 3 は
    右に配置する必要があります。

  • 要素 2 と 3 は、それぞれ要素 4 の幅の半分にする必要があります。

これが、RelativeLayout を使用したこのレイアウトの試みです。

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="?android:attr/listPreferredItemHeight"
android:padding="2dp">
<TextView
    android:id="@+id/txtRaceNumber"
    android:layout_width="20dp"
    android:layout_height="fill_parent"
    android:textAppearance="?android:attr/textAppearanceLarge"
    android:gravity="center"
    android:layout_gravity="center" 
    android:layout_alignParentTop="true"
    android:layout_alignParentBottom="true" />
    <TextView
        android:id="@+id/txtRaceName"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textAppearance="?android:attr/textAppearanceMedium"
        android:layout_toRightOf="@id/txtRaceNumber"
        android:layout_alignParentTop="true" />
    <TextView
        android:id="@+id/txtRaceClass"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:textAppearance="?android:attr/textAppearanceSmall"
        android:maxLines="1"
        android:ellipsize="marquee"
        android:layout_alignParentBottom="true"
        android:layout_alignParentLeft="true"
        android:layout_toRightOf="@id/txtRaceNumber" />
    <TextView
        android:id="@+id/txtRaceStartTime"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:textAppearance="?android:attr/textAppearanceSmall"
        android:maxLines="1"
        android:layout_alignParentBottom="true"
        android:layout_toRightOf="@id/txtRaceClass" />
     <ImageButton
        android:id="@+id/btnTracklist"
        android:layout_width="wrap_content"
        android:layout_height="fill_parent"
        android:background="@null"
        android:paddingRight="8dip"
        android:focusable="false"
        android:layout_gravity="center_vertical|center_horizontal"
        android:layout_alignParentTop="true"
        android:layout_alignParentBottom="true"
        android:layout_toRightOf="@id/txtRaceStartTime" />
    <ImageView
        android:src="@drawable/go"
        android:layout_width="wrap_content"
        android:layout_height="fill_parent"
        android:layout_gravity="center_vertical"
        android:layout_alignParentTop="true"
        android:layout_alignParentBottom="true"
        android:layout_alignParentRight="true"
        android:layout_toRightOf="@id/btnTracklist" />
</RelativeLayout>

この RelativeLayout を使用すると、すべての要素がレイアウト内でスクランブルされて表示されます。

図に示したように、これらすべての要素を整列させるにはどうすればよいですか?

4

4 に答える 4

0

これはあなたが必要なものですか?

<LinearLayout
    android:id="@+id/lin1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
   android:layout_alignParentLeft="true"
    android:layout_centerVertical="true"
    android:orientation="vertical" >

    <TextView
        android:id="@+id/txtRaceNumber"
        android:layout_width="wrap_content"
        android:layout_height="fill_parent"

        android:gravity="center"
        android:text="TExt1"
        android:textAppearance="?android:attr/textAppearanceMedium" />
</LinearLayout>

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

    android:orientation="vertical" 
    android:layout_toRightOf="@+id/lin1"
    android:layout_toLeftOf="@+id/lin3">

    <TextView
        android:id="@+id/txtRaceName"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Text4"
        android:textAppearance="?android:attr/textAppearanceMedium" />

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

        <TextView
            android:id="@+id/txtRaceClass"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:maxLines="1"
            android:text="text2"
            android:textAppearance="?android:attr/textAppearanceSmall" />

        <TextView
            android:id="@+id/txtRaceStartTime"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:maxLines="1"
            android:text="text3"
            android:textAppearance="?android:attr/textAppearanceSmall" />
    </LinearLayout>
</LinearLayout>

<LinearLayout
    android:id="@+id/lin3"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"

    android:layout_alignParentRight="true"
    android:orientation="horizontal" >

    <ImageButton
        android:id="@+id/btnTracklist"
        android:layout_width="wrap_content"
        android:layout_height="fill_parent"
        android:background="@null"
        android:focusable="false"
        android:paddingRight="8dip" />

    <ImageView
        android:layout_width="wrap_content"
        android:layout_height="fill_parent"
        android:layout_gravity="center_vertical"
        android:src="@drawable/ic_launcher" />
</LinearLayout>

于 2012-10-25T08:39:32.633 に答える
0

メイン レイアウトで weightSum を使用して目的のレイアウトを取得することができました。

コードは次のとおりです。

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/twolinechecked"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:minHeight="?android:attr/listPreferredItemHeight"
android:maxHeight="?android:attr/listPreferredItemHeight"
android:paddingTop="2dip"
android:paddingBottom="2dip"
android:orientation="horizontal"
android:weightSum="1"
android:descendantFocusability="blocksDescendants">
<TextView
    android:id="@+id/txtRaceNumber"
    android:layout_width="40dip"
    android:layout_height="wrap_content"
    android:textAppearance="?android:attr/textAppearanceLarge"
    android:gravity="center"
    android:layout_gravity="center"
    android:paddingRight="5dip"
    android:paddingLeft="5dip"
    android:textStyle="bold" />
<LinearLayout
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    android:layout_weight="1"
    android:layout_gravity="center_vertical|center_horizontal"
    android:layout_marginLeft="6dip">
    <TextView
        android:id="@+id/txtRaceName"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textAppearance="?android:attr/textAppearanceMedium" />
    <LinearLayout
        android:id="@+id/linearTextInner"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        android:layout_gravity="center_vertical|center_horizontal">
        <TextView
            android:id="@+id/txtRaceClass"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:textAppearance="?android:attr/textAppearanceSmall"
            android:maxLines="1"
            android:ellipsize="marquee"
            android:layout_alignParentLeft="true" />
        <TextView
            android:id="@+id/txtRaceStartTime"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:textAppearance="?android:attr/textAppearanceSmall"
            android:layout_weight="1"
            android:maxLines="1"
            android:layout_alignParentRight="true"
            android:gravity="right" />
    </LinearLayout>
</LinearLayout>
<ImageButton
    android:id="@+id/btnTracklist"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:background="@null"
    android:layout_marginLeft="5dip"
    android:paddingRight="8dip"
    android:layout_gravity="center_vertical|center_horizontal" />
<ImageView
    android:src="@drawable/go"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_gravity="center_vertical"
    android:layout_alignParentRight="true" />
</LinearLayout>
于 2012-10-25T20:50:11.747 に答える
0

以下の構造に従ってください。重量と重量合計を使用して、必要なものを達成できると思います。

<LinearLayout orientation="horizontal">
    <LinearLayout>
    <TextView/>
    </LinearLayout>
    <LinearLayout orientation="vertical">
    <TextView/>
    <LinearLayout orientation="horizontal">
    <TextView/>
    <TextView/>
    </LinearLayout>
    <ImageButton/>
    <ImageView/>
</LinearLayout>

編集

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="?android:attr/listPreferredItemHeight"
    android:baselineAligned="false"
    android:orientation="horizontal"
    android:padding="2dp"
    android:weightSum="1" >

    <LinearLayout
        android:layout_width="0dip"
        android:layout_height="fill_parent"
        android:layout_weight="0.2" >

        <TextView
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:gravity="center" />
    </LinearLayout>

    <LinearLayout
        android:layout_width="0dip"
        android:layout_height="fill_parent"
        android:layout_weight="0.5"
        android:orientation="vertical"
        android:weightSum="1" >

        <TextView
            android:layout_width="fill_parent"
            android:layout_height="0dip"
            android:layout_weight="0.7"
            android:gravity="center" />

        <LinearLayout
            android:layout_width="fill_parent"
            android:layout_height="0dip"
            android:layout_weight="0.3"
            android:orientation="horizontal"
            android:weightSum="1" >

            <TextView
                android:layout_width="0dip"
                android:layout_height="fill_parent"
                android:layout_weight="0.5"
                android:gravity="center" />

            <TextView
                android:layout_width="0dip"
                android:layout_height="fill_parent"
                android:layout_weight="0.5"
                android:gravity="center" />
        </LinearLayout>
    </LinearLayout>

    <ImageButton
        android:layout_width="0dip"
        android:layout_height="fill_parent"
        android:layout_weight="0.15" />

    <ImageButton
        android:layout_width="0dip"
        android:layout_height="fill_parent"
        android:layout_weight="0.15" />

</LinearLayout>
于 2012-10-25T08:21:09.877 に答える
0

このコードを試してください

<?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="90dp"
    android:gravity="center|left"
    android:orientation="horizontal" >

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="fill_parent"
        android:layout_gravity="left|center"
        android:layout_gravity="center"
        android:gravity="center"
        android:text="TextView"
        android:textColor="#FFFFFF"
        android:textSize="15sp" />

    <LinearLayout
        xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:gravity="center"
        android:orientation="vertical" >

        <LinearLayout
            xmlns:android="http://schemas.android.com/apk/res/android"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:gravity="left|center"
            android:orientation="horizontal" >

            <TextView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_gravity="left|center"
                android:text="TextView"
                android:textColor="#FFFFFF"
                android:textSize="15sp" />
        </LinearLayout>

        <LinearLayout
            xmlns:android="http://schemas.android.com/apk/res/android"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:gravity="left|center"
            android:orientation="horizontal" >

            <TextView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_gravity="left|center"
                android:layout_weight="1"
                android:text="TextView"
                android:textColor="#FFFFFF"
                android:textSize="15sp" />

            <TextView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_gravity="left|center"
                android:layout_weight="1"
                android:text="TextView"
                android:textColor="#FFFFFF"
                android:textSize="15sp" />
        </LinearLayout>

        <LinearLayout
            xmlns:android="http://schemas.android.com/apk/res/android"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:gravity="left|center" >
        </LinearLayout>
    </LinearLayout>

    <LinearLayout
        android:layout_width="wrap_content"
        android:layout_height="fill_parent"
        android:layout_gravity="center"
        android:layout_marginRight="3dp"
        android:gravity="center"
        android:orientation="vertical" >

        <ImageView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="right|center"
            android:src="@drawable/ic_launcher"
           />
    </LinearLayout>

    <LinearLayout
        android:layout_width="wrap_content"
        android:layout_height="fill_parent"
        android:layout_gravity="center"
        android:layout_marginRight="3dp"
        android:gravity="center"
        android:orientation="vertical" >

        <ImageView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="right|center"
            android:src="@drawable/ic_launcher"
            />
    </LinearLayout>

</LinearLayout>
于 2012-10-25T08:47:28.593 に答える