Java 将ReyclView元素与android对齐

Java 将ReyclView元素与android对齐,java,android,Java,Android,我有一个带有TextView和EditText的recyclerview,它构建的行的TextView在左边,EditText在右边。 当前视图如下所示: Aaa: value1 Abbsbc: value2 Cskhkdhd: value3 HJhk: value4 <?xml version="1.0" encoding="utf-8"?> <RelativeLayout android:id="@+id/brand_row" xmlns:android="http

我有一个带有TextView和EditText的recyclerview,它构建的行的TextView在左边,EditText在右边。 当前视图如下所示:

Aaa:  value1
Abbsbc:  value2
Cskhkdhd: value3
HJhk:  value4
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
android:id="@+id/brand_row"
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@drawable/brand_selector">

<View
    android:id="@+id/divider"
    android:layout_width="match_parent"
    android:layout_height="1dp"
    android:background="@color/divider"/>

<TextView
    android:id="@+id/object"
    android:layout_width="wrap_content"
    android:layout_height="@dimen/edit_box_height"
    android:layout_below="@id/divider"
    android:gravity="center_vertical"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:singleLine="true"
    android:textAppearance="?android:attr/textAppearanceListItemSmall"
    android:textColor="@color/noData"/>

<EditText
    android:id="@+id/value"
    android:layout_width="wrap_content"
    android:layout_height="@dimen/edit_box_height"
    android:layout_below="@id/divider"
    android:layout_toRightOf="@id/object"
    android:background="@android:color/transparent"
    android:hint="Enter value"
    android:singleLine="true"
    android:textAppearance="?android:attr/textAppearanceListItemSmall"
    android:textColor="@android:color/black"
    android:textColorHint="@color/divider"/>
</RelativeLayout>
我希望视图是这样的:

            Aaa:  value1
     Abbsbc:  value2
 Cskhkdhd:  value3
         HJhk:  value4
布局如下:

Aaa:  value1
Abbsbc:  value2
Cskhkdhd: value3
HJhk:  value4
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
android:id="@+id/brand_row"
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@drawable/brand_selector">

<View
    android:id="@+id/divider"
    android:layout_width="match_parent"
    android:layout_height="1dp"
    android:background="@color/divider"/>

<TextView
    android:id="@+id/object"
    android:layout_width="wrap_content"
    android:layout_height="@dimen/edit_box_height"
    android:layout_below="@id/divider"
    android:gravity="center_vertical"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:singleLine="true"
    android:textAppearance="?android:attr/textAppearanceListItemSmall"
    android:textColor="@color/noData"/>

<EditText
    android:id="@+id/value"
    android:layout_width="wrap_content"
    android:layout_height="@dimen/edit_box_height"
    android:layout_below="@id/divider"
    android:layout_toRightOf="@id/object"
    android:background="@android:color/transparent"
    android:hint="Enter value"
    android:singleLine="true"
    android:textAppearance="?android:attr/textAppearanceListItemSmall"
    android:textColor="@android:color/black"
    android:textColorHint="@color/divider"/>
</RelativeLayout>

在文本视图中添加此行:

android:textAlignment="viewEnd" 
android:gravity="center_vertical|end"
此外,我认为如果文本视图文本的长度在行中变化,这仍然会导致对齐不均匀,因此如果使用线性布局作为父布局,效果会更好。我已相应地重做了xml:

<?xml version="1.0" encoding="utf-8"?>

    <LinearLayout
        android:id="@+id/brand_row"
        xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="@drawable/brand_selector">

        <TextView
            android:id="@+id/object"
            android:layout_width="0dp"
            android:layout_weight="1"
            android:layout_height="@dimen/edit_box_height"
            android:textAlignment="viewEnd"
            android:gravity="center_vertical|end"
            android:paddingLeft="@dimen/activity_horizontal_margin"
            android:paddingRight="@dimen/activity_horizontal_margin"
            android:singleLine="true"
            android:textAppearance="?android:attr/textAppearanceListItemSmall"
            android:textColor="@color/noData"/>

        <EditText
            android:id="@+id/value"
            android:layout_width="0dp"
            android:layout_weight="1"
            android:layout_height="@dimen/edit_box_height"
            android:layout_below="@id/divider"
            android:layout_toRightOf="@id/object"
            android:background="@android:color/transparent"
            android:hint="Enter value"
            android:singleLine="true"
            android:textAppearance="?android:attr/textAppearanceListItemSmall"
            android:textColor="@android:color/black"
            android:textColorHint="@color/divider"/>
    </LinearLayout>

尝试带重量的线性布局:



编辑:我在文本视图的右侧添加了一个重力端点以对齐,在编辑文本上添加了一个起始端点以在标签和值之间留出空间

您是否尝试过将对象文本视图添加到另一个布局(例如重力右键)?建议的答案均未达到预期结果。我只是编辑了我的答案以对齐右边,试试这个wayoups,有双重重力属性,现在应该可以了: