Android小项目之十一 应用程序的主界面


------- 源自梦想永远是你IT事业的好友、只是勇敢地说出我学到! ----------

按惯例,写在前面的:可能在学习Android的过程中,大家会和我一样,学习过大量的基础知识,很多的知识点也都能说出了123来,但是这些孤立的点终究显得太零散了,因此,我想从今天开始,以最经典的手机安全卫士项目为例,自己锻炼一下,也是想和大家交流交流,希望大家都能给出见解,共同进步。


十一、应用程序的主界面

之前的完成以后,用户每次打开都会有更新提醒,这样对于用户来说是很烦的。用户体验就不是特别好了。
因此我们需要这样一个选项,在用户选择关闭更新提醒的时候,就不会显示提醒,直接进入主界面。

设置中心》设置。。。

下面先做下主界面(LinearLayout):
1.标题:
具体代码:
			    <TextView
					style="@style/text_title_style"
					android:text="手机卫士" />

这里我们把TextView的样式抽取到样式文件中,
具体代码:
			    <style name="text_title_style">
					<item name="android:layout_width">fill_parent</item>
					<item name="android:layout_height">50dp</item>
					<item name="android:gravity">center</item>
					<item name="android:background">#8066ff00</item>
					<item name="android:textColor">#000000</item>
					<item name="android:textSize">20sp</item>
				</style>


之后再用到这个TextView的时候就直接使用style="@style/text_title_style"即可。
同样我们自己可以做一些常用的style.

2.下面我们做一个滚动的TextView
具体代码:
			    <TextView 
					style="@style/fill_wrap_style"
					android:singleLine="true"
					android:ellipsize="marquee"
					android:text="我是您的手机小卫士,专门保护您的手机,快些使用下面的功能吧,随时随地为您服务!"/>


3.下面就是各个功能模块,使用GridView。
指定列数为3.
		    <GridView 
				style="@style/fill_style"
				android:id="@+id/gv_home"
				android:numColumns="3"
				></GridView>


指定各模块的图片和名称:
			private static final String[] names = {"手机防盗","通讯卫士","软件管理","进程管理"
									,"流量统计","手机杀毒","系统优化","高级工具","设置中心"};
			private static final int[] icons = {R.drawable.safe,R.drawable.callmsgsafe,R.drawable.app,R.drawable.taskmanager
								,R.drawable.netmanager,R.drawable.trojan,R.drawable.sysoptimize,R.drawable.atools,R.drawable.settings};

定义一个适配器HomeAdapter,继承BaseAdapter。复写getView方法。
在这之前我们先写一个list_home_item.xml文件,里面是一个ImageView和一个TextView。
具体代码:
				    <ImageView 
						android:id="@+id/iv_home_icon"
						android:layout_width="50dip"
						android:layout_height="50dip"
						android:src="@drawable/app"
						/>
					
					<TextView 
						android:id="@+id/tv_home_name"
						style="@style/wrap_style"
						android:text="手机防盗"
						android:textColor="#000000"
						android:textStyle="bold"
						/>

上面的src和text仅为演示用。演示后应删除掉。
HomeAdapter的getView方法具体代码:
					@Override
					public View getView(int position, View convertView, ViewGroup parent) {
						//把布局文件转化成View对象
						View view = View.inflate(getApplicationContext(), R.layout.list_home_item, null);
						ImageView iv_home_icon = (ImageView) view.findViewById(R.id.iv_home_icon);
						iv_home_icon.setImageResource(icons[position]);
						TextView tv_home_name = (TextView) view.findViewById(R.id.tv_home_name);
						tv_home_name.setText(names[position]);
						return view;
					}

还要记得写getCount()方法,不然显示为0个功能模块:
				public int getCount() {
					return names.length;
				}

小问题:
1几个模块靠的太近,要显示有一些距离:
在<GridView下设置网格垂直方向间距:android:verticalSpacing="10dp"

2设置界面没有标题栏。

3滚动文本没有自动滚动。
若想要其滚动,应该设置focusabelInTouchMode为True.
需要新建类,重写TextView方法。
具体代码:
						public class FocusTextView extends TextView {
							public FocusTextView(Context context, AttributeSet attrs, int defStyle) {
								super(context, attrs, defStyle);
							}


							public FocusTextView(Context context, AttributeSet attrs) {
								super(context, attrs);
							}


							public FocusTextView(Context context) {
								super(context);
							}
							@Override
							@ExportedProperty(category = "focus")
							public boolean isFocused() {
								return true;
							}
						}


再将滚动文本的标签改为com.dongdong.phonesafe.ui.FocusTextView即可。

------- 源自梦想永远是你IT事业的好友、只是勇敢地说出我学到! ----------


posted @ 2013-09-18 17:42  马走日  阅读(377)  评论(0编辑  收藏  举报