0

私は最終的に TableLayout の使用に切り替えましたが、それが最も成功していることが証明されています。ただし、を使用しようとしても、正しく整列させることはできませんgravity

コード:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:orientation="horizontal" >

<TableLayout
android:id="@+id/background"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_gravity="center"
android:gravity="center"
android:orientation="horizontal"
android:minHeight="52dp" >

<!-- My pic row -->
<TableRow
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal" >

<ImageView
    android:id="@+id/myPicture"
    android:layout_width="48dp"
    android:layout_height="48dp"
    android:gravity="right"
    android:layout_gravity="right"
    android:layout_marginTop="0dp"
    android:maxHeight="48dp"
    android:maxWidth="48dp"
    android:minHeight="48dp"
    android:minWidth="48dp"
    android:scaleType="centerCrop" />

</TableRow>


<!-- Contact row -->
<TableRow
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal" >

<ImageView
    android:id="@+id/contactPicture"
    android:layout_width="48dp"
    android:layout_height="48dp"
    android:layout_marginTop="0dp"
    android:layout_gravity="left"
    android:gravity="left"
    android:scaleType="centerCrop"
    android:maxHeight="48dp"
    android:maxWidth="48dp"
    android:minHeight="48dp"
    android:minWidth="48dp" />

<View
    android:id="@+id/holder"
    android:layout_gravity="center"
    android:gravity="center"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content" />

</TableRow>

<TextView
    android:id="@+id/body"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:ellipsize="marquee"
    android:fadingEdge="horizontal"
    android:paddingLeft="5dp"
    android:paddingRight="5dp"
    android:textSize="14sp"
    android:textColor="@color/textColorReceived" />

    <TextView
        android:id="@+id/name"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center_vertical"
        android:layout_marginTop="-3dp"
        android:ellipsize="marquee"
        android:fadingEdge="horizontal"
        android:fontFamily="sans-serif-light"
        android:gravity="center_vertical"
        android:paddingBottom="3dp"
        android:paddingRight="5dp"
        android:textColor="@color/dateColorReceived"
        android:textSize="12sp" />

    <ImageView
        android:id="@+id/media"
        android:layout_width="200dp"
        android:layout_height="200dp"
        android:layout_gravity="center"
        android:gravity="center"
        android:padding="10dp"
        android:scaleType="centerInside"
        android:visibility="gone" />

    <View
          android:id="@+id/gifView"
          android:layout_width="200dp"
          android:layout_height="wrap_content"
          android:padding="10dp"
          android:visibility="gone" />

<TextView
    android:id="@+id/date"
    android:layout_gravity="bottom|center"
    android:gravity="bottom|center"
    android:textSize="12sp"
    android:visibility="visible"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:fontFamily="sans-serif-light"
    android:textColor="@color/dateColorReceived" />

  </TableLayout>
</RelativeLayout>

現状です

コードのスクリーンショット

これは私が達成したいことにとても近いです。@+id/contactPicture(赤い男)が@+id/body(テキスト)の左側にある必要があります。@+id/myPictureこれは、テキストの右側にある必要があることを除いて、私の写真にも@+id/body当てはまります。gravityとが機能しない理由がわかりませんlayout_gravity

このレイアウトは完成に近づいています。今日、私はこのレイアウトでほぼ 12 時間作業しましたが、今週の作業を合計すると、おそらくそれをはるかに超えています。すべての助けに本当に感謝しています。

これは私が行くものです

スクリーンショット2

4

1 に答える 1

1

使う

<LinearLayout> </LinearLayout>

表の行アイテム内で方向が水平に設定されています。textview と image を LL 内に配置します。

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >

    <TableLayout
        android:layout_width="match_parent"
        android:layout_height="fill_parent" >

        <TableRow
            android:id="@+id/tableRow1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_margin="10dp" 
             android:orientation="horizontal">

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

                <ImageView
                    android:id="@+id/imageView1"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_gravity="center_vertical"
                    android:layout_marginLeft="10dp"
                    android:src="@drawable/ic_launcher" />

                <TextView
                    android:id="@+id/textView1"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_gravity="center_vertical"
                    android:layout_marginLeft="10dp"
                    android:text="TextView" />

            </LinearLayout>

        </TableRow>

        <TableRow
            android:id="@+id/tableRow2"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" >
        </TableRow>

        <TableRow
            android:id="@+id/tableRow3"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" >
        </TableRow>

        <TableRow
            android:id="@+id/tableRow4"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" >
        </TableRow>
    </TableLayout>

</LinearLayout>

そのように。

になります: http://puu.sh/6GNRT.jpg

于 2014-02-02T01:52:41.383 に答える