• Android 之 AndroidManifest.xml 详解(二)


    [10]<activity>

          Activity活动组件(即界面控制器组件)的声明标签,Android应用中的每一个Activity都必须在AndroidManifest.xml配置文件中声明,否则系统将不识别也不执行该Activity。另外,<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>
    

    (1)android:allowTaskReparenting=["true" | "false"]:是否允许activity更换从属的任务,比如从短信息任务切换到浏览器任务。

    (2)android:alwaysRetainTaskState=["true" | "false"]:是否保留状态不变, 比如切换回home, 再从新打开, activity处于最后的状态 。  

    (3)android:clearTaskOnLaunch=["true"" | "false"] :比如 P 是 activity, Q 是被P 触发的 activity, 然后返回Home, 从新启动 P, 是否显示 Q 。          

    (4)android:configChanges=[one or more of: "mcc" "mnc" "locale"  "touchscreen" "keyboard" "keyboardHidden" "navigation" "orientation"  "fontScale"]:当配置list发生修改时, 是否调用 onConfigurationChanged() 方法 比如 "locale|navigation|orientation".          

    (5) android:enabled=["true" | "false"]:activity是否可以被实例化。        

    (6)android:excludeFromRecents=["true" | "false"]:是否可被显示在最近打开的activity列表里。     

    (7)android:exported=["true" | "false"]:是否允许activity被其它程序调用。          

    (8)android:finishOnTaskLaunch=["true" | "false"]:是否关闭已打开的activity当用户重新启动这个任务的时候。       

    (9)android:icon="drawable resource"           

    (10)android:label="string resource"          

    (11)android:launchMode=["multiple" | "singleTop" |"singleTask" | "singleInstance"]:activity启动方式, "standard" "singleTop" "singleTask" "singleInstance" 其中前两个为一组, 后两个为一组。         

    (12)android:multiprocess=["true" | "false"]            

    (13)android:name="string"            

    (14)android:noHistory=["true" | "false"]:是否需要移除这个activity当用户切换到其他屏幕时。 这个属性是 API level 3 中引入的         

    (15)android:permission="string"         

    (16)android:process="string"     一个activity运行时所在的进程名,所有程序组件运行在应用程序默认的进程中,这个进程名跟应用程序的包名一致。    <application>中的元素process属性能够为所有组件设定一个新的默认值。但是任何组件都可以覆盖这个默认值,允许你    将你的程序放在多进程中运行。 如果这个属性被分配的名字以:开头,当这个activity运行时,一个新的专属于这个程序的    进程将会被创建。如果这个进程名以小写字母开头,这个activity将会运行在全局的进程中,被它的许可所提供。        

    (17)android:screenOrientation=["unspecified" | "user" | "behind" |"landscape" | "portrait" | "sensor" | "nonsensor"]           activity显示的模式, "unspecified" 默认值 "landscape" 风景画模式,宽度比高度大一些 "portrait" 肖像模式, 高度比    宽度大。 "user" 用户的设置 "behind" "sensor" "nosensor"          

    (18)android:stateNotNeeded=["true" | "false"]:是否 activity被销毁和成功重启并不保存状态 。

    (19)android:taskAffinity="string":activity的亲属关系, 默认情况同一个应用程序下的activity有相同的关系。      

    (20)android:theme="resource or theme":activity的样式主题, 如果没有设置,则activity的主题样式从属于应用程序。

    (21)android:windowSoftInputMode=[one or more of: "stateUnspecified""stateUnchanged" "stateHidden" "stateAlwaysHidden"           "stateVisible""stateAlwaysVisible""adjustUnspecified""adjustResize" "adjustPan"] >: activity主窗口与软键盘的交互模式, 自从API level 3 被引入。 

    [11]<activity-alias>

          Activity组件别名的声明标签,简单来说就是Activity的快捷方式,属性android:targetActivity表示的就是其相关的Activity名,当然必须是前面已经声明过的Activity。另外,我们还需要注意的是,Activity别名也是一个独立的Activity,可以拥有自己的<intent-filter>和<meta-data>元素。

    (1)android:name:Activity别名名称;

    (2)android:enabled:别名开关;

    (3)android:permission:权限控制等。

    其语法范例如下:

    <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>
    

    [12]<intent-filter>与<action>、<category>、<data>

    (1)<intent-filter>:用于Intent消息过滤器的声明:<intent-filter>元素可以放在<activity>、<activity-alias>、<service>和<receiver>元素标签中,来区分可用于处理消息的Activity控制器、Service服务和广播接收器Broadcast Receiver。另外,我们还知道Intent消息还包含有名称、动作、数据、类别等几个重要属性。这点与该标签的写法也有一定的关系,以下元素:

    1)<action>:<intent-filter>中必须包含有该元素,用于描述具体消息的名称;

    2)<category>:用于表示能处理消息组件的类别,即该Action所符合的类别

    3)<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>
    

    [13]<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);
    

    [14]<service>

          Service服务组件的声明标签,用于定义与描述一个具体的Android服务。

    (1)android:name:Service服务类名;

    (2)android:icon:服务图标;

    (3)android:label:服务描述;

    (4)android:enabled:服务开关等。

    以下是<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>
    

    [15]<receiver>

          Boardcast Receiver广播接收器组件的声明标签,用于定义与描述一个具体的Android广播接收器。

    (1)android:name:接收器类名;

    (2)android:icon:接收器图标;

    (3)android:label:接收器描述;

    (4)android:enabled:接收器开关等。

    以下是<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>
    

    [16]<provider>与<grant-uri-permission>

          除Activity、Service和Boardcast Receiver之外的另一个“四大组件”,也就是Content Provider内容提供者的声明标签。

    (1)android:name

    (2)android:icon

    (3)android:label

    用于支持其功能的特殊属性:

    (4)android:authorities:内容提供者标识名称;

    (5)android:grantUriPermission:对指定URI授予权限标识;

    (6)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>
    
  • 相关阅读:
    外部程序启动App
    简单修改文件名python脚本
    监听软键盘的显示
    ActionBar 笔记
    ActionBar 笔记
    Android Lock Pattern 图案解锁
    通过反射实现圆角ImageView
    android 通过命令行启动Apk
    ubuntu svn rabbitvcs 安装
    Android 两个界面间快速切换时,会发现有短暂黑屏
  • 原文地址:https://www.cnblogs.com/xinaixia/p/4113369.html
Copyright © 2020-2023  润新知