您可以根据平台版本选择主题,如Styles and Themes开发指南中所述。在res/values/styles.xml中定义样式,如下所示:
<style name="ThemeSelector" parent="android:Theme.Light">
...
</style>
然后在 res/values-v11/ 文件夹中选择您的主题(如果您使用的是暗色主题,则可能是 Holo)。
<style name="ThemeSelector" parent="android:Theme.Holo">
...
</style>
然后在该样式中添加图标。例如,这是来自HoneycombGallery示例应用程序的styles.xml文件的片段。
<style name="AppTheme.Dark" parent="@android:style/Theme.Holo">
...
<item name="menuIconCamera">@drawable/ic_menu_camera_holo_dark</item>
<item name="menuIconToggle">@drawable/ic_menu_toggle_holo_dark</item>
<item name="menuIconShare">@drawable/ic_menu_share_holo_dark</item>
</style>
底部的三个元素都是drawable目录中的图标。您仍然需要至少一个文件夹来放置每组特定分辨率的图标,但您可以将浅色和深色图标合并到同一个文件夹中,而不必为每个平台版本创建不同的图标文件夹。此外,您需要在values/attrs.xml文件中将它们列为引用,就像这样:
<resources>
<declare-styleable name="AppTheme">
<attr name="listDragShadowBackground" format="reference" />
<attr name="menuIconCamera" format="reference" />
<attr name="menuIconToggle" format="reference" />
<attr name="menuIconShare" format="reference" />
</declare-styleable>
</resources>
在此之后,您将能够使用 "?attr/NameOfYourDrawable" 来引用它们在布局 XML 中的位置,就像这样:
<item android:id="@+id/menu_camera"
android:title="@string/camera"
android:icon="?attr/menuIconCamera"
android:showAsAction="ifRoom" />