Android 5.1上的CardView-为什么显示菱形而不是圆形?

时间:2018-10-25 07:11:42

标签: android android-layout imageview cardview

我有一个带ImageView的CardView:

<android.support.v7.widget.CardView
        android:id="@+id/message_avatar_card"
        android:layout_width="40dp"
        android:layout_height="40dp"
        android:layout_marginEnd="4dp"
        android:layout_marginStart="4dp"
        app:cardCornerRadius="40dp"
        android:innerRadius="0dp"
        android:thicknessRatio="1.9"
        android:background="@color/fui_transparent">

        <ImageView
            android:id="@+id/message_avatar"
            android:layout_width="40dp"
            android:layout_height="40dp"
            android:src="@drawable/ic_person_black_24dp"
            android:layout_marginEnd="4dp"
            android:scaleType="centerCrop"
            android:background="@color/fui_transparent"/>
    </android.support.v7.widget.CardView>

在Android 9.0上一切正常,请参见屏幕截图

android 9

但是在Android 5.1上,我看到菱形,而不是圆圈

android 5.1

如何解决?

2 个答案:

答案 0 :(得分:0)

正确的密码

<android.support.v7.widget.CardView
        android:id="@+id/message_avatar_card"
        android:layout_width="40dp"
        android:layout_height="40dp"
        android:layout_marginEnd="4dp"
        android:layout_marginStart="4dp"
        app:cardCornerRadius="20dp"
        android:innerRadius="0dp"
        android:thicknessRatio="1.9"
        android:background="@color/fui_transparent">

        <ImageView
            android:id="@+id/message_avatar"
            android:layout_width="40dp"
            android:layout_height="40dp"
            android:src="@drawable/ic_person_black_24dp"
            android:layout_marginEnd="4dp"
            android:scaleType="centerCrop"
            android:background="@color/fui_transparent"/>
    </android.support.v7.widget.CardView>

答案 1 :(得分:0)

使用 CircleImageView 库:

implementation 'de.hdodenhof:circleimageview:2.2.0'

在XML中:

<de.hdodenhof.circleimageview.CircleImageView
        xmlns:app="http://schemas.android.com/apk/res-auto"
        android:id="@+id/message_avatar"
        android:layout_width="75dp"
        android:layout_height="75dp"
        android:src="@drawable/avatar"
        app:civ_border_width="2dp"
        android:layout_gravity="center"
        app:civ_border_color="YOUR_COLOR"/> // if you don't want give any border remove this line

在Java中:

CircleImageView message_avatar = (CircleImageView) findViewById(R.id.message_avatar);

如果您是动态设置图片,请使用 Picasso 库:

implementation 'com.squareup.picasso:picasso:2.5.2'

在Java中

Picasso.with(context).load(IMAGE_PATH).into(message_avatar);