web-dev-qa-db-ja.com

Android TextviewおよびImageviewで水平に整列する制約レイアウトセンターが機能しない

I want like this

上記の画像のようなtextviewとimageviewが必要です。

1.制約レイアウトを使用して、TextviewとImageviewを水平に単一行に設定したい.

2.TextviewがImageviewの中央(中央)に来ていない(左右の位置)

3.また、Cosntraintレイアウトのために、レイアウトの重力がtextview centerを作成するために機能していません

4.これを達成するために私を助けてください。

前もって感謝します。

  <Android.support.v7.widget.CardView
            Android:id="@+id/cv2"
            Android:layout_width="match_parent"
            Android:layout_height="wrap_content"
            Android:layout_gravity="center"
            app:cardCornerRadius="4dp"
            app:layout_constraintTop_toBottomOf="@+id/cv1">

            <Android.support.constraint.ConstraintLayout
                xmlns:app="http://schemas.Android.com/apk/res-auto"
                Android:layout_width="match_parent"
                Android:layout_height="wrap_content">

                <TextView
                    Android:id="@+id/title1"
                    Android:layout_width="0dp"
                    Android:layout_height="wrap_content"
                    Android:paddingLeft="10dp"
                    Android:text="Hero"
                    Android:textColor="@color/colorPrimary"
                    Android:textSize="16dp"
                    Android:textStyle="bold"
                    app:layout_constraintLeft_toLeftOf="parent"
                    app:layout_constraintRight_toLeftOf="@+id/display_pic"
                    />


                <ImageView
                    Android:id="@+id/display_pic"
                    Android:layout_width="80dp"
                    Android:layout_height="80dp"
                    Android:layout_alignParentEnd="true"
                    Android:layout_margin="16dp"
                    Android:adjustViewBounds="false"
                    Android:scaleType="centerCrop"
                    app:layout_constraintLeft_toLeftOf="@+id/title1"
                    app:layout_constraintRight_toRightOf="parent"
                    app:layout_constraintTop_toTopOf="parent"
                    app:srcCompat="@Android:color/holo_red_light" />


            </Android.support.constraint.ConstraintLayout>

</Android.support.v7.widget.CardView>
6
Kumar

親の右側にImageViewが必要な場合は、この属性を削除します。

app:layout_constraintLeft_toLeftOf="@+id/title1"

また、TextViewを垂直方向に整列させる場合は、次の属性を追加します。

app:layout_constraintTop_toTopOf="@id/display_pic"
app:layout_constraintBottom_toBottomOf="@id/display_pic"

変更されたxml:

<?xml version="1.0" encoding="utf-8"?>
<Android.support.v7.widget.CardView
    Android:id="@+id/cv2"
    xmlns:Android="http://schemas.Android.com/apk/res/Android"
    xmlns:app="http://schemas.Android.com/apk/res-auto"
    Android:layout_width="match_parent"
    Android:layout_height="wrap_content"
    Android:layout_gravity="center"
    app:cardCornerRadius="4dp"
    app:layout_constraintTop_toBottomOf="@+id/cv1">

    <Android.support.constraint.ConstraintLayout
        xmlns:app="http://schemas.Android.com/apk/res-auto"
        Android:layout_width="match_parent"
        Android:layout_height="wrap_content">

        <TextView
            Android:id="@+id/title1"
            Android:layout_width="0dp"
            Android:layout_height="wrap_content"
            Android:paddingLeft="10dp"
            Android:text="Hero"
            Android:textColor="@color/colorPrimary"
            Android:textSize="16dp"
            Android:textStyle="bold"
            app:layout_constraintTop_toTopOf="@id/display_pic"
            app:layout_constraintBottom_toBottomOf="@id/display_pic"
            app:layout_constraintLeft_toLeftOf="parent"
            app:layout_constraintRight_toLeftOf="@+id/display_pic"/>


        <ImageView
            Android:id="@+id/display_pic"
            Android:layout_width="80dp"
            Android:layout_height="80dp"
            Android:layout_alignParentEnd="true"
            Android:adjustViewBounds="false"
            Android:scaleType="centerCrop"
            app:layout_constraintRight_toRightOf="parent"
            app:layout_constraintTop_toTopOf="parent"
            app:srcCompat="@Android:color/holo_red_light"/>

    </Android.support.constraint.ConstraintLayout>
</Android.support.v7.widget.CardView>

結果:

Result

13
Juan Cruz Soler
<?xml version="1.0" encoding="utf-8"?>
<Android.support.constraint.ConstraintLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
    xmlns:app="http://schemas.Android.com/apk/res-auto"
    Android:layout_width="match_parent"
    Android:layout_height="match_parent">

    <ImageView
        Android:id="@+id/imageView2"
        Android:layout_width="80dp"
        Android:layout_height="80dp"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:srcCompat="@mipmap/ic_launcher" />

    <TextView
        Android:id="@+id/textView4"
        Android:layout_width="wrap_content"
        Android:layout_height="wrap_content"
        Android:text="Hero"
        Android:textColor="@color/colorPrimary"
        Android:textSize="16dp"
        Android:textStyle="bold"
        app:layout_constraintBottom_toBottomOf="@+id/imageView2"
        app:layout_constraintEnd_toEndOf="@+id/imageView2"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintStart_toStartOf="@+id/imageView2"
        app:layout_constraintTop_toTopOf="@+id/imageView2" />


</Android.support.constraint.ConstraintLayout>

上記のコードを使用すると、テキストビューを画像ビューの中央に保持できます。画像ビューを配置するには、垂直バイアスと水平バイアスを調整します。お役に立てれば。

2
SKG

これがあなたの欲しいものだと思います!画像とコメントをご覧ください

enter image description here

<?xml version="1.0" encoding="utf-8"?>
<Android.support.v7.widget.CardView
    xmlns:Android="http://schemas.Android.com/apk/res/Android"
    xmlns:app="http://schemas.Android.com/apk/res-auto"
    xmlns:tools="http://schemas.Android.com/tools"
    Android:layout_width="match_parent"
    Android:layout_height="match_parent">

    <Android.support.constraint.ConstraintLayout
        Android:layout_width="match_parent"
        Android:layout_height="wrap_content"
        Android:padding="10dp">

        <ImageView
            Android:id="@+id/imageView2"
            Android:layout_width="wrap_content"
            Android:layout_height="wrap_content"
            app:layout_constraintBottom_toBottomOf="@+id/textView2"
            app:layout_constraintEnd_toEndOf="@+id/textView2"
            app:layout_constraintTop_toTopOf="@+id/textView2"
            app:srcCompat="@drawable/ic_favorite_border_black_24dp"
            tools:ignore="VectorDrawableCompat" />

        <TextView
            Android:id="@+id/textView2"
            Android:layout_width="wrap_content"
            Android:layout_height="wrap_content"
            Android:layout_marginStart="8dp"
            Android:text="TextView"
            app:layout_constraintBottom_toBottomOf="parent"
            app:layout_constraintStart_toEndOf="@+id/imageView2"
            app:layout_constraintTop_toTopOf="parent"
            Android:layout_marginLeft="8dp" />


    </Android.support.constraint.ConstraintLayout>


</Android.support.v7.widget.CardView>
1
Rizwan atta