- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Android用户界面设计
Android用户界面设计:使用片段
Android 3.0引入的新的片断 (Fragment )API,让我们更容易地创建动态用户界面。在这个教程中,我们学习如
何将一个两屏的ListView转换成WebView流,以适应大屏幕的单屏流设计,比如在平板设备中。
这篇文章的节奏将比我们的入门教程更快一些。如果你对基本的Android控件或概念不熟悉你可能需要复习这个
网站上我们其它的一些教程,甚至是Android API参考。最终的开源代码可以在Google code上下载到。
片段简介
在我们开始之间,让我们在更高的层次上定义一下什么是片段。通常来说,片段是一大块用户界面,它具有自己
的生存周期。如果它听起来像一个Activity ,那是因为它确实很像一个Activity 。然而,片段与Activity不同,片段必
须存在于Activity之内。片段不须要在它每次初始化的时候与同一个Activity配对,这使它具有一些灵活性。与
Activity一样,片段也无需包含任何用户界面。
步骤0 :开始
这个教程假设你读过我们的列表视图教程,你可以下载那个教程的代码,并完成一些任务,然后开始,也可以直
接下载这个教程的代码直接开始。
步骤1:重新设计界面
下图示意了我上在列表视图教程中所提到的文章阅读应用,我们还没有考虑并使用片段:
这个流程在相对小屏幕上运行得很不错。然而,在大屏幕上,比如Motorola Xoom平板的10寸屏幕上,在列表视
图上却浪费了很多空间。WebView看起来正常,但是有点枯燥。
这就是要引入片段的地方:在大屏幕上,我们可以提供更有效的用户界面,如果我们可以在同一屏上显示
ListView和WebView。当用户点击左边“面板” 的列表视图中的某一项时,右边的WebView更新显示相应的内容。
这种工作流程经常用于email或文档或RSS阅读器。下图就是重新设计之后的界面示意图:
步骤2 :转换为基于片段的设计
现在我们知道了新的流程应该如何设计,我们也知道当前的两个活动必须转换成片段。我们将分几步来完成这个
转换。第一步保持界面样子不变,只是使用片段修改每个界面内容。一个片段将包含当前的ListView,另一个包
含WebView。然后我们再转到单个屏幕的实现,修改ListView和WebView之间的消息传递。
首先,将你的程序的项目构建目标改变Android 3.0 。在Eclipse 中,右键点击项目并选择“属性” 。点击Android部
分并选中Android 3.0 。我们不使用任何Google API,所以Android开源项目版本足够了。然后点击“确定”按钮。
现在你就可以访问新的API了,包括片段API。
注意:在将来的教程中,我们将讨论如何使用新的兼容层来使得像片段API这样的技术在更早版本的Android设备
上也能工作。但是现在它只能运行在Android 3.0设备上。
步骤3 :创建片段类
创建两个Java类来代表两个片段:ListView界面和WebView界面。将它们命名为TutListFragment和
TutViewerFragment 。TutListFragment将继承ListFragment类,TutViewerFragment只是继承Fragment类。
在TutListFragment类中,我们需要重写两个方法: onListItemClick()和onCreate() 。这些方法的内容看起来应该
很熟悉,它与之前我们讲过的TutListActivity类的代码一致。这个代码很快就要修改,但是现在暂时不需要,下面
是当前TutListFragment类的代码:
@Override
public void onListItemClick(ListView l, View v, int position, long id) {
String[] links getResources().getStringArray(R.array.tut_ links);
String content links[position];
Intent showContent new Intent(getActivity().getApplicationContext(),
TutViewerActivity.class);
showContent.setData(Uri.parse(content));
startActivity
您可能关注的文档
- 2014秋 材料力学 第10章 动应力与交变应力 1.pdf
- 2014优化探究高三地理一轮复习第四编 第二章 章末大结局.ppt
- 2015安徽公务员考试行测考点大全:数量关系-工程问题.doc
- 2015版高考生物大二轮专题突破练习 专题三 第2讲.doc
- 2015高考地理 第五章 第一讲 人口增长模式及地区分布 环境承载力与人口合理容量课件.ppt
- 2015届高考生物一轮复习检测 细胞生命历程单元检测.doc
- 2015年1月会考选择题练习一 二.doc
- 2015年北京师范大学法学理论考研真题,复试流程,考研心态,考研经验.pdf
- 2015年北京师范大学法学综合考研真题,复试流程,考研心态,考研经验.pdf
- 2015年护士资格考试110个总结上(医师从业指南).doc
文档评论(0)