Android Manifest中meta-data扩展元素数据的配置与获取方式

在AndroidManifest.xml清单文件中 我们有时会看到如下类似的<meta-data ... >元素开始的配置内容:

<meta-data
  android:name="com.google.android.maps.v2.API_KEY"
  android:value="AIzaSyBhBFOgVQclaa8p1JJeqaZHiCo2nfiyBBo" />
<meta-data
  android:name="com.google.android.gms.version"
  android:value="@integer/google_play_services_version" />

标签<meta-data>是提供组件额外的数据用的,它本身就是一个键值对,可以自定义名称和值。它可以包含在以下组件当中:

<activity>、<application> 、<service> 和 <receiver>

一、如何配置<mate-data...>元素:

标签<meta-data>元素的配置语法如下:

<meta-data android:name="string"
   android:resource="resource specification"
   android:value="string" />

说明:一般的值可以通过value属性来指定,但是如果要指定一个资源的id,则需要使用resource属性来配置。

如以下配置内容:

<meta-data android:name="api_key" android:value="@string/api_key" />

指定的api_key值为存储在资源文件string中的api_key值 如:

AIzaSyBhBFOgVQclaa8p1JJeqaZHiCo2nfiyBBo

如以下配置内容:

<meta-data android:name="resId" android:resource="@string/res_id" />

指定的resId值则是为res_id的资源id号 而不是string中的res_id值

二、如何获取<mate-data...>元素配置的值:

1、在<application...>元素下配置<mate-data...>元素

xml代码段:

<application...>
  .....
  <meta-data
     android:name="api_key"
     android:value="AIzaSyBhBFOgVQclaa8p1JJeqaZHiCo2nfiyBBo" />
</application>

Java代码段:

    try {
      ApplicationInfo appInfo = getPackageManager().getApplicationInfo(getPackageName(),
          PackageManager.GET_META_DATA);
      String value = appInfo.metaData.getString("api_key");
      Log.d("Tag", " app key : " + value); // Tag﹕ app key : AIzaSyBhBFOgVQclaa8p1JJeqaZHiCo2nfiyBBo
    } catch (PackageManager.NameNotFoundException e) {
      e.printStackTrace();
    }

2、在<activity...>元素下配置<mate-data...>元素

xml代码段:

<activity ...>
  .....
  <meta-data android:name="resource_id"
     android:resource="@string/ice" />
</activity>

Java代码段:

    try {
      ActivityInfo activityInfo = getPackageManager().getActivityInfo(getComponentName(),
          PackageManager.GET_META_DATA);
      // 获取到的是 @string/ice 对应的资源id值
      int value = activityInfo.metaData.getInt("resource_id");
      Log.d("Activity Tag", "resource_id : " + value); // Activity Tag﹕ resource_id : 2131361808
    } catch (PackageManager.NameNotFoundException e) {
      e.printStackTrace();
    }

3、在<service...>元素下配置<mate-data...>元素

xml代码段:

<service android:name="MetaDataService">
   .....
   <meta-data android:name="service_meta_data" android:value="xxxxxxx" />
</service>

Java代码段:

try {
   ComponentName cn=new ComponentName(this, MetaDataService.class);
   ServiceInfo info=this.getPackageManager()
        .getServiceInfo(cn, PackageManager.GET_META_DATA);
   String value = info.metaData.getString("service_meta_data");
   Log.d("Service TAG", " value == " + value);
} catch (PackageManager.NameNotFoundException e) {
   e.printStackTrace();
}

4、在<receiver...>元素下配置<mate-data...>元素

xml代码段:

<receiver android:name="MetaDataReceiver">
   .....
   <meta-data android:name="receiver_meta_data" android:value="xxxxxxx" />
</receiver>

Java代码段:

try {
   ComponentName cn=new ComponentName(this, MetaDataReceiver.class);
   ActivityInfo info=context.getPackageManager()
               .getReceiverInfo(cn, PackageManager.GET_META_DATA);
   String value = info.metaData.getString("receiver_meta_data");
   Log.d("Receiver TAG", " value == " + value);
} catch (PackageManager.NameNotFoundException e) {
   e.printStackTrace();
}

以上这篇Android Manifest中meta-data扩展元素数据的配置与获取方式就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • 史上最全的Android build.gradle配置教程

    前言 Android Studio是采用gradle来构建项目的,gradle是基于groovy语言的,如果只是用它构建普通Android项目的话,是可以不去学groovy的.当我们创建一个Android项目时会包含两个Android build.gradle配置详解文件,如下图: 一.Project的build.gradle文件: 对应的build.gradle代码如下: // Top-level build file where you can add configuration optio

  • AndroidManifest.xml中含盖的安全问题详解

    0x00 关于AndroidManifest.xml AndroidManifest.xml 是每个android程序中必须的文件.它位于整个项目的根目录,Manifest文件提供有关应用程序到Android系统的基本信息,系统必须具有该信息才能运行任何应用程序的代码.换句话说APP是跑在Android系统上,既然要跑在其上,就必须提供信息给Android System,这些信息就存在AndroidManifest中.AndroidManifest.xml 存放在 app/src/main/ 目

  • Android Manifest中meta-data扩展元素数据的配置与获取方式

    在AndroidManifest.xml清单文件中 我们有时会看到如下类似的<meta-data ... >元素开始的配置内容: <meta-data android:name="com.google.android.maps.v2.API_KEY" android:value="AIzaSyBhBFOgVQclaa8p1JJeqaZHiCo2nfiyBBo" /> <meta-data android:name="com.g

  • Android开发中Listview动态加载数据的方法示例

    本文实例讲述了Android开发中Listview动态加载数据的方法.分享给大家供大家参考,具体如下: 最近在研究网络数据加载的问题,比如我有几百,甚至上千条数据,这些数据如果一次性全部加载到arraylist,然后再加载到Listview中.我们必然会去单独开线程来做,这样造成的结果就是会出现等待时间很长,用户体验非常不好.我的想法是动态加载数据,第一次加载十条,然后往下面滑动的时候再追加十条,再往下面滑动的时候再去追加,这样大大减少了用户等待的时间,同时给处理数据留下了时间.网上看到了这样一

  • Vue如何在CSS中使用data定义的数据浅析

    1.考虑一个问题, 后端传来一个数据, 比如是某个百分比, 需要在页面做进度展示. 一般的情况都会在 CSS 中设置数据展示, 但是 CSS 中如何获取到后端传来的数据呢? 2.使用自定义属性: data- 通过 v-bind 将后端的数据绑定在自定义 HTML 属性上, 然后通过 CSS 的 attr() 函数获取该属性 <template> <div> <div class="box" :data-content="obj.desc"

  • Android应用中使用SharedPreferences类存储数据的方法

    在Android系统中提供了多种存储技术.通过这些存储技术可以将数据存储在各种存储介质上.比如sharedpreferences可以将数据保存着应用软件的私有存储区,这些存储区的数据只能被写入这些数据的软件读取.当然Android还支持文件存储.SQLite数据库和Content Provider.在这里我们将对sharedpreferences存储方式进行介绍. SharedPreferences是一种轻量级的数据存储方式,学过Web开发的同学,可以想象它是一个小小的Cookie.它可以用键值

  • vue3中调用api接口实现数据的渲染以及详情方式

    目录 调用api接口实现数据的渲染及详情 vue3常用api梳理 setup参数 生命周期 响应式数据 ref.reactive coumputed watch && watchEffect 获取元素 this不可用 调用api接口实现数据的渲染及详情 首先新建一个项目 yarn create vite vue3-template --template vue 然后下载相应的api npm i axios router 首先配置 App.vue <script setup> &

  • Android应用中使用XmlSerializer序列化XML数据的教程

    首先,我们看一下什么是serializer,serializer就是串行化,又名序列化.它可并不只是简单的把对象保存在存储器上,它可以使我们在流中传输对象,使对象变的可以像基本数据一样传递. XmlSerializer是针对XML进行序列化的类库,我们先来看一下里面的常用方法: 基本方法 1.创建一个xml文件的序列化器,返回的是一个Xml的 Serializer 对象. XmlSerializer = Xml.newSerializer(); 2.设置序列化器的输出路径和编码方式 FileOu

  • Centos中安装多个mysql数据的配置实例

    注:本文档做了两个MYSQL实例,多个实例方法以此类推 LINUX操作系统:centOS6.3 64bit(安装了系统默认开发包)数据库一:MYSQL版本:mysql-5.0.56PORT:3306系统目录:/usr/local/mysql3306数据库二:MYSQL版本:mysql-5.1.72PORT:3307系统目录:/usr/local/mysql3307 一.安装开发包(使用默认CENTOS更新源): 复制代码 代码如下: # yum -y install wget gcc-c++ n

  • ASP.NET中操作SQL数据库(连接字符串的配置及获取)

    在WebConfig中配置数据库连接字符串,代码如下: 复制代码 代码如下: <connectionStrings> <add name="ConnectionString" connectionString="user id=用户名;password=密码;initial catalog=数据库名称;data source=服务器名称"/> </connectionStrings> 然后在Webform_1.aspx.cs里面获

  • Vuex数据的存储与获取方式

    目录 Vuex数据存储与获取 以下示例引用自官网(开始 | Vuex) 可以举一个实际应用的例子 Vuex存值与取值(简单易懂) Vuex数据存储与获取 因为最近需要对原有项目进行改造,之前没有认真研究过vuex的使用,今天把学习官方文档的过程记录下来以供日后查阅,同时也希望能够为其他开发人员提供参考. vuex的核心点是store,store本质上是一个仓库,它可以存储大部分的state.而这种存储是响应式的,如果state发生变化,那么对应的组件也会响应更新.如果想要改变state,那么需要

  • vue项目中form data形式传参方式

    目录 vue中form data形式传参 vue文件提交 FormData方式 前驱知识 FormDate FormData的使用 URL 实操 vue中form data形式传参 vue项目中form data形式传参,需要在headers中添加如下代码 headers: { 'Content-Type': 'application/x-www-form-urlencoded;charset=UTF-8' } 接口请求如下: export function subFaq (params) {

随机推荐