第一次观看我文章的朋友,可以关注、点赞、转发一下,每天分享各种干货技术和程序猿趣事
前言
CardView一般用于需要显示阴影效果的UI,此外CardView还提供了圆角的功能。(嘿嘿,这东西还能直接设置成圆形,可以简单的弄成圆形View)。CardView其实本身是使用FrameLayout 帧布局,所以它其实还是一个布局。
引用
CardView未在androidx全家桶套餐中,需要你自己添加
implementation 'androidx.cardview:cardview:1.0.0'
一个简单的使用Demo
xml
<androidx.constraintlayout.widget.ConstraintLayout
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"
tools:context=".MainActivity">
<androidx.cardview.widget.CardView
android:id="@+id/card_view"
android:layout_width="100dp"
android:layout_height="100dp"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent">
<TextView
android:id="@+id/content1"
android:text="内容"
android:gravity="center"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
</androidx.cardview.widget.CardView>
</androidx.constraintlayout.widget.ConstraintLayout>
效果图:
Api详解
设置背景颜色
注意
1.View自带原本的属性android:background="" 已经没有效果了,被下面的方法替代了
2.下面提供的api只能设置颜色不能设置图片
xml
app:cardBackgroundColor="@android:color/holo_blue_bright"
java
mCardView.setCardBackgroundColor(getResources().getColor(android.R.color.holo_blue_bright));
效果图:
设置圆角
xml
app:cardCornerRadius="50dp"
java
mCardView.setRadius(20);
效果图:
设置阴影效果
xml
app:cardElevation="30dp"
java
mCardView.setCardElevation(10);
设置最大阴影
xml
app:cardMaxElevation="100dp"
java
mCardView.setMaxCardElevation(10);
设置内边距
xml
app:contentPadding="10dp"
app:contentPaddingTop="10dp"
app:contentPaddingBottom="10dp"
app:contentPaddingLeft="10dp"
app:contentPaddingRight="10dp"
java
mCardView.setPadding(10,10,10,10);
自动设置内边距,让内容不会与圆角重叠
app:cardPreventCornerOverlap="true"
兼容模式
个别机型(说的就是你,喜欢瞎搞的华为)或者Android版本使用CardView没有效果,可能需要开启兼容模式
app:cardUseCompatPadding="true"
点子
实现一个圆形的CardView
因为,在onCreate生命周期里,CardView并没有测量绘制完成,所以我们需要等CardView运行完全部绘制工作后在执行设置圆角的代码。
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mCardView = findViewById(R.id.card_view);
mCardView.post(new Runnable() {
@Override
public void run() {
mCardView.setRadius(mCardView.getWidth()/2);
}
});
}
网友评论