Andriod游戏开发 第九章 游戏程序的生命周期.docxVIP

Andriod游戏开发 第九章 游戏程序的生命周期.docx

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
从零开始Android游戏编程(第二版) 第九章 游戏程序的生命周期 \o 收藏到我的网摘中,并分享给我的朋友 收藏 第九章 游戏程序的生命周期 在讲解游戏程序的生命周期之前,让我们先看看普通Android使用的生命周期。关于生命周期,SDK附带的文档上有详细的解释,让我们打开文档,找到andorid.app-Activity,我们会看到这样一张图片 图片将整个程序的生命周期描述的非常清楚,为了加深理解,我们创建一个程序实际看一下这个过程。 创建项目LifeCycle,sdk就选择1.6吧。在Activity中重载如下几个函数,并增加Log语句: @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); LogF(); } @Override protected void onDestroy() { // TODO Auto-generated method stub super.onDestroy(); LogF(); } @Override protected void onPause() { // TODO Auto-generated method stub super.onPause(); LogF(); } @Override protected void onRestart() { // TODO Auto-generated method stub super.onRestart(); LogF(); } @Override protected void onResume() { // TODO Auto-generated method stub super.onResume(); LogF(); } @Override protected void onStart() { // TODO Auto-generated method stub super.onStart(); LogF(); } @Override protected void onStop() { // TODO Auto-generated method stub super.onStop(); LogF(); } LogF()定义如下: public static void LogF() { Log.v(Thread.currentThread().getStackTrace()[3].getClassName(), Thread.currentThread().getStackTrace()[3].getMethodName()); } 除了onCreate之外,都需要手工添加,重载函数的方法前面有哦,一年过去了,大家没忘吧:) 让我们在模拟器中运行这个程序。同时在LogCat中查看输出。前面好像没有讲到LogCat,但是很多代码用到了Log,大家都已经找到了吧。 程序启动后,我们看到了3条自定义的Log信息: 让我们按下返回键结束程序, 这就是一个程序从创建到销毁的标准流程。但是作为手机使用,我们前面提到的被抢占屏幕的情况就必须要被考虑。让我们来测试一下: 重新运行LifeCycle,在DDMS中模拟一个电话呼入 日志中出现了 这次没有调用onDestory。 然后让我们把电话挂掉 同样,没有调用onCreate而调用了onRestart。 另外还有一种情况,就是当程序被放置到后台过久,系统在一定条件下会自动将程序销毁,让我们看一下这种情况下程序的生命周期会有什么变化。 运行LifeCycle,转到DDMS,模拟一个来电,然后在Devices找到LifeCycle并强行停止他 我们会发现日志中并没有任何输出。 这时,让我们挂掉电话,日志中出现了如下三行 可以看到,程序被重新创建了,调用了onCreate而不是onRestart,这和我们前面说的流程相悖,因为在这种情况下,我们应该继续程序的执行而不是重新初始化。那么如何解决这个问题呢? 方法如下,让我们重载下面这个函数: @Override protected void onSaveInstanceState(Bundle outState) { // TODO Auto-generated method stub super.onSaveInstanceState(outState); Log.v(this.toString(), Thread.currentThread().getStackTrace()[2].getMethodName()); } 重新拨入电话,日志中出现了如下

文档评论(0)

137****4840 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档