先來看這樣一個錯誤:
No resource found that matches the given name '@style/Theme.AppCompat.Light'
對於這個錯誤,相信大部分Android開發者都遇到過,可能很多朋友通過百度或者Google已經解決了這個問題,但是網上大部分都只給出瞭解決方法。
正所謂知其然,知其所以然,本文將從此問題出發,深入分析探討導致此問題的原因、由其衍生出來的一系列問題及其解決方案。
Android Support Library
The Android Support Library package is a set of code libraries that provide backward-compatible versions of Android framework APIs as well as features that are only available through the library APIs.
Android的SDK版本很多,新的SDK版本包含了很多新的特性,爲此Google官方提供Android Support Library package來保證高版本SDK的向下兼容。通過使用此包,可以讓擁有最新SDK特性的應用運行在API lever 4(即Android 1.6) 及更高版本的設備之上。
- v4 Support Library
此包用在API lever 4(即Android 1.6)及更高版本之上。它包含了較多的內容,使用非常廣泛,例如:Fragment,NotificationCompat,LoadBroadcastManager,ViewPager,PageTabStrip,Loader,FileProvider 等。 -
v7 Support Libraries
此包是針對API level 7(即Android 2.1)及以上版本而設計的,但是v7是要依賴v4這個包的,v7支持了Action Bar以及一些Theme的兼容。Note: v7 appcompat library
v7 appcompat library 是包含在 v7 Support Libraries裏面的一個包,正是此包增加了Action Bar 用戶界面的設計模式,並加入了對material design 的支持,是我們使用最多的一個兼容包。 -
v13 Support Library
此包是針對API level 13(即Android 3.2)及更高版本設計的,一般我們都不常用,平板開發中能用到,這裏就不過多介紹了。 - v17 Preference Support Library for TV
看名字就知道了,此包主要是爲了TV設備而設計。
Android Theme
- Hoho Theme
在4.0之前Android可以說是沒有設計可言的,在4.0之後推出了Android Design,從此Android在設計上有了很大的改善,而在程序實現上相應的就是Holo風格,所以你看到有類似 Theme.Holo.Light、 Theme.Holo.Light.DarkActionBar 就是4.0的設計風格,但是爲了讓4.0之前的版本也能有這種風格怎麼辦呢?這個時候就不得不引用v7包了,所以對應的就有 Theme.AppCompat.Light、Theme.AppCompat.Light.DarkActionBar,如果你的程序最小支持的版本是API14(即Android 4.0),那麼可以不用考慮v7的兼容。
- Material Design Theme
Android在5.0版本推出了Material Design的概念,這是Android設計上又一大突破。對應的程序實現上就有Theme.Material.Light、 Theme.Material.Light.DarkActionBar等,但是這種風格只能應用在在5.0版本的手機,如果在5.0之前應用Material Design該怎麼辦呢?同樣的引用appcompat-v7包,這個時候的Theme.AppCompat.Light、Theme.AppCompat.Light.DarkActionBar就是相對應兼容的Material Design的Theme。
問題分析
由此可以得出以下情形會導致本文一開始提出的問題。
- 項目使用的是Theme.AppCompat主題,具體表現爲
項目values目錄styles.xml文件裏面style爲
AndroidManifest.xml文件裏面<resources> <style name="AppBaseTheme" parent="Theme.AppCompat.Light"></style> <style name="AppTheme" parent="AppBaseTheme"></style> </resources>
android:theme="@style/AppTheme"
-
項目支持的最小SDK小於API 14(即Android4.0),具體表現爲
AndroidManifest.xml文件裏面,minSdkVersion
<14,比如<uses-sdk android:minSdkVersion="8" android:targetSdkVersion="23" />
-
項目沒有導入android-support-v7-appcompat兼容包。
解決方案
此時的解決方法有如下幾種:
- 既然沒有找到
Theme.AppCompat.Light
主題,那麼我就不使用此主題。此時將項目values,values-v11,values-v14目錄下的styles.xml文件裏面的style都改爲<resources> <style name="AppBaseTheme" parent="android:Theme.Light"></style> <style name="AppTheme" parent="AppBaseTheme"></style> </resources>
-
那如果沒有找到
Theme.AppCompat.Light
主題,而我們又想要使用最新的主題效果呢,還有種方法就是將AndroidManifest.xml文件裏面,minSdkVersion
改成14,比如<uses-sdk android:minSdkVersion="14" android:targetSdkVersion="23" />
此時再將項目values,values-v11,values-v14目錄下的styles.xml文件裏面style都改爲
<resources> <style name="AppBaseTheme" parent="android:Theme.Holo.Light"></style> <style name="AppTheme" parent="AppBaseTheme"></style> </resources>
-
當然以上都不是最好的方法,只是提供一種思路。最好的方法就是導入android-support-v7-appcompat庫。下面具體介紹:
3.1 通過Android SDK Manager下載最新的Android Support Library。
下載完成之後,可以在以下目錄找到AppCompat libraryandroid-sdk/extras/android/support/v7/appcompat
3.2 將此目錄下的項目導入到Eclipse中
3.3 右鍵點擊我們的Android項目,選擇Properties,左側選擇Android,在下方Library框裏點擊Add,最後選擇appcompat_v7,確定。
此時問題就解決了。
但在以上3.2導入appcompat_v7到Eclipse之後,有可能還會出現錯誤提示,比如
appcompat_v7\res\values-v23\styles_base.xml:20: error: Error retrieving parent for item: No resource found that matches the given name 'android:Widget.Material.Button.Colored'.
出現此問題的原因是appcompat_v7已經更新到了最新版本並且高於編譯環境的SDK版本,此時在Android SDK Manager將SDK及編譯工具更新到最高版本
升級完成之後右鍵點擊appcompat_v7項目,選擇Properties,選擇Project Build Target 爲最新版本,這樣就OK了。