代码之家  ›  专栏  ›  技术社区  ›  Ravi Ranjan

如何在相对布局Android中对齐中心垂直的imageView

  •  0
  • Ravi Ranjan  · 技术社区  · 12 年前

    我正在尝试为列表设计一行。。。它包含1个复选框、2个文本视图、1个图像视图和1个评级栏。。。

    1. 添加评级栏后,根据相对布局,ImageView不在centerVertical中
    2. 我用过 android:layout_marginRight=“70dp” 把它固定在正确的位置,但我想用 android:layout_toRightOf=“@+id/list_image”

    下面是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 回复  |  直到 12 年前
        1
  •  1
  •   Hariharan    12 年前

    试试这个。。

    使用 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>
    
        2
  •  0
  •   Rushabh Patel    12 年前

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

    <?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>
    

    希望这对你有帮助。。