zl程序教程

您现在的位置是:首页 >  移动开发

当前栏目

Android笔记之:App模块化及工程扩展的应用

AndroidApp扩展应用笔记 工程 模块化
2023-06-13 09:14:51 时间

1.需求
   无论是在.net还是java平台,合理的分层架构是最普遍的模块化思路之一。
   dll,jar文件无不风靡盛行,无处不在。
   一天,tx团队和我说,我们现在要做android上做三个论坛的客户端,一个是新闻论坛,一个是文学论坛,一个是音乐论坛。除了数据,界面和很少的模块不一样,其他的都一摸一样。
  jar是我第一刻就想到的东西,但是共用的jar文件无法方便的共享资源或者覆盖资源。
   而我们也不会傻傻的单独做三个客户端的吧,也不会傻傻的做3个客户端再傻傻的copy3份,依次修改吧。

2.问题
  在Android工程中如何开发一个共用Framework,能共用资源,代码,但是也能扩展? 

3.使用硬编码判断
  有人提出了一种方案,在代码里面判断:

复制代码代码如下:

if(新闻论坛){
  //加载新闻论坛的资源
  //执行新闻论坛的代码
  //显示新闻论坛的效果
}elseif(文学论坛){
  //加载文学论坛的资源
  //执行文学论坛的代码
  //显示文学论坛的效果
}elseif(音乐论坛){
  //加载音乐论坛的资源
  //执行音乐论坛的代码
  //显示音乐论坛的效果
}
PS:这是一种很无奈的办法,代码丑陋,扩展性差,有没有更好的办法呢?

4.使用AndroidLibrary分离工程
  AndroidLibrary提供了一个类似于其他平台的库的概念,这个库不仅能公用代码,还能共用资源,还能覆写资源。
  AndroidLibrary是以工程的颗粒来复用,引用它的工程,其实就是引用它的代码,然后生成R.java和主工程需要的资源,而剔除Library中被覆盖的资源。其中Library中的AndroidManifest.xml不能复用,也就是说主工程必须重新定义AndroidManifest.xml,这个也很容易理解,AndroidManifest.xml本来就是工程的一个配置文件,一般来说不具备共用的库的通用性。
  步骤如下:
  第一步:新建Android工程common。
  第二步:右键common,选择Properties,在Android标签页,选中"IsLibrary",如下图。
 
  第三步:新建主工程新闻论坛tianxianews。
  第四步: 右键tianxianews,选择Properties,在Android标签页,点击Add,选中common。如下图。
  查看最后的工程结构:
  此时此刻,common工程天衣无缝成了tianxianews工程的一部分。
  我们展开tianxianews工程的gen目录:
   
  eclipse为了生成了两个R.java,一个是common工程的,一个tianxianews工程的,但是内容是一摸一样的,这样做的好处是:R.java里面的内容包括两个工程资源,第一,tianxianews工程通过R.java能调用到common工程的资源;第二,如果有覆写的资源,生成apk的时候,tianxianews工程覆盖common工程的资源,因为两个R.java内容一样,common代码调用的R.java中的资源,实际上调用的是tianxianews资源,这个特性类似如面向对象的继承的概念。
  我们还可以另外新建tianxiamusic,tianxialiterature工程,都引用common,这样我们三个工程就能共用common,这样我们就可以只在common一个工程中开发了。
  在这里,具体的使用步骤我没有截图出来,主要是没什么技术,也没什么好说的,就是两个字:覆盖。 

5.小结
  AndroidLibrary为Android模块化和工程扩展提供了一个很好的工具或者方式。随着项目的增大,资源的共享,模块化和扩展的这种需求更是日益凸显,它不仅去掉了代码的丑陋,而且减少了开发量,带来的益处不少。同时由此我们也可以看出来Android的不成熟,他们为我们大型工程提供的方案还是太少,这可能也有源自手机平台本身的局限性吧,我们期待Android市场走向更强大,技术走向更强悍。