Android 5.0学习<三>

CardView控件

用于实现一个立体的卡片,提供了圆角,阴影等效果。
继承自FrameLayout,所以本身可以作为容器。

基本用法
  1. 在\extras\android\support\v7\cardview\libs\目录下,将android-support-v7-cardview.jar拷贝工程中。
  2. 拷贝CardView生成的R.java到项目中,或引用CardView第三方库到项目中,因为控件会用到自己的资源文件。
  3. 编写所需要的资源属性。
  4. 按照布局控件的方式使用。
代码实例

在Style中定义资源属性

    <!-- 资源属性 -->
    <declare-styleable name="CardView">
        <attr name="cardBackgroundColor" format="color" />
        <attr name="cardCornerRadius" format="dimension" />
    </declare-styleable>

    <!-- 默认背景色 -->
    <style name="CardView">
        <item name="cardBackgroundColor">@color/cardview_light_background</item>
    </style>

    <!-- 暗色主题默认背景色 -->
    <style name="CardView.Dark">
        <item name="cardBackgroundColor">@color/cardview_dark_background</item>
    </style>

    <!-- 亮色主题默认背景色 -->
    <style name="CardView.Light">
        <item name="cardBackgroundColor">@color/cardview_light_background</item>
    </style>

在layout中定义CardView控件信息

  • 在根节点,定义资源文件属性的命名空间
 xmlns:card_view="http://schemas.android.com/apk/res-auto"
  • 定义CardView的布局信息
        <android.support.v7.widget.CardView
            android:id="@+id/cardView"
            android:layout_width="match_parent"
            android:layout_height="96dp"
            android:layout_marginLeft="8dp"
            android:layout_marginRight="8dp"
            android:elevation="100dp"
            card_view:cardBackgroundColor="@color/cardview_initial_background"
            card_view:cardCornerRadius="8dp" >

            <TextView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_gravity="center"
                android:layout_marginLeft="8dp"
                android:layout_marginRight="8dp"
                android:text="这是一个测试CardView的小程序,不要在意这些细节"
                android:textSize="16sp" />
        </android.support.v7.widget.CardView>
  • 在Activity中声明并且使用
cardView = (CardView) findViewById(R.id.cardView);
// 控制圆角角度
cardView.setRadius(progress);
// 控制阴影,即高度
cardView.setElevation(progress);
效果展示

这里写图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值