支持不同的平台版本
定最小和Target API级别
例如:
<manifest xmlns:android="http://schemas.android.com/apk/res/android" ... > <uses-sdk android:minSdkVersion="4" android:targetSdkVersion="15" /> ... </manifest>
随着新版Android的发布,一些风格和行为可能会改变。 为了让您的应用程序能够利用这些更改,并确保您的应用程序适合每个用户设备的风格,您应该将targetSdkVersion值设置为与最新版本的Android版本相匹配
在运行时检查系统版本
Android在Build常量类中为每个平台版本提供了一个唯一的代码。在您的应用程序中使用这些代码来构建条件,确保只有在系统上提供这些API时,才会执行依赖于更高API级别的代码。
private void setUpActionBar() { // Make sure we're running on Honeycomb or higher to use ActionBar APIs if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) { ActionBar actionBar = getActionBar(); actionBar.setDisplayHomeAsUpEnabled(true); } }
Note: 解析XML资源时,Android会忽略当前设备不支持的XML属性。因此,您可以安全地使用仅由较新版本支持的XML属性,而不用担心旧版本遇到该代码时会破坏旧版本。例如,如果您设置targetSdkVersion =“11”,则应用程序在Android 3.0及更高版本上默认包含ActionBar。然后将菜单项添加到操作栏,您需要在菜单资源XML中设置android:showAsAction =“ifRoom”。可以在跨版本的XML文件中做到这一点,因为旧版本的Android只是忽略showAsAction属性(也就是说,在res / menu-v11 /中不需要单独的版本)。
使用平台样式和主题
Android提供用户体验主题,为应用程序提供底层操作系统的外观和感觉。 这些主题可以应用到清单文件中的应用程序。 通过使用这些内置的样式和主题,您的应用程序将自然地遵循Android的最新外观和每个新版本的感觉。
To make your activity look like a dialog box:
<activity android:theme="@android:style/Theme.Dialog">
To make your activity have a transparent background:
<activity android:theme="@android:style/Theme.Translucent">
To apply your own custom theme defined in /res/values/styles.xml
:
<activity android:theme="@style/CustomTheme">
To apply a theme to your entire app (all activities), add the android:theme
attribute to the <application>
element:
<application android:theme="@style/CustomTheme">