Android應(yīng)用開發(fā)中CardView的初步使用指南
引言
在Google I/O 2014上,Google公布了Android L Preview版本,此版本的UI有了非常大的改變,很炫很給力!同時,Google也給出了兩個可以向下兼容的控件放到了V7包中,分別是RecyclerView和CardView,這篇博文就說一下怎么使用CardView。
CardView的包在哪?
雖然說CardView整合到了V7中,但是在support-v7中并不能發(fā)現(xiàn),通過查看sdk extra路徑下的文件可以發(fā)現(xiàn),其名字叫cardview-v7。
這個路徑下就有cardview相關(guān)的東西了,包括已經(jīng)打包好的aar包。
依賴
如果應(yīng)用是以Gradle構(gòu)建的,引用CardView就很簡單了:
dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) compile 'com.android.support:cardview-v7:21.0.0-rc1' }
如果Gradle提示找不到,就證明你的SDK需要更新了,把Google support包更新到最新吧。
如果沒有用Gradle構(gòu)建,就需要找到j(luò)ar包引用進來,而jar包隱藏在CardView的aar文件中:
以壓縮包方式打開aar,提取出其中的class.jar,這個jar文件就可以當(dāng)作庫文件進行依賴了。
依賴添加完成后,進行編譯會發(fā)現(xiàn)出現(xiàn)minSdk錯誤,cardview-v7的minsdk為“L",其實CardView能夠向下兼容到2.0。
在Android gradle tools 0.11版本后,可以通過xml中的tools配置進行節(jié)點替換,而AndrodiStudio對gradle tools的支持更好一些,其ParentIDE Intellij都不行,所以目前我能找到的正常使用CardView的IDE及配置辦法只有在AndroidStudio中,不過這也是趨勢,早用早好的事情。
解決辦法:
在使用CardView的工程的AndroidManifest.xml中:
<uses-sdk xmlns:tools="http://schemas.android.com/tools" tools:node="replace" />
意思就是在做AndroidoManifest.xml編譯時,采用替換的策略,即全部使用build.gradle中定義的屬性作為最終屬性。添加完成后,再次編譯,問題解決。
使用
在使用CardVIew之前,要明白CardView是個什么東西。CardView如Linearlayout、Framelayout一樣都是ViewGroup,即其他控件的容器。CardView繼承于Framelayout,所以Framelayout的屬性他都有,同時CardView還有幾個特殊的屬性:
在API21(Android L)等級以上擁有屬性elevation,意為CardView的Z軸陰影,只有L平臺有效。只能通過xml中的elevation屬性指定;
其余(2.0以上)有屬性cardBackgroundColor,意為CardView的卡片顏色,只能通過xml的cardBackgroundColor進行指定;
其余(2.0以上)有屬性cardConerRadius,意為CardView卡片的四角圓角矩形程度,單位dimen(dp px sp),可以通過xml指定,也可以通過代碼中的setRadius指定。
示例:
<android.support.v7.widget.CardView xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" android:id="@+id/cardview" app:cardCornerRadius="8dp" app:cardBackgroundColor="@color/black" android:layout_margin="8dp" android:layout_height="80dp" android:layout_width="match_parent"> <TextView android:text="TextView in CardView" android:layout_gravity="center" android:textSize="26sp" android:textColor="@color/l_white" android:layout_width="wrap_content" android:layout_height="wrap_content" /> </android.support.v7.widget.CardView>
效果圖:
CardView繼承至FrameLayout類,可以在一個卡片布局中一致性的顯示內(nèi)容,卡片可以包含圓角和陰影。CardView是一個Layout,可以布局其他View。
CardView常用屬性:
- card_view:cardElevation 陰影的大小
- card_view:cardMaxElevation 陰影最大高度
- card_view:cardBackgroundColor 卡片的背景色
- card_view:cardCornerRadius 卡片的圓角大小
- card_view:contentPadding 卡片內(nèi)容于邊距的間隔
- card_view:contentPaddingBottom 卡片內(nèi)容與底部的邊距
- card_view:contentPaddingTop 卡片內(nèi)容與頂部的邊距
- card_view:contentPaddingLeft 卡片內(nèi)容與左邊的邊距
- card_view:contentPaddingRight 卡片內(nèi)容與右邊的邊距
- card_view:contentPaddingStart 卡片內(nèi)容于邊距的間隔起始
- card_view:contentPaddingEnd 卡片內(nèi)容于邊距的間隔終止
- card_view:cardUseCompatPadding 設(shè)置內(nèi)邊距,V21+的版本和之前的版本仍舊具有一樣的計算方式
- card_view:cardPreventConrerOverlap 在V20和之前的版本中添加內(nèi)邊距,這個屬性為了防止內(nèi)容和邊角的重疊
再來看一個例子:
<android.support.v7.widget.CardView xmlns:card_view="http://schemas.android.com/apk/res-auto" android:layout_width="200dp" android:layout_height="wrap_content" card_view:cardBackgroundColor="#303069" card_view:cardCornerRadius="10dp" card_view:cardPreventCornerOverlap="true" card_view:cardUseCompatPadding="true" card_view:contentPadding="10dp"> ... </android.support.v7.widget.CardView>
注:在gradle的dependencies中添加`compile 'com.android.support:cardview-v7:21.+'`
然后視圖中的卡片基本上會這樣顯示:
CardView繼承至FrameLayout類,可以在一個卡片布局中一致性的顯示內(nèi)容,卡片可以包含圓角和陰影。CardView是一個Layout,可以布局其他View。
相關(guān)文章
一文搞懂Android RecyclerView點擊展開、折疊效果的實現(xiàn)代碼
雖然在日常開發(fā)中已經(jīng)多次接觸過RecycleView,但也只是用到其最基本的功能,并沒有深入研究其他內(nèi)容。接下來將抽出時間去了解RecycleView的相關(guān)內(nèi)容,這篇文章主要是介紹Android RecyclerView點擊展開、折疊效果的實現(xiàn)方式,一起看看吧2021-06-06Android中的webview監(jiān)聽每次URL變化實例
這篇文章主要介紹了Android中的webview監(jiān)聽每次URL變化實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-03-03Android網(wǎng)絡(luò)工具類NetworkUtils詳解
這篇文章主要為大家詳細介紹了Android網(wǎng)絡(luò)工具類NetworkUtils,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-04-04android AsynTask處理返回數(shù)據(jù)和AsynTask使用get,post請求
本文主要介紹了android AsynTask處理返回數(shù)據(jù)和AsynTask使用get,post請求方法。具有一定的參考價值,下面跟著小編一起來看下吧2017-01-01Android實戰(zhàn)教程第二篇之簡單實現(xiàn)兩種進度條效果
這篇文章主要為大家詳細介紹了Android實戰(zhàn)教程第二篇,簡單實現(xiàn)兩種進度條效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-11-11