Android基础知识【项目实训】【4】
【该项目实训是Android基础知识的一个综合练习,特别提示:项目中会用到一些图片素材,都是随意整理的,稍后会上传一个资源,包含该事项项目的基本功能,也含有图片素材】
主界面的功能确实比较复杂,因此上一篇知识说的周边内容。现在开始说这个界面的代码和布局文件。
1、先看一下项目的组织结构吧,要不然不好说他们的关系:
(1)db包中的都是跟 数据库相关的
(2)eatall中放的都是activity或者fragment
(3)entity中放的实体类
(4)util中放的是工具类
2、主界面activity类是MainActivity,注意它继承的是ActivityGroup,因为还没用使用Fragment
/** * 百米购的主界面,内含一个TabHost,作为主导航使用 * @author Administrator */ public class MainActivity extends ActivityGroup { TabHost tabHost; GridView gv; String mainMenus[]={"百米美食","百米餐馆","推荐美食","我的最爱", "健康跟踪","美食心得","查看菜系","我的账单", "提前预定","系统帮助","百米设置","注册信息"}; int mainMenuIcons[]=new int[12]; List<Map<String,Object>> menuData ;//Tab3中主菜单的 数据 EatApp app ; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); tabHost=(TabHost) findViewById(R.id.mainTabHost); //初始化导航界面 initTabHost(); app=(EatApp) getApplication(); } // private void initTabHost() { tabHost.setup();//使用TabHost控件时,必须加入该程序 tabHost.setup(getLocalActivityManager()); TabSpec tab1=tabHost.newTabSpec("t1"); tab1.setIndicator("促销打折",getResources().getDrawable(R.drawable.logo_s) ); Intent intent1=new Intent(MainActivity.this,DiscountFoodActivity.class); tab1.setContent(intent1); TabSpec tab2=tabHost.newTabSpec("t2"); tab2.setIndicator("我的账单",getResources().getDrawable(R.drawable.logo_s) ); Intent intent2=new Intent(MainActivity.this,AccountActivity.class); tab2.setContent(intent2); TabSpec tab3=tabHost.newTabSpec("t3"); tab3.setIndicator("百米购",getResources().getDrawable(R.drawable.logo_s) ); tab3.setContent(R.id.main_tabMainFace); tabHost.addTab(tab1); tabHost.addTab(tab2); tabHost.addTab(tab3); //初始化Tab3的主导航页面 gv=(GridView) findViewById(R.id.main_tabMainFace_gv); initGridView(); } //对Tag3中的主导航GridView进行初始化 private void initGridView() { for (int i = 0; i <mainMenuIcons.length; i++) { mainMenuIcons[i]=R.drawable.mainmenu_01+i; } menuData=new ArrayList<Map<String,Object>>(); for (int i = 0; i < mainMenus.length; i++) { Map<String,Object>item =new HashMap<String,Object>(); item.put("menuImg", mainMenuIcons[i]); item.put("menuTitle", mainMenus[i]); menuData.add(item); } SimpleAdapter sa =new SimpleAdapter( this, menuData, R.layout.mainmenulist_item, new String[]{"menuImg","menuTitle"}, new int[]{R.id.mainMenu_item_img,R.id.mainMenu_item_title} ); gv.setAdapter(sa); gv.setOnItemClickListener(new OnItemClickListener(){ @Override public void onItemClick(AdapterView<?> arg0, View arg1, int arg2, long arg3) { }} ); } @Override public boolean onCreateOptionsMenu(Menu menu) { getMenuInflater().inflate(R.menu.main, menu); return true; } //菜单点击 @Override public boolean onOptionsItemSelected(MenuItem item) { Intent intent=null ; switch(item.getItemId()){ case R.id.menu_shopcat: //查看购物车菜单 intent =new Intent(MainActivity.this,ShopcartActivity.class); break; case R.id.menu_info: //查看个人信息 Log.i("Msg", app.userInfo+" 登录信息"); if(app.userInfo!=null){ intent =new Intent(MainActivity.this,UserinfoActivity.class); }else{ new LoginDialog(this); } break; case R.id.menu_setting: //系统设置菜单 break; case R.id.menu_exit: //系统推出菜单 MainActivity.this.finish(); break; } if(intent!=null) startActivity(intent); return super.onOptionsItemSelected(item); } @Override protected void onResume() { super.onResume(); if(app.userInfo!=null){ setTitle("百米购["+app.userInfo.getUserName()+"]"); } } /*退出时,情况购物车中的数据*/ @Override protected void onDestroy() { super.onDestroy(); EatApp app=(EatApp) getApplication(); app.orderItems.clear(); app.userInfo=null; finish(); } }此处对几个方法的功能,进一步说明:
(1)
TabHost tabHost;这个是底部的Tab导航要用的。
(2)下面这几个是 第三个Tab中要用的内容
GridView gv; String mainMenus[]={"百米美食","百米餐馆","推荐美食","我的最爱", "健康跟踪","美食心得","查看菜系","我的账单", "提前预定","系统帮助","百米设置","注册信息"}; int mainMenuIcons[]=new int[12]; List<Map<String,Object>> menuData ;//Tab3中主菜单的 数据
(3)
EatApp app ;
这是自定义的一个Application类,目的是让不同的Activity可以共用一部分数据【后面还有说明的】
(4)代码中涉及到很多其他的Activity和类,先说明一下
<span style="background-color: rgb(153, 255, 153);">DiscountFoodActivity.class :这个地方是 打折促销的 Activity界面</span>
<span style="background-color: rgb(153, 255, 153);">AccountActivity.class :这个是账单信息Activity界面</span>
<span style="background-color: rgb(153, 255, 153);">ShopcartActivity.class : 查看购物车菜单被点击,前往购物车Activity界面</span>
<pre name="code" class="java"><span style="background-color: rgb(153, 255, 153);">UserinfoActivity.class :用户信息Activity界面</span>
<span style="background-color: rgb(153, 255, 153);">new LoginDialog(this) : 有一个自定义的对话框界面,实现用户登录</span>
3、主界面的布局文件是:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".MainActivity" > <TabHost android:id="@+id/mainTabHost" android:layout_width="match_parent" android:layout_height="match_parent" > <LinearLayout android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" > <FrameLayout android:id="@android:id/tabcontent" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_weight="1" > <LinearLayout android:id="@+id/main_tabMainFace" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" > <GridView android:id="@+id/main_tabMainFace_gv" android:layout_width="match_parent" android:layout_height="match_parent" android:numColumns="4" android:padding="8dp" android:gravity="center_horizontal" ></GridView> </LinearLayout> </FrameLayout> <TabWidget android:id="@android:id/tabs" android:layout_width="match_parent" android:layout_height="wrap_content" > </TabWidget> </LinearLayout> </TabHost> </RelativeLayout>注意将TabWidget放在下面,以实现标签导航在下的方式。
4、上面用到一个GridView,它的元素采用的布局文件是:
<?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_horizontal" > <ImageView android:id="@+id/mainMenu_item_img" android:layout_width="80dp" android:layout_height="80dp" android:scaleType="centerCrop" /> <TextView android:id="@+id/mainMenu_item_title" android:layout_width="wrap_content" android:layout_height="wrap_content" android:textSize="16sp" android:layout_marginTop="5dp" android:text="菜单名" /> </LinearLayout>
结束,下一篇,说明主界面中的三个子界面是如果实现的。
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。