2-VVI-材料设计之CardView

零、前言

[1].CardView extends FrameLayout [2].一个带圆角和阴影的FrameLayout,FrameLayout怎么用,它就怎么用 [3].依赖implementation 'com.android.support:cardview-v7:26.1.0'

CardView.gif

一、使用:

1.属性一览:
  app:cardBackgroundColor      背景颜色
  app:cardCornerRadius         圆角大小
  app:cardElevation            z轴阴影高度
  app:cardMaxElevation         z轴最大高度值

  app:contentPadding           内容与边距的间隔
  app:contentPaddingLeft       内容与左边的间隔
  app:contentPaddingTop        内容与顶部的间隔
  app:contentPaddingRight      内容与右边的间隔
  app:contentPaddingBottom     内容与底部的间隔    

  app:paddingStart             内容与边距的间隔起始
  app:paddingEnd               内容与边距的间隔终止

  app:cardUseCompatPadding     设置内边距,在API21及以上版本和之前的版本仍旧具有一样的计算方式
  app:cardPreventConrerOverlap 在API20及以下版本中添加内边距,这个属性为了防止内容和边角的重叠
  注意:CardView中使用android:background设置背景颜色无效。
2.可在style里抽一下常用的卡片样式:
    <!--cardView常用配置-->
    <style name="MyBaseCard" parent="@style/CardView.Light">
        <item name="cardPreventCornerOverlap">false</item>
        <item name="cardUseCompatPadding">true</item>
        <item name="cardElevation">9dp</item>
        <item name="cardCornerRadius">6dp</item>

        <item name="android:foreground">?attr/selectableItemBackground</item>
        <item name="cardBackgroundColor">#A0BDF4</item>
    </style>
3.使用:
<?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">

    <android.support.v7.widget.CardView
        android:id="@+id/id_cv"
        style="@style/MyBaseCard"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_margin="15dp"
        android:layout_marginTop="8dp"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.441"
        app:layout_constraintStart_toStartOf="parent">

        <LinearLayout
            android:layout_width="200dp"
            android:layout_height="230dp"
            android:orientation="vertical">
            <ImageView
                android:layout_gravity="center"
                android:id="@+id/id_img"
                android:layout_width="wrap_content"
                android:layout_height="180dp"
                android:padding="5dp"
                android:src="@mipmap/c1"/>
            <TextView
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:background="#E8E9EA"
                android:gravity="center"
                android:padding="8dp"
                android:text="红红战士"
                android:textColor="#FF0000"/>
        </LinearLayout>
    </android.support.v7.widget.CardView>

</android.support.constraint.ConstraintLayout>
4.Activity:
public class V02_CardActivity extends AppCompatActivity {

    @BindView(R.id.id_cv)
    CardView mIdCv;
    @BindView(R.id.id_img)
    ImageView mIdImg;
    int count = 0;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.a2_card);
        ButterKnife.bind(this);
        mIdCv.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                runAnima();
            }
        });
    }

    private void runAnima() {
        mIdCv.animate().translationX(100 + count).setDuration(1000).start();
        count += 10;
    }
}

二、后记
1.阴影Padding
CardView会自动添加一些额外的padding空间来绘制阴影部分,
这也导致了以V21为界的不同系统上CardView的尺寸大小不同
app:cardUseCompatPadding="true"适配
2.圆角覆盖:剪裁情况
app:cardPreventCornerOverlap="false"适配
3.点击涟漪
android:foreground="?android:attr/selectableItemBackground"

本文由张风捷特烈原创,转载请注明 更多安卓技术欢迎访问:https://www.jianshu.com/c/004f3fe34c94 张风捷特烈个人网站,编程笔记请访问:http://www.toly1994.com 你的喜欢与支持将是我最大的动力

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Android 技术栈

Android 关于Glide的拓展(高斯模糊、加载监听、圆形图片)

Glide默认开启磁盘缓存和内存缓存,当然也可以对单张图片进行设置特定的缓存策略。 设置图片不加入到内存缓存

7403
来自专栏Android机器圈

Android图片处理--缩放

把ImageView或者PhotoView的对象名直接添加到display中就OK 了。

2406
来自专栏飞雪无情的博客

Android Layout的layout_height等属性为什么会不起作用?

有的时候,我们配置好的布局文件,在加载完成添加到我们的Activity中后发现,并没有安装我们设置的属性来布局,比为我们设置了android:layout_ma...

1093
来自专栏雨过天晴

转 Android设置虚线、圆角、渐变

1713
来自专栏Android机器圈

自定义tab吸顶效果一(原理)

PS:问题:什么是吸顶,吸顶有什么作用,吸顶怎么使用? 在很多app商城中,介绍软件的时候就会使用吸顶效果, 吸顶有很多作用,一个最简单粗暴的作用就是,让用户知...

63913
来自专栏Hongten

android开发_SimpleAdapter适配器

drawable-hdpi文件夹中的图片是自己加入的。主要是在菜单选项中显示的图片:

912
来自专栏向治洪

BottomSheet底部动作条使用

底部动作条 底部动作条(Bottom Sheets)是一个从屏幕底部边缘向上滑出的一个面板,使用这种方式向用户呈现一组功能。底部动作条呈现了简单、清晰、无需额...

2388
来自专栏Android干货

Android项目实战(二):安卓应用程序退出的三种方法

2785
来自专栏Flutter入门到实战

Android仿简书长按文章生成图片效果

使用简书APP的同学都知道,简书有这样一个功能:文章页长按内容时底部会出现一个 生成图片分享 的按钮,点击之后就可以将当前的文章生成一张长图片,这张图片可以保存...

2902
来自专栏Android干货

安卓开发_慕课网_百度地图_添加覆盖物

30510

扫码关注云+社区