2-VVI-材料设计之CardView
零、前言
[1].CardView extends FrameLayout
[2].一个带圆角和阴影的FrameLayout,FrameLayout怎么用,它就怎么用
[3].依赖implementation 'com.android.support:cardview-v7:26.1.0'
一、使用:
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"
后记、
1.声明:
[1]本文由张风捷特烈原创,转载请注明
[2]欢迎广大编程爱好者共同交流
[3]个人能力有限,如有不正之处欢迎大家批评指证,必定虚心改正
[4]你的喜欢与支持将是我最大的动力
2.连接传送门:
更多安卓技术欢迎访问:安卓技术栈
我的github地址:欢迎star
简书首发,腾讯云+社区同步更新
张风捷特烈个人网站,编程笔记请访问:http://www.toly1994.com
3.联系我
QQ:1981462002
邮箱:1981462002@qq.com
微信:zdl1994328
4.欢迎关注我的微信公众号,最新精彩文章,及时送达:

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
-
上一篇
react native 百度统计 ios端集成
react native 百度统计Android端的集成可参考:https://www.jianshu.com/p/cc354c6a81d5 希望能够让同学们少走些弯路。 百度统计的集成还是蛮简单的,主要分下面一些步骤: 步骤 sdk的集成 交互类 sdk的配置以及初始化 RN 端调用 1. sdk 的集成 官网下载地址:https://mtj.baidu.com/web/sdk/index 我这里选择的是手动埋点的方式。 官网的 技术文档介绍:https://mtj.baidu.com/static/userguide/book/ios/sdk/manual.html 官网介绍的已经很清楚,比友盟的集成清晰很多,大家按照文档操作就可以,很顺利就能完成集成。 2.交互类 git上有个开源的交互类 大家可进行参考修改https://github.com/BaiduMobileAnalysis/baidumobstat-react-native/blob/master/ios/RCTBaiduMobStat/RCTBaiduMobStat/RCTBaiduMobStat.m // // R...
-
下一篇
安卓面试中高级安卓开发工程师总结之——如何写一份让HR主动邀请你面试的简历
简历是用人单位做人事筛选的评判标准。如何让自己的简历被更多公司HR看到,并且通过技术部简历初步审核呢? 博主这次跳槽,只投过一次8个公司(小公司)的简历。然后就再也没有主动投递过简历,仅仅把自己的简历,就收到了很多大公司的面试邀请。那么博主是怎么做的呢? 首先准备一份真实的简历。真实不代表不能包装。至于怎么包装,这是一个技术活,我后面在讲。然后最好不要选择智联,51job,这些已经过时的,人才网站。也不要用58,赶集这样普通岗位的网站。最好在拉钩,猎聘,boss投递简历。不愿意花钱在人事招聘上的公司,是不会有太高的薪资和薪资涨幅的。所以,像猎聘这些高门槛,高收费,高认证,高标准的招聘网站中的公司,很多都是比较舍得花钱寻找适合自己的人才的。同时你会发现,猎聘的大公司非常多,并且薪资给的也普遍比较高。所以,建议各位在猎聘求职,补充自己的简历,然后猎聘中猎头公司非常多,如果你不想被猎头公司骚扰,你可以设置成简历仅对公司HR可见。如果你还在职,不想自己的简历被自己的公司看到,你可以屏蔽自己的公司(也可以屏蔽掉其他公司)。 第二:如果你投递的公司是大互联网公司,那么你的简历必须真实可查。尤其是学...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- SpringBoot2整合Thymeleaf,官方推荐html解决方案
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- MySQL8.0.19开启GTID主从同步CentOS8
- MySQL数据库在高并发下的优化方案
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- SpringBoot2更换Tomcat为Jetty,小型站点的福音
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- SpringBoot2全家桶,快速入门学习开发网站教程