Android之androidmainfest.xml配置文件詳解


寫配置文件的時候我們會不知道把那些配置項放在哪里,請看:

配置文件樣例:

<?xml version="1.0" encoding="utf-8"?>
 
<manifest>
 
    <!-- 基本配置 -->
    <uses-permission />
    <permission />
    <permission-tree />
    <permission-group />
    <instrumentation />
    <uses-sdk />
    <uses-configuration />
    <uses-feature />
    <supports-screens />
    <compatible-screens />
    <supports-gl-texture />
    
    <!-- 應用配置 -->
    <application>
        
        <!-- Activity 配置 -->
        <activity>
            <intent-filter>
                <action />
                <category />
                <data />
            </intent-filter>
            <meta-data />
        </activity>
        
        <activity-alias>
            <intent-filter> . . . </intent-filter>
            <meta-data />
        </activity-alias>
        
        <!-- Service 配置 -->
        <service>
            <intent-filter> . . . </intent-filter>
            <meta-data/>
        </service>
        
        <!-- Receiver 配置 -->
        <receiver>
            <intent-filter> . . . </intent-filter>
            <meta-data />
        </receiver>
        
        <!-- Provider 配置 -->
        <provider>
            <grant-uri-permission />
            <meta-data />
        </provider>
        
        <!-- 所需類庫配置 -->
        <uses-library />
 
    </application>
 
</manifest>

    從以上示例代碼中,我們可以看出Android配置文件采用XML作為描述語言,每個XML標簽都不同的含義,大部分的配置參數都放在標簽的屬性中,下面我們便按照以上配置文件樣例中的先后順序來學習Android配置文件中主要元素與標簽的用法。
<manifest>

AndroidManifest.xml配置文件的根元素,必須包含一個<application>元素並且指定xlmns:android和package屬性。xlmns:android指定了Android的命名空間,默認情況下是“http://schemas.android.com/apk/res/android”;而package是標准的應用包名,也是一個應用進程的默認名稱,以本書微博應用實例中的包名為例,即“com.app.demos”就是一個標准的Java應用包名,我們為了避免命名空間的沖突,一般會以應用的域名來作為包名。當然還有一些其他常用的屬性需要注意一下,比如android:versionCode是給設備程序識別版本用的,必須是一個整數值代表app更新過多少次;而android:versionName則是給用戶查看版本用的,需要具備一定的可讀性,比如“1.0.0”這樣的。<manifest>標簽語法范例如下。

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="string"
    android:sharedUserId="string"
    android:sharedUserLabel="string resource" 
    android:versionCode="integer"
    android:versionName="string"
    android:installLocation=["auto" | "internalOnly" | "preferExternal"] >
... ...
</manifest>


<uses-permission>

為了保證Android應用的安全性,應用框架制定了比較嚴格的權限系統,一個應用必須聲明了正確的權限才可以使用相應的功能,例如我們需要讓應用能夠訪問網絡就需要配置“android.permission.INTERNET”,而如果要使用設備的相機功能,則需要設置“android.permission.CAMERA”等。<uses-permission>就是我們最經常使用的權限設定標簽,我們通過設定android:name屬性來聲明相應的權限名,比如在微博應用實例中,我們就是根據應用的所需功能聲明了對應的權限,相關代碼如下。

<manifest ...>
... ...
    <!-- 網絡相關功能 -->
    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
    <!-- 讀取電話狀態 -->
    <uses-permission android:name="android.permission.READ_PHONE_STATE"/>
    <!-- 通知相關功能 -->
    <uses-permission android:name="android.permission.VIBRATE" />
... ...
</manifest>


<permission>

權限聲明標簽,定義了供給<uses-permission>使用的具體權限,通常情況下我們不需要為自己的應用程序聲明某個權限,除非需要給其他應用程序提供可調用的代碼或者數據,這個時候你才需要使用<permission>標簽。該標簽中提供了android:name權限名標簽,權限圖標android:icon以及權限描述android:description等屬性,另外還可以和<permission-group>以及<permission-tree>配合使用來構造更有層次的、更有針對性權限系統。<permission>標簽語法范例如下。

<permission android:description="string resource"
    android:icon="drawable resource"
    android:label="string resource"
    android:name="string"
    android:permissionGroup="string"
    android:protectionLevel=["normal" | "dangerous" | "signature" | "signatureOrSystem"] />

<instrumentation>

用於聲明Instrumentation測試類來監控Android應用的行為並應用到相關的功能測試中,其中比較重要的屬性有:測試功能開關android:functionalTest,profiling調試功能開關android:handleProfiling,測試用例目標對象android:targetPackage等。另外,我們需要注意的是Instrumentation對象是在應用程序的組件之前被實例化的,這點在組織測試邏輯的時候需要被考慮到。<instrumentation>標簽語法范例如下。

<instrumentation android:functionalTest=["true" | "false"]
    android:handleProfiling=["true" | "false"]
    android:icon="drawable resource"
    android:label="string resource"
    android:name="string"
    android:targetPackage="string" />

<uses-sdk>

用於指定Android應用中所需要使用的SDK的版本,比如我們的應用必須運行於Android 2.0以上版本的系統SDK之上,那么就需要指定應用支持最小的SDK版本數為5;當然,每個SDK版本都會有指定的整數值與之對應,比如我們最常用的Android 2.2.x的版本數是8。當然,除了可以指定最低版本之外,<uses-sdk>標簽還可以指定最高版本和目標版本,語法范例如下

<uses-sdk android:minSdkVersion="integer" 
    android:targetSdkVersion="integer"
    android:maxSdkVersion="integer" />

<uses-configuration>與<uses-feature>

這兩個標簽都是用於描述應用所需要的硬件和軟件特性,以便防止應用在沒有這些特性的設備上安裝。<uses-configuration>標簽中,比如有些設備帶有D-pad或者Trackball這些特殊硬件,那么android:reqFiveWayNav屬性就需要設置為true;而如果有一些設備帶有硬件鍵盤,android:reqHardKeyboard也需要被設置為true。另外,如果設備需要支持藍牙,我們可以使用<uses-feature android:name="android.hardware.bluetooth" />來支持這個功能。這兩個標簽主要用於支持一些特殊的設備中的應用,兩個標簽的語法范例分別如下。

<uses-configuration android:reqFiveWayNav=["true" | "false"] 
    android:reqHardKeyboard=["true" | "false"]
    android:reqKeyboardType=["undefined" | "nokeys" | "qwerty" | "twelvekey"]
    android:reqNavigation=["undefined" | "nonav" | "dpad" | "trackball" | "wheel"]
    android:reqTouchScreen=["undefined" | "notouch" | "stylus" | "finger"] />
 
<uses-feature android:name="string"
    android:required=["true" | "false"]
    android:glEsVersion="integer" />

<uses-library>

用於指定Android應用可使用的用戶庫,除了系統自帶的android.app、android.content、android.view和android.widget這些默認類庫之外,有些應用可能還需要一些其他的Java類庫作為支持,這種情況下我們就可以使用<uses-library>標簽讓ClassLoader加載其類庫供Android應用運行時用。<uses-library>標簽的用法很簡單,以下是語法范例。

<uses-library android:name="string"
    android:required=["true" | "false"] />

小貼士:
當運行Java程序時,首先運行JVM(Java虛擬機),然后再把Java類加載到JVM里頭運行,負責加載Java類的這部分就叫做ClassLoader。當然,ClassLoader是由多個部分構成的,每個部分都負責相應的加載工作。當運行一個程序的時候,JVM啟動,運行BootstrapClassLoader,該ClassLoader加載java核心API(ExtClassLoader和AppClassLoader也在此時被加載),然后調用ExtClassLoader加載擴展API,最后AppClassLoader加載CLASSPATH目錄下定義的Class,這就是一個Java程序最基本的加載流程。

<supports-screens>

對於一些應用或者游戲來說,只能支持某些屏幕大小的設備或者在某些設備中的效果比較好,我們就會使用<supports-screens>標簽來指定支持的屏幕特征。其中比較重要的屬性包括:屏幕自適應屬性android:resizeable,小屏(android:smallScreens)、中屏(android:normalScreens)、大屏(android:largeScreens)和特大屏(android:xlargeScreens)支持屬性,按屏幕渲染圖像屬性android:anyDensity以及最小屏幕寬度屬性android:requiresSmallestWidthDp等。<supports-screens>標簽的語法范例如下。

<supports-screens android:resizeable=["true"| "false"]
    android:smallScreens=["true" | "false"]
    android:normalScreens=["true" | "false"]
    android:largeScreens=["true" | "false"]
    android:xlargeScreens=["true" | "false"]
    android:anyDensity=["true" | "false"]
    android:requiresSmallestWidthDp="integer"
    android:compatibleWidthLimitDp="integer"
    android:largestWidthLimitDp="integer"/>

<application>

應用配置的根元素,位於<manifest>下層,包含所有與應用有關配置的元素,其屬性可以作為子元素的默認屬性,常用的屬性包括:應用名android:label,應用圖標android:icon,應用主題android:theme等。當然,<application>標簽還提供了其他豐富的配置屬性,由於篇幅原因就不列舉了,大家可以打開Android SDK文檔來進一步學習,以下是語法范例。

<application android:allowTaskReparenting=["true" | "false"]
    android:backupAgent="string"
    android:debuggable=["true" | "false"]
    android:description="string resource"
    android:enabled=["true" | "false"]
    android:hasCode=["true" | "false"]
    android:hardwareAccelerated=["true" | "false"]
    android:icon="drawable resource"
    android:killAfterRestore=["true" | "false"]
    android:label="string resource"
    android:logo="drawable resource"
    android:manageSpaceActivity="string"
    android:name="string"
    android:permission="string"
    android:persistent=["true" | "false"]
    android:process="string"
    android:restoreAnyVersion=["true" | "false"]
    android:taskAffinity="string"
    android:theme="resource or theme" >
... ...
</application>

<activity>

Activity活動組件(即界面控制器組件)的聲明標簽,Android應用中的每一個Activity都必須在AndroidManifest.xml配置文件中聲明,否則系統將不識別也不執行該Activity。<activity>標簽中常用的屬性有:Activity對應類名android:name,對應主題android:theme,加載模式android:launchMode(詳見2.1.3.4節),鍵盤交互模式android:windowSoftInputMode等,其他的屬性用法大家可以參考Android SDK文檔學習。另外,<activity>標簽還可以包含用於消息過濾的<intent-filter>元素,當然還有可用於存儲預定義數據的<meta-data>元素,以下是<activity>標簽的語法范例。

<activity android:allowTaskReparenting=["true" | "false"]
    android:alwaysRetainTaskState=["true" | "false"]
    android:clearTaskOnLaunch=["true" | "false"]
    android:configChanges=["mcc", "mnc", "locale",
        "touchscreen", "keyboard", "keyboardHidden",
        "navigation", "orientation", "screenLayout",
        "fontScale", "uiMode"]
    android:enabled=["true" | "false"]
    android:excludeFromRecents=["true" | "false"]
    android:exported=["true" | "false"]
    android:finishOnTaskLaunch=["true" | "false"]
    android:hardwareAccelerated=["true" | "false"]
    android:icon="drawable resource"
    android:label="string resource"
    android:launchMode=["multiple" | "singleTop" | "singleTask" | "singleInstance"]
    android:multiprocess=["true" | "false"]
    android:name="string"
    android:noHistory=["true" | "false"]  
    android:permission="string"
    android:process="string"
    android:screenOrientation=["unspecified" | "user" | "behind" |
        "landscape" | "portrait" |
        "sensor" | "nosensor"]
    android:stateNotNeeded=["true" | "false"]
    android:taskAffinity="string"
    android:theme="resource or theme"
    android:windowSoftInputMode=["stateUnspecified",
        "stateUnchanged", "stateHidden",
        "stateAlwaysHidden", "stateVisible",
        "stateAlwaysVisible", "adjustUnspecified",
        "adjustResize", "adjustPan"] >   
... ...
</activity>

<activity-alias>

Activity組件別名的聲明標簽,簡單來說就是Activity的快捷方式,屬性android:targetActivity表示的就是其相關的Activity名,當然必須是前面已經聲明過的Activity。除此之外,其他比較常見的屬性有:Activity別名名稱android:name,別名開關android:enabled,權限控制android:permission等。另外,我們還需要注意的是,Activity別名也是一個獨立的Activity,可以擁有自己的<intent-filter>和<meta-data>元素,其語法范例如下。

<activity-alias android:enabled=["true" | "false"]
    android:exported=["true" | "false"]
    android:icon="drawable resource"
    android:label="string resource"
    android:name="string"
    android:permission="string"
    android:targetActivity="string" >
... ...
</activity-alias>

<intent-filter>與<action>、<category>、<data>

<intent-filter>用於Intent消息過濾器的聲明,在前面的2.1.3.2節中我們已經對Android應用框架中的Intent消息作過比較詳細的介紹,我們了解到Intent消息對於Android應用系統來說,是非常重要的“粘合劑”,<intent-filter>元素可以放在<activity>、<activity-alias>、<service>和<receiver>元素標簽中,來區分可用於處理消息的Activity控制器、Service服務和廣播接收器Broadcast Receiver。另外,我們還知道Intent消息還包含有名稱、動作、數據、類別等幾個重要屬性。這點與該標簽的寫法也有一定的關系,比如<intent-filter>中必須包含有<action>元素,即用於描述具體消息的名稱;<category>標簽則用於表示能處理消息組件的類別,即該Action所符合的類別;而<data>元素則用於描述消息需要處理的數據格式,我們甚至還可以使用正則表達式來限定數據來源。當然,這些元素和標簽的具體用法我們還需要慢慢學習,下面是標准<intent-filter>元素標簽的語法范例。

<intent-filter android:icon="drawable resource"
    android:label="string resource"
    android:priority="integer" >
    <action android:name="string" />
    <category android:name="string" />
    <data android:host="string"
        android:mimeType="string"
        android:path="string"
        android:pathPattern="string"
        android:pathPrefix="string"
        android:port="string"
        android:scheme="string" />
</intent-filter>

<meta-data>

用於存儲預定義數據,和<intent-filter>類似,<meta-data>也可以放在<activity>、<activity-alias>、<service>和<receiver>這四個元素標簽中。Meta數據一般會以鍵值對的形式出現,個數沒有限制,而這些數據都將被放到一個Bundle對象中,程序中我們則可以使用ActivityInfo、ServiceInfo甚至ApplicationInfo對象的metaData屬性中讀取。假設我們在一個Activity中定義了一個<meta-data>元素,相關示例用法如下。

<activity...>
    <meta-data android:name="testData" android:value="Test Meta Data"></meta-data>
</activity>
 
ActivityInfo info = this.getPackageManager()
    .getActivityInfo(getComponentName(), PackageManager.GET_META_DATA);
String testData = info.metaData.getString("testData");
System.out.println("testData:" + testData);

<service>

Service服務組件的聲明標簽,用於定義與描述一個具體的Android服務,主要屬性有:Service服務類名android:name,服務圖標android:icon,服務描述android:label以及服務開關android:enabled等。關於Service服務組件的概念和用法請參考2.1.4.2節的內容,以下是<service>標簽的語法范例。

<service android:enabled=["true" | "false"]
    android:exported=["true" | "false"]
    android:icon="drawable resource"
    android:label="string resource"
    android:name="string"
    android:permission="string"
    android:process="string" >
... ...
</service>

<receiver>

Boardcast Receiver廣播接收器組件的聲明標簽,用於定義與描述一個具體的Android廣播接收器,其主要屬性和<service>標簽有些類似:Boardcast Receiver接收器類名android:name,接收器圖標android:icon,接收器描述android:label以及接收器開關android:enabled等。關於Boardcast Receiver廣播接收器組件的概念和用法請參考2.1.4.3節的內容,以下是<receiver>標簽的語法范例。

<receiver android:enabled=["true" | "false"]
    android:exported=["true" | "false"]
    android:icon="drawable resource"
    android:label="string resource"
    android:name="string"
    android:permission="string"
    android:process="string" >
... ...
</receiver>

<provider>與<grant-uri-permission>

除Activity、Service和Boardcast Receiver之外的另一個“四大組件”,也就是Content Provider內容提供者的聲明標簽。關於內容提供者組件的概念和用法請參考2.1.4.4節的內容,不再贅述。<provider>標簽除了和其他組件相同的android:name、android:icon和android:label等基礎屬性之外,還提供了用於支持其功能的特殊屬性,如:內容提供者標識名稱android:authorities,對指定URI授予權限標識android:grantUriPermission以及具體的讀、寫權限,即android:readPermission和android:writePermission等。當然,這些屬性的具體用法我們還需要慢慢學習,以下是<provider>標簽的語法范例。

<provider android:authorities="list"
    android:enabled=["true" | "false"]
    android:exported=["true" | "false"]
    android:grantUriPermissions=["true" | "false"]
    android:icon="drawable resource"
    android:initOrder="integer"
    android:label="string resource"
    android:multiprocess=["true" | "false"]
    android:name="string"
    android:permission="string"
    android:process="string"
    android:readPermission="string"
    android:syncable=["true" | "false"]
    android:writePermission="string" >
... ...
</provider>

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM