Android ApiDemos示例解析(2): SimpleAdapter,ListActivity,PackageManager

创建好ApiDemo项目后,就可以逐个示例的来分析代码,这里假定读者已对Android开发有些了解或是读过Android简明开发教程

首先是看ApiDemo的主Activity: com.example.android.apis.ApiDemos ,这个主Activity为ListActivity的子类,主要用来列出ApiDemos中的200多个实例,实例采取分类层次显示。

在ApiDemos 的 onCreate()中代码:

setListAdapter(new SimpleAdapter(this, getData(path),
 android.R.layout.simple_list_item_1, new String[] { "title" },
 new int[] { android.R.id.text1 }));


 

SimpleAdatper 作为数据源 getData(path) 与 UI ListActivity 之间的桥梁,它的构造函数如下:

SimpleAdapter(Context context, List<? extends Map<String, ?>> data, int resource, String[] from, int[] to)

我们知道ListActivity可以用来显示一个列表,在使用SimpleAdapter时可以借用二维表来更好的理解。 SimpleAdapter的数据源data 类型为List<? extends Map<String, ?>> List 中每一项为一个Map对象,相当于二维表中一行,这一行可以有多列,每列可以有个名字,为Map<String,?> string ,相当于表的列名:


ApiDemos中每条记录只显示一列”title”。 android.R.layout.simple_list_item_1 为用来显示每条记录的Layout资源id, ListActivity允许使用自定义Layout ,这里使用了Android系统资源,simple_list_item_1由一个TextView构成,其id为text1.

new String[] { “title” } 为需要显示的列表的数组,ApiDemos只显示一列“title”,如果有多列:则可以为new String[] { “title”,”field1”,”field2”,”field3” }。

new int[] { android.R.id.text1 }则指定使用 android.R.layout.simple_list_item_1 中 id 为text1的 TextView 来显示 “title” 列。 如果有多列,Layout可以定义多个View (不一定都为TextView) ,然后为每列指定显示的View的id。

再来看看getData(path)是如何定义的,protected List getData(String prefix) 返回一个列表

protected List getData(String prefix) {
List<Map> myData = new ArrayList<Map>();
 
Intent mainIntent = new Intent(Intent.ACTION_MAIN, null);
mainIntent.addCategory(Intent.CATEGORY_SAMPLE_CODE);
 
PackageManager pm = getPackageManager();
List<ResolveInfo> list = pm.queryIntentActivities(mainIntent, 0);
 
... ...
for (int i = 0; i < len; i++) {
...
if ((prefixPath != null ? prefixPath.length : 0) == labelPath.length - 1) {
addItem(myData, nextLabel, activityIntent(
info.activityInfo.applicationInfo.packageName,
info.activityInfo.name));
} else {
if (entries.get(nextLabel) == null) {
addItem(myData, nextLabel,
browseIntent(prefix.equals("") ? nextLabel : prefix + "/" + nextLabel));
entries.put(nextLabel, true);
}
}
}
}
 
Collections.sort(myData, sDisplayNameComparator);
 
return myData;
}

它通过PackageManager 从 AndroidManifest.xml中读取所以Intent-Filter含有:Intent.ACTION_MAIN和Intent.CATEGORY_SAMPLE_CODE所有Activity信息。前面说过200多个示例根据其功能分类,比如 Hello World示例它的Label为

App/Activity/<b>Hello <i>World</i></b>,

表是它的分类为分类App下Activity子类。getData(String prefix)根据每个Activity的Label属性和当前层次(prefix)来决定当前列表中某项为叶子列表项,还是分类列表项,如果是叶子列表项,则添加为activityIntent,当用户点击改列表项时则会触发该示例。若是分类列表项,则添加为browseIntent,browseIntent还是触发ApiDemos Activity,但Intent带有Extra信息,表示需要显示改分类下的子类:

Intent result = new Intent();
result.setClass(this, ApiDemos.class);
result.putExtra("com.example.android.apis.Path", path);

此时如果用户点击改节点列表项,则会进入还分类下级目录。


protected void addItem(List<Map> data, String name, Intent intent) {
Map<String, Object> temp = new HashMap<String, Object>();
temp.put("title", name);
temp.put("intent", intent);
data.add(temp);
}
 
@Override
protected void onListItemClick(ListView l, View v, int position, long id) {
Map map = (Map) l.getItemAtPosition(position);
 
Intent intent = (Intent) map.get("intent");
startActivity(intent);
}


 


addItem 给返回的List中添加一项,每个记录含两列 :”title”,”intent” ,其中只显示”title”列,如果想要显示”intent”列的信息,就不能使用android.R.layout.simple_list_item_1 了,这时可以另外定义一个Layout 来显示多列数据。 intent可以为触发示例,如”Hello World”或是下级示例列表,此时触发的Activity还是ApiDemos。
此外,ApiDemo还定义了ApiDemosApplication做为Application的子类,如果需要在多个Activity共享一些数据,可以定义在Application中。如果使用了自定义的Application,别忘了修改AndroidManifest.xml ,如下:

<application android:name=”ApiDemosApplication”
android:label=”@string/activity_sample_code”
android:icon=”@drawable/app_sample_code” >

</application> 

 

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
### 回答1: illd_tc2xx_demos是基于英飞凌公司开发的工具集成体ILLD (Infineon Low Level Driver)的一种示例代码集合,可在英飞凌的32位TriCore™芯片上运行。这些示例代码主要包括了常见的应用,如CAN通信、PWM输出、ADC采集等。使用者可以通过对这些示例代码的学习和修改,快速了解TriCore™芯片的使用方法,加深对ILLD工具集成体的理解。 ILLD是英飞凌公司独立开发的底层驱动,提供了硬件驱动抽象层、操作系统接口层等多种API供上层应用调用,大大简化了应用编程者的工作量。ILLD与TriCore™芯片充分结合,提供高效、稳定的底层驱动服务,为用户的应用提供稳定的运行环境。 TriCore™芯片是英飞凌公司专为汽车电子领域开发的一种32位微处理器。其高性能、低功耗、可靠性强等优点,使其在汽车电子控制器领域得到广泛的应用。ILLD_tc2xx_demos中提供的示例代码,涉及了TriCore™芯片的多个模块以及ILLD工具集成体的多个功能,可以有效的帮助用户快速上手TriCore™芯片和ILLD的使用。 总之,ILLD_tc2xx_demos是一种实用的示例代码集合,对于TriCore™芯片和ILLD工具集成体的使用有很好的帮助作用。通过学习和运用这些示例代码,用户可以提高开发效率,快速完成应用程序的开发,为汽车电子等领域的控制器开发提供支持。 ### 回答2: illd_tc2xx_demos是一组用于TriCore® 2xx系列微控制器的演示程序。这些演示程序涵盖了许多TC2xx器件的不同方面,包括CAN和LIN通信,ADC和PWM驱动,以及多种不同的外设和传感器的集成。这些演示程序可用于展示TriCore® 2xx系列微控制器的许多功能和性能,并可用于帮助开发者调试和优化TC2xx应用程序。 illd_tc2xx_demos是作为Infineon公司的TriCore® 2xx系列微控制器的集成开发环境(IDE)和软件包的一部分提供的。这些IDE和软件包为开发者提供了一个全面的工具链,可用于设计,开发和优化TC2xx应用程序。除了illd_tc2xx_demos之外,这些IDE和软件包还包括用于代码生成,仿真和调试的工具,以及针对特定应用的软件库和示例代码。 整个软件包旨在使开发者能够快速轻松地利用TriCore® 2xx系列微控制器的功能和性能。通过使用illd_tc2xx_demos,开发者可以学习如何利用TC2xx的不同特性来满足他们的应用需求,并避免需要从头开始编写代码来实现这些功能。因此,illd_tc2xx_demos是TC2xx应用程序设计和开发的重要资源。 ### 回答3: illd_tc2xx_demos是一系列使用INFINEON的TC2xx芯片开发的示例程序集合。TC2xx芯片是基于AURIX架构的高性能汽车控制芯片,拥有强大的计算性能和丰富的外设接口。 illd_tc2xx_demos提供了多个示例程序,包含了各种常见的汽车控制应用场景。其中包括CAN总线通信、外设控制、数据转换、自动驾驶、安全行车等多个应用领域。 这些示例程序往往是基于具体的硬件平台和软件库开发的,并且经过了充分的测试和验证。因此,使用这些示例程序可以帮助开发者快速了解和掌握汽车控制领域的相关技术和应用,并且可以在实际项目开发中奠定良好的基础。 值得一提的是,illd_tc2xx_demos不仅仅是给初学者使用的,对于有一定经验的开发者来说,通过阅读和修改这些示例程序,还可以深入理解汽车控制技术的工作原理和实现方式,并且可以快速开发自己的实际项目。 综上所述,illd_tc2xx_demos是一款非常有用的示例程序集合,对于研究和开发汽车控制领域的技术人员来说,具有非常重要的意义。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

引路蜂

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值