如何在LinearLayout上垂直设置中心的小部件

时间:2016-03-22 05:30:48

标签: android android-layout

我想在Widgets center_vertical上设置horizontal LinearLayout,并将父{0}}设置为父版面右侧的最后Textview

我尝试了但是我很难过。我在下面提供了我的代码。

  

xml layout:

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

    <ImageView
        android:id="@+id/icon"
        android:layout_width="25dp"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_marginLeft="12dp"
        android:layout_marginRight="12dp"
        android:contentDescription="@string/desc_list_item_icon"
        android:src="@drawable/image1"
        android:layout_centerVertical="true" />

    <TextView
        android:id="@+id/title"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_toRightOf="@id/icon"
        android:minHeight="?android:attr/listPreferredItemHeightSmall"
        android:textAppearance="?android:attr/textAppearanceListItemSmall"
        android:textColor="@color/colorPrimary"
        android:layout_centerVertical="true"
        android:text="Hello world"
        android:paddingRight="40dp"/>

    <TextView android:id="@+id/counter"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="@drawable/counter_bg"
        android:layout_alignParentRight="true"
        android:layout_centerVertical="true"
        android:layout_marginRight="8dp"
        android:textColor="@color/counter_text_color"/>

</LinearLayout>

以下是我正在尝试制作的内容:

enter image description here

2 个答案:

答案 0 :(得分:0)

android:layout_centerVertical在LinearLayout中没有做任何事情(仅在RelativeLayouts中使用)

您希望对每个孩子使用android:layout_gravity="center_vertical",或者在LinearLayout上使用android:gravity="center_vertical"

编辑:让您的最后一个视图停留在布局右侧的一种方法是让您的标题视图具有属性android:weight="1",以使其宽度扩展为填写布局

答案 1 :(得分:0)

执行您要完成的工作的最简单方法是使用RelativeLayout gravity="center_vertical"。要继续并给你代码片段,因为你提到你是Android的新手。也许下次你将成为提供答案的人。 ;)

  

sample.xml中

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="48dp"
    android:gravity="center_vertical"
    android:padding="5dp">

    <ImageView
        android:id="@+id/icon"
        android:layout_width="25dp"
        android:layout_height="25dp"
        android:layout_marginLeft="12dp"
        android:layout_marginRight="12dp"
        android:contentDescription="Sample Description"
        android:src="@drawable/sample_img" />

    <TextView
        android:id="@+id/title"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_toRightOf="@id/icon"
        android:text="Hello world"
        android:textAppearance="?android:attr/textAppearanceListItemSmall"
        android:textColor="@color/colorPrimary" />

    <TextView
        android:id="@+id/counter"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentRight="true"
        android:layout_marginRight="8dp"
        android:background="@android:color/holo_blue_bright"
        android:text="8"
        android:textColor="@android:color/holo_green_dark" />

</RelativeLayout>

有关RelativeLayout的更多信息,请查看here

希望这会有所帮助。祝好运。