由于前两天忙于学校的实习,就断了两三天没有学习android,今天实习结束,又可以继续了。
下面我将给出进入主页面的entryHome函数的实现以及使用gridView布局功能界面
entryHome函数实现
/** * 进入主页面 */ private void enterHome() { Intent intent = new Intent(this, HomeActivity.class); this.startActivity(intent); /*关闭当前页面*/ finish(); }
主界面预览图
这里先给出主界面功能图标的实现过程,展示最新信息的跑马灯我将独立出一篇单独给出(使用自定义),希望对跟我一样刚入门android的同学有所帮助
提前给出一些GridView 的属性功能介绍
属性名称
描述
android:columnWidth
设置列的宽度。
android:gravity
设置此组件中的内容在组件中的位置。可选的值有:top、bottom、left、right、center_vertical、fill_vertical、center_horizontal、fill_horizontal、center、fill、clip_vertical可以多选,用“|”分开。
android:horizontalSpacing
两列之间的间距。
android:numColumns
设置列数。
android:stretchMode
缩放模式。
android:verticalSpacing
两行之间的间距。
功能界面布局文件
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" android:theme="@style/AppTheme.NoActionBar"> <TextView android:id="@+id/textView1" android:layout_width="fill_parent" android:layout_height="55dip" android:background="@android:color/holo_green_dark" android:gravity="center" android:text="功能列表" android:textColor="@android:color/black" android:textSize="22sp" />
//此处为实现跑马灯效果的消息展示,后面将独立讲解 <com.zaizai.safty.ui.FocusedTextView android:layout_width="match_parent" android:layout_height="wrap_content" android:ellipsize="marquee" android:focusableInTouchMode="true" android:singleLine="true" android:text="最新的仔仔手机安全卫士,快来下载啊,下载送好吃的。最新的仔仔手机安全卫士,快来下载啊,下载送好吃的。最新的仔仔手机安全卫士,快来下载啊,下载送好吃的。" android:textSize="18sp" />//GridView展示的单个Itme将使用自定义的样式进行展示 <GridView android:id="@+id/gv_list_home" android:layout_width="wrap_content" android:layout_height="wrap_content" android:numColumns="3" android:verticalSpacing="10dip" /> </LinearLayout>//GridView 中的Itme样式布局文件如下<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" android:gravity="center"> mipmap-hdpi/app.png <ImageView android:id="@+id/iv_item" android:layout_width="60dip" android:layout_height="60dip" android:src="@drawable/app" /> <TextView android:id="@+id/tv_item" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="手机防盗" android:textSize="16sp" /> </LinearLayout>即上面用一个ImageView展示功能的图标,这里的src只是为了阅览调试布局配置,实际运行将动态加载,下面为一个TextView展示功能名称下面我将贴出整个功能界面的Activity然后在代码中使用注释进行分步讲解package com.zaizai.safty; import android.app.Activity; import android.content.Intent; import android.os.Bundle; import android.view.View; import android.view.ViewGroup; import android.widget.AdapterView; import android.widget.BaseAdapter; import android.widget.GridView; import android.widget.ImageView; import android.widget.TextView; /** * Created by zaizai on 2015/10/12. */ public class HomeActivity extends Activity { private GridView gv_list_home; private MyAdapter myAdapter;//分别定义出9个功能的名称 private static String[] names = { "手机防盗", "通讯卫士", "软件管理", "进程管理", "流量统计", "手机杀毒", "缓存清理", "高级工具", "设置中心" };//由于我使用的是android studio 所以我将9个功能的图标的图片文件放入mipmap-mdp中//仍然时定义一个数组,数组存储的是图片的引用整型变量,整型变量所引用的值才是图片的路径 private static int[] ids = {R.mipmap.safe, R.mipmap.callmsgsafe, R.mipmap.app, R.mipmap.taskmanager , R.mipmap.netmanager, R.mipmap.trojan, R.mipmap.sysoptimize, R.mipmap.atools, R.mipmap.settings }; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState);//加载布局文件 this.setContentView(R.layout.activity_home);//得到GirdView gv_list_home = (GridView) this.findViewById(R.id.gv_list_home);//创建一个数据适配器,在后面定义 myAdapter = new MyAdapter();//给GirdView 设置数据适配器 gv_list_home.setAdapter(myAdapter); /*设置主页面功能图标的的点击事件*/ gv_list_home.setOnItemClickListener(new AdapterView.OnItemClickListener() { @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { switch (position) { //根据position即可知道点击了第几个功能图标 } } }); } private class MyAdapter extends BaseAdapter { @Override public int getCount() { return names.length; } @Override public View getView(int position, View convertView, ViewGroup parent) {//将GridView 的Itme项的布局文件加载到功能页面视图中 View view = View.inflate(HomeActivity.this, R.layout.list_item_home, null);//得到显示功能图标的imageView ImageView iv_item = (ImageView) view.findViewById(R.id.iv_item);//得到显示功能名称的TextView TextView tv_item = (TextView) view.findViewById(R.id.tv_item);//position代表第几个功能项,从0开始,我们将对应的存储功能名称的数组赋值给它即可 tv_item.setText(names[position]);//与上面相同 iv_item.setImageResource(ids[position]); return view; } @Override public Object getItem(int position) { return null; } @Override public long getItemId(int position) { return 0; } } }到这里即完成了功能界面图标展示功能后面将给出跑马灯效果的消息展示横幅的实现过程