这是学习 Android 的第二个月,前一个月将 Mars 老师的视频看了一边,也将《第一行代码》开了一遍,并将书中的代码都敲了一遍,这个月从网上下载了黑马的 Android 项目教程:智慧北京,用来对 Android 基础知识进行巩固和练习。“智慧北京”算是一个新闻客户端,前前后后我大概写了两遍,第一遍是边看视频边写代码,第二遍没有看视频,是按照自己的回忆和理解来写的,刚开始,感觉很艰辛,视频一关,就忘记怎么写了,不过随着理解的加深、敲代码感觉的提高,后来渐渐的就不再需要忘记,就算忘记,也会根据自己的理解写出,这种感觉棒棒的。
作为一个新闻客户端项目,也是我第一个项目,我从中学到了很多,当然,就算是同一个项目,不同的人会看到、学到不同的东西,对我来说,“智慧北京”这个项目的最大作用,是培养了我的代码感觉,有了充分的练习,能够自己写出代码。这里记录下我学到的知识点:
这个只是针对我这个新手而言是一个知识点,明白了概念以及流程,我觉得闪屏页还有点用处,但是引导页就不明白有什么用了,在用其它 App 的时候我都是快速滑过,然后进入,基本没有看引导页具体有什么内容。
当然,这是我作为一个新手现在的想法,以后可能会有所改变吧。
闪屏的实现方式,我看到的有两种,一种是利用 Handler 发送一个空的延时消息,就可以在闪屏界面停留一定的时间。另一种是利用动画,动画播放的时间就是闪屏停留的时间。
这个知识点我觉得是我学到的最重要的知识点之一了,首先 ViewPager 是第一次用,ListView 之前在看《第一行代码》的时候,继承的是 ArrayAdapter 或者直接使用系统自带的适配器,只是一些基础使用,相对比较简单,这次提高了一点,继承的是 BaseAdapter,与使用 ViewPager 控件时继承的 PagerAdapter 的使用方式很相似,通用性很好;关键是在项目中用了很多次,现在都特别熟悉了,几个方法闭着眼睛都能写,呵呵…
之前学习基础的时候也用过,不过那属于练习,用过一次,只是保证以后看到了能够看懂,自己能不能写出来就不一定了。
“智慧北京”这个项目的主界面以及菜单界面都是使用的 Fragment,最开始,FrameLayout、Fragment 类、Fragment 布局文件、FragmentManager 几个概念把我搞蒙了,废了半天劲,才把它们理顺:
“智慧北京”项目中用到了三个 GitHub 上的开源项目,分别是:SlidingMenu、xUtils、ViewPagerIndicator。在引用几个开源项目库的时候,也遇到了一些问题(以后会提到),当时废了好大的劲才解决,现在看来,都是小问题啦,哈哈…
SlidingMenu 可以说是现在最流行的菜单样式框架,主要方式是从左边或右边滑出菜单项。简单使用如下(Activity 需要继承 SlidingFragmentActivity),详情参见后期文章。
//设置菜单页面
setBehindContentView(R.layout.left_menu);
//获取菜单对象
SlidingMenu slidingMenu = getSlidingMenu();
//设置滑出菜单的方式
slidingMenu.setTouchModeAbove(SlidingMenu.TOUCHMODE_FULLSCREEN);
//滑出菜单后能够看到的主界面的宽度
slidingMenu.setBehindOffset(700);
xUtils 翻译过来就是很牛X的工具,的确很牛瓣,“智慧北京”主要使用了其中的 HttpUtils、BitmapUtils 和注解,由于我是练习,就没有用有点偷懒的注解。简单使用如下。
HttpUtils:
HttpUtils utils = new HttpUtils();
//参数1:请求方式;参数2:请求Url;参数3:回调函数
utils.send(HttpRequest.HttpMethod.GET, GlobalConstants.CATEGORY_URL, new RequestCallBack<String>() {
@Override
public void onSuccess(ResponseInfo<String> responseInfo) {
String result = responseInfo.result;
processData(result);
}
@Override
public void onFailure(HttpException e, String s) {
Toast.makeText(mActivity,"网络访问错误",Toast.LENGTH_SHORT).show();
}
});
BitmapUtils:
BitmapUtils bitmapUtils;
bitmapUtils = new BitmapUtils(mActivity);
//设置加载图片时显示的图片
bitmapUtils.configDefaultLoadingImage(R.mipmap.topnews_item_default);
//加载图片。参数1:显示图片的控件;参数2:图片的Url
bitmapUtils.display(view,imageUrl);
基于用户体验考虑,ViewPager 的每次滑动,都有一个指示器来标识 ViewPager 滑动的位置,这个指示器就是 ViewPagerIndicator,具体实现一句两句说不清楚,为了篇幅,这里就不给出代码了,给几张效果图吧。
这里说的 UI 架构的策略不是想象中的那么高深的东西,而是面临设计好的 UI 图,整理实现方式方法的策略。在实现 UI 时,需要一层一层的去架构,先分析最外围的布局方式,采用什么控件,然后分析下一层的 UI 的布局方式…不一定一次就把所有 UI 都分析出来用什么布局、用什么控件实现,可以分析一层,实现一层,按需实现 UI。