如何在相对布局Android中的centerVertical中对齐imageView

时间:2014-04-07 11:05:00

标签: android xml relativelayout

我正在尝试为列表设计一行...它包含1个复选框,2个textView,1个ImageView和1个评级栏...

  1. 添加评级栏后,根据相对布局
  2. ,ImageView不在centerVertical中
  3. 我使用 android:layout_marginRight =" 70dp" 将其修复到正确位置,但我想使用 android:layout_toRightOf ="修复它@ + ID / list_image"
  4. 这是xml

    <?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"
        android:background="@drawable/list_selector"
        android:orientation="horizontal"
        android:padding="5dip" >
    
        <!--  ListRow Left sied Thumbnail image -->
        <LinearLayout android:id="@+id/thumbnail"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:padding="3dip"
            android:layout_alignParentRight="true"
            android:background="@drawable/image_bg"
            android:layout_marginRight="5dip">
    
            <ImageView
                android:id="@+id/list_image"
                android:layout_width="50dip"
                android:layout_height="50dip"
                android:src="@drawable/bday"/>
    
        </LinearLayout>
    
        <CheckBox
            android:id="@+id/checkBox1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignTop="@+id/thumbnail"
            android:textColor="#040404"
            android:typeface="sans"
            android:textSize="15dip"
            android:textStyle="bold"
            android:text="Ravi Ranjan" />
    
            <!-- GENDER -->
        <TextView
            android:id="@+id/gender"
            android:layout_marginLeft="35dp"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginTop="1dp"
            android:layout_below="@id/checkBox1"
            android:textColor="#343434"
            android:textSize="12dip"
             android:text="Male" />
        <TextView
            android:id="@+id/gender"
            android:layout_marginLeft="35dp"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginTop="1dp"
            android:layout_below="@id/checkBox1"
            android:layout_alignParentRight="true"
            android:layout_marginRight="70dp"
            android:textColor="#343434"
            android:rating   = "4"
            android:textSize="12dip"
             android:text="1 Aug" />
    
        <RatingBar
            android:id="@+id/ratingBar1"
            style = "?android:attr/ratingBarStyleSmall"
            android:layout_marginLeft="35dp"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" 
            android:layout_below="@id/gender"
            android:layout_marginTop="1dp"
            />
    
    </RelativeLayout>
    

2 个答案:

答案 0 :(得分:1)

试试这个..

android:layout_centerVertical="true"用于缩略图 LinearLayout

   <LinearLayout
        android:id="@+id/thumbnail"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentRight="true"
        android:layout_centerVertical="true"
        android:layout_marginRight="5dip"
        android:gravity="center"
        android:background="@drawable/image_bg"
        android:padding="3dip" >

        <ImageView
            android:id="@+id/list_image"
            android:layout_width="50dip"
            android:layout_height="50dip"
            android:src="@drawable/bday" />
    </LinearLayout>

答案 1 :(得分:0)

您可以尝试以下实体布局,根据您的需要支持几乎所有屏幕。

<?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"
    android:background="@drawable/list_selector"
    android:orientation="horizontal"
    android:padding="5dip" >

    <!-- ListRow Left sied Thumbnail image -->

    <LinearLayout
        android:id="@+id/thumbnail"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentRight="true"
        android:layout_centerVertical="true"
        android:layout_marginRight="5dip"
        android:background="@drawable/image_bg"
        android:padding="3dip" >

        <ImageView
            android:id="@+id/list_image"
            android:layout_width="50dip"
            android:layout_height="50dip"
            android:src="@drawable/bday" />
    </LinearLayout>

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_toLeftOf="@+id/thumbnail"
        android:gravity="center"
        android:orientation="vertical" >

        <CheckBox
            android:id="@+id/checkBox1"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:text="Ravi Ranjan"
            android:textColor="#040404"
            android:textSize="15dip"
            android:textStyle="bold"
            android:typeface="sans" />

        <!-- GENDER -->

        <TableRow
            android:layout_width="match_parent"
            android:layout_height="wrap_content" >

            <TextView
                android:id="@+id/gender"
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_weight="1"
                android:text="Male"
                android:textColor="#343434"
                android:textSize="12dip" />

            <TextView
                android:id="@+id/gender"
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_marginTop="1dp"
                android:layout_weight="1"
                android:rating="4"
                android:text="1 Aug"
                android:textColor="#343434"
                android:textSize="12dip" />
        </TableRow>

        <RatingBar
            android:id="@+id/ratingBar1"
            style="?android:attr/ratingBarStyleSmall"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginLeft="10dp"
            android:layout_marginTop="1dp" />
    </LinearLayout>

</RelativeLayout>

希望它会帮助你..