前言

android API Demo程序主要演示了Android常见API的使用方法, 本文将该程序的框架提取出来, 以作为自己研究和学习Android编程的一个示例收集框架,即将所有自己研究过的例子按照分类收集起来, 方便日后查找。

正文

下面只贴出框架相关的文件内容, 最后说明如果将自己的例子加入到框架中。

框架的工程的源码目录结构如下:

核心包

com.fyj.demo包含三个文件, Globals.java MyAppDemoActivity.java MyAppDemoApplication.java, 文件的内容如下:

Globals.java

package com.fyj.demo;public class Globals {public static final String CATEGORY_MYAPP_DEMO = "android.intent.category.MYAPP_DEMO";
}

该文件主要定义一些全局变量,如上所示,我们定义了自己的CATEGORY。

MyAppDemoApplication.java

package com.fyj.demo;import android.app.Application;
import android.util.Log;public class MyAppDemoApplication extends Application {private static final String TAG = "MyAppDemoApplication";@Overridepublic void onCreate() {Log.i(TAG, "My App Demo is running...");}
}

此类可加入一些全局初始化的代码。

MyAppDemoActivity.java

package com.fyj.demo;import java.text.Collator;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.HashMap;
import java.util.List;
import java.util.Map;import android.app.ListActivity;
import android.content.Intent;
import android.content.pm.PackageManager;
import android.content.pm.ResolveInfo;
import android.os.Bundle;
import android.view.View;
import android.widget.ListView;
import android.widget.SimpleAdapter;public class MyAppDemoActivity extends ListActivity {@Overridepublic void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);Intent intent = getIntent();String path = intent.getStringExtra("com.fyj.demo.Path");if (path == null) {path = "";}setListAdapter(new SimpleAdapter(this, getData(path),android.R.layout.simple_list_item_1, new String[] { "title" },new int[] { android.R.id.text1 }));getListView().setTextFilterEnabled(true);}protected List<Map<String, Object>> getData(String prefix) {List<Map<String, Object>> myData = new ArrayList<Map<String, Object>>();Intent mainIntent = new Intent(Intent.ACTION_MAIN, null);mainIntent.addCategory(Globals.CATEGORY_MYAPP_DEMO);PackageManager pm = getPackageManager();List<ResolveInfo> list = pm.queryIntentActivities(mainIntent, 0);if (null == list)return myData;String[] prefixPath;String prefixWithSlash = prefix;if (prefix.equals("")) {prefixPath = null;} else {prefixPath = prefix.split("/");prefixWithSlash = prefix + "/";}int len = list.size();Map<String, Boolean> entries = new HashMap<String, Boolean>();for (int i = 0; i < len; i++) {ResolveInfo info = list.get(i);CharSequence labelSeq = info.loadLabel(pm);String label = labelSeq != null ? labelSeq.toString(): info.activityInfo.name;if (prefixWithSlash.length() == 0|| label.startsWith(prefixWithSlash)) {String[] labelPath = label.split("/");String nextLabel = prefixPath == null ? labelPath[0]: labelPath[prefixPath.length];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;}private final static Comparator<Map<String, Object>> sDisplayNameComparator = new Comparator<Map<String, Object>>() {private final Collator collator = Collator.getInstance();public int compare(Map<String, Object> map1, Map<String, Object> map2) {return collator.compare(map1.get("title"), map2.get("title"));}};protected Intent activityIntent(String pkg, String componentName) {Intent result = new Intent();result.setClassName(pkg, componentName);return result;}protected Intent browseIntent(String path) {Intent result = new Intent();result.setClass(this, MyAppDemoActivity.class);result.putExtra("com.fyj.demo.Path", path);return result;}protected void addItem(List<Map<String, Object>> 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@SuppressWarnings("unchecked")protected void onListItemClick(ListView l, View v, int position, long id) {Map<String, Object> map = (Map<String, Object>) l.getItemAtPosition(position);Intent intent = (Intent) map.get("intent");startActivity(intent);}
}

该类是框架的主活动类,通过它来启动我们之后添加到框架中的一些示例。

扩展包

除核心包之后的代码都是按照示例的分类放置在不同的扩展包中,作为例子,本文创建了一个扩展包为com.fyj.demo.app

在此包中,我们创建了一个例子,名为HelloWorld.java, 它的内容如下:

package com.fyj.demo.app;import android.app.Activity;
import android.os.Bundle;import com.fyj.demo.R;public class HelloWorld extends Activity {@Overrideprotected void onCreate(Bundle savedInstanceState) {// TODO Auto-generated method stubsuper.onCreate(savedInstanceState);setContentView(R.layout.hello);}
}

下面进入res目录下,这里我们主要关注的是layout, values子目录,其中layout是一些布局文件,values目录下的strings.xml定义了示例应用程序中的一些字符串, 这里我们主要看下strings.xml文件的内容:

<?xml version="1.0" encoding="utf-8"?>
<resources><string name="hello">Hello World, MyAppDemoActivity!</string><string name="app_name">MyAppDemo</string>    <string name="activity_hello_world">App/Activity/<b>Hello <i>World</i></b></string></resources>

其中,在定义示例程序的标题字符串的时候,要按照上述的格式定义, 上述名称代表HelloWorld示例程序被归在App分类下的Activity子分类中,多少个'/'代表有多少个分类层次。

最后,我们看下AndroidManifest.xml文件的内容:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"package="com.fyj.demo"android:versionCode="1"android:versionName="1.0" ><uses-sdk android:minSdkVersion="15" /><applicationandroid:name="MyAppDemoApplication"android:icon="@drawable/ic_launcher"android:label="@string/app_name" ><activityandroid:name=".MyAppDemoActivity"android:label="@string/app_name" ><intent-filter><action android:name="android.intent.action.MAIN" /><category android:name="android.intent.category.DEFAULT" /><category android:name="android.intent.category.LAUNCHER" /></intent-filter></activity><!-- Activity Samples --><activityandroid:name=".app.HelloWorld"android:label="@string/activity_hello_world" ><intent-filter><action android:name="android.intent.action.MAIN" /><category android:name="android.intent.category.MYAPP_DEMO" /></intent-filter></activity></application></manifest>

注意,在示例的Activity中, category都要设置为android.intent.category.MYAPP_DEMO。

转载于:https://my.oschina.net/fuyajun1983cn/blog/263880

Android API Demo程序框架相关推荐

  1. 匆匆忙忙赶出的Arcgis Android api demo,拿出来献丑啦

    转载于:https://my.oschina.net/LinBandit/blog/69147

  2. android应用程序框架图,Android系统框架图详解

    Android系统从下至上分为4层:Linux内核.Android程序库及Android运行时.Android应用程序框架,以及应用程序等. 图1-1 Android系统框架 1. Linux内核(L ...

  3. Android 2018优秀开源框架整理收藏

    中级.高级.资深工程师 知其然知其不可然 <框架百大排行榜>里所提到的流行词.流行术语--使用能力.融会贯通其原理.讲解框架能力的高低,将让你不断的在这三个级别徘徊: 会有意识的合并榜单里 ...

  4. android 优秀的开源框架整理

    程序员界有个神奇的网站,那就是github,这个网站集合了一大批优秀的开源框架,极大地节省了开发者开发的时间,在这里我进行了一下整理,这样可以使我们在使用到时快速的查找到,希望对大家有所帮助! 1. ...

  5. Android开发最新所有框架总结

    1. Retrofit 一句话介绍:Retrofit是一款类型安全的网络框架,基于HTTP协议,服务于Android和java语言 上榜理由:Retrofit以21.8k的stars量雄踞github ...

  6. android api 相机,具有相机2 API的Android Lollipop上的ZSL功能

    我试图从相机应用程序,相机框架和libcameraservice实施以及相机HAL v3.2规范中了解Android 5.0对ZSL功能的支持. 据我了解,在Android中实现ZSL的方式有两种: ...

  7. binder 从c到java_Android系统进程间通信Binder机制在应用程序框架层的Java接口源代码分析...

    在前面几篇文章中,我们详细介绍了Android系统进程间通信机制Binder的原理,并且深入分析了系统提供的Binder运行库和驱动程序的源代码.细心的读者会发现,这几篇文章分析的Binder接口都是 ...

  8. Android应用开发五大框架,android 五大应用开发框架是什么

    android应用开发框架是 Application Framework. 其系统架构由5部分组成,分别是:Linux Kernel.Android Runtime.Libraries.Applica ...

  9. Android应用程序框架

    应用程序框架可以说是一个应用程序的核心,是所有参与开发的程序员共同使用和遵守的约定,大家在其约定上进行必要的扩展,但程序始终保持主体结构的一致性.其作用是让程序保持清晰和一目了然,在满足不同需求的同时 ...

最新文章

  1. android系统用在什么电脑,手机变电脑的简单操作 适用于所有Android系统的向日葵...
  2. 基于时间片的轮转调度算法
  3. 【 || 短路运算】if语句的简化:短路原理、短路效应
  4. vue.js框架:数组的各种变异方法
  5. Pandas中的元素替换
  6. Office 365系列之八:配置和体验Exchange和Lync
  7. 逐步创建ASP.NET Core 2.2应用程序
  8. python 排列组合_Python计算生态jieba库和random库的综合运用之爬山篇
  9. Ubuntu18.04安装福昕阅读器
  10. 如果Google统治世界[组图]
  11. Selenium爬虫 -- 用户动态数据爬取
  12. mkvtoolnix视频转换 v51.0.0中文版
  13. 如何优化内存?Unity中的内存种类;冯乐乐的总结的优化技术
  14. 千兆以太网芯片88E1111 RGMII模式的驱动
  15. 外国内乱时,撤侨不一定是最佳策略
  16. 思科模拟器 --- 扩展IP访问控制列表配置
  17. 什么是序列化 怎么序列化 为什么序列化
  18. 0基础2(在1基础之上)
  19. 【java】英语单词对战小游戏
  20. Java SE(7)

热门文章

  1. selenium - webdriver常用方法
  2. 前端学HTTP之网关、隧道和中继
  3. 【DFS/BFS】NYOJ-58-最少步数(迷宫最短路径问题)
  4. 每次输出日志前需要判断日志的级别吗?
  5. docker centos7容器 安装ssh服务
  6. 渗透测试中的文件传输技巧
  7. docker-compose.yml 配置文件编写
  8. linux ssh 隧道 tunnel 一般场景用法
  9. Nosql简介 Redis,Memchche,MongoDb的区别
  10. smarty foreach函数