Android 抽屉导航

简介:

效果

使用最新的android-support-v4.jar, 见附件.


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
< android.support.v4.widget.DrawerLayout
     xmlns:android = "http://schemas.android.com/apk/res/android"
     android:id = "@+id/drawer_layout"
     android:layout_width = "match_parent"
     android:layout_height = "match_parent" >
     <!-- The main content view -->
      ...
     <!-- The navigation drawer -->
     < ListView
         android:id = "@+id/left_drawer"
         android:layout_width = "120dp"
         android:layout_height = "match_parent"
         android:layout_gravity = "start"
         android:choiceMode = "singleChoice"
         android:divider = "@android:color/transparent"
         android:dividerHeight = "0dp"
         android:background = "#EEA9B8" />
</ android.support.v4.widget.DrawerLayout >

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
     /** 抽屉导航变量 */
     private  DrawerLayout mDrawerLayout;
     private  ListView mDrawerList;
     private  ActionBarDrawerToggle mDrawerToggle;
                           
...
                           
         /** 抽屉导航相关 */
         mDrawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout);
         mDrawerList = (ListView) findViewById(R.id.left_drawer);
         mDrawerLayout.setDrawerShadow(R.drawable.draw, GravityCompat.RELATIVE_HORIZONTAL_GRAVITY_MASK);
                           
         mDrawerList.setAdapter( new  SimpleAdapter( this , getDrawerItems( false ),
                 R.layout.drawer_item,  new  String[] {  "drawer_img" ,
                         "drawer_title"  },  new  int [] { R.id.drawer_img,
                         R.id.drawer_title }));
                           
         mDrawerList.setOnItemClickListener( new  DrawerItemClickListener());
         mDrawerToggle =  new  ActionBarDrawerToggle(
                 this ,                   /** host Activity */
                 mDrawerLayout,          /** DrawerLayout object */
                 R.drawable.draw,   /** nav drawer image to replace 'Up' caret */
                 R.string.search_label,   /** "open drawer" description for accessibility */
                 R.string.defalut_text   /** "close drawer" description for accessibility */
                 ) {
             public  void  onDrawerClosed(View view) {
                 getActionBar().setTitle( "onDrawerClosed" );
                 invalidateOptionsMenu();  // creates call to onPrepareOptionsMenu()
             }
                           
             public  void  onDrawerOpened(View drawerView) {
                 getActionBar().setTitle( "onDrawerOpened" );
                 invalidateOptionsMenu();  // creates call to onPrepareOptionsMenu()
             }
         };
         mDrawerLayout.setDrawerListener(mDrawerToggle);
                           
...
                           
     /**
      * 监听抽屉导航item点击事件
      */
     private  class  DrawerItemClickListener  implements  ListView.OnItemClickListener {
                           
         @Override
         public  void  onItemClick(AdapterView<?> parent, View view,  int  position,  long  id) {
             selectItem(view, position);
         }
     }
                           
     private  boolean  flag =  false ;
     private  void  selectItem(View view,  int  position) {
         if  (position ==  0 ) {
             if  (!flag) {
                 mDrawerList.setAdapter( new  SimpleAdapter( this , getDrawerItems( true ),
                         R.layout.drawer_item,  new  String[] {  "drawer_img" ,
                                 "drawer_title"  },  new  int [] { R.id.drawer_img,
                                 R.id.drawer_title }));
                 flag =  true ;
             else  {
                 mDrawerList.setAdapter( new  SimpleAdapter( this , getDrawerItems( false ),
                         R.layout.drawer_item,  new  String[] {  "drawer_img" ,
                                 "drawer_title"  },  new  int [] { R.id.drawer_img,
                                 R.id.drawer_title }));
                 flag =  false ;
             }
         else  {
             TextView title = (TextView) view.findViewById(R.id.drawer_title);
             String cityName = title.getText().toString();
             this .cityInput.setText(cityName);
         }
     }



本文转自chainli 51CTO博客,原文链接:http://blog.51cto.com/lichen/1212912,如需转载请自行联系原作者

相关文章
|
4月前
|
Android开发 Kotlin
kotlin开发安卓app,如何让布局自适应系统传统导航和全面屏导航
使用`navigationBarsPadding()`修饰符实现界面自适应,自动处理底部导航栏的内边距,再加上`.padding(bottom = 10.dp)`设定内容与屏幕底部的距离,以完成全面的布局适配。示例代码采用Kotlin。
127 15
|
6月前
|
Java Android开发
Android 导航方式切换
Android 导航方式切换
123 1
|
6月前
|
Android开发
【Android 从入门到出门】第四章:现代Android开发中的导航
【Android 从入门到出门】第四章:现代Android开发中的导航
43 2
【Android 从入门到出门】第四章:现代Android开发中的导航
|
6月前
|
Java 定位技术 Android开发
【Android App】利用腾讯地图获取地点信息和规划导航线路讲解及实战(附源码和演示视频 超详细必看)
【Android App】利用腾讯地图获取地点信息和规划导航线路讲解及实战(附源码和演示视频 超详细必看)
373 1
|
6月前
|
XML Java 定位技术
【Android App】定位导航GPS中开启手机定位功能讲解及实战(附源码和演示 超详细)
【Android App】定位导航GPS中开启手机定位功能讲解及实战(附源码和演示 超详细)
293 0
|
存储 Android开发
android ViewPager + Fragment + Tablayout 实现嵌套页面导航(二)
android ViewPager + Fragment + Tablayout 实现嵌套页面导航
android ViewPager + Fragment + Tablayout 实现嵌套页面导航(二)
|
XML Android开发 数据格式
【Android】DrawerLayout抽屉布局的写法
抽屉布局就类似那种侧拉出来的界面。 一个页面想要实现抽屉布局很简单! 这个XML文件包含抽屉布局的代码。
134 0
|
编译器 Android开发 容器
android ViewPager + Fragment + Tablayout 实现嵌套页面导航(一)
android ViewPager + Fragment + Tablayout 实现嵌套页面导航
android ViewPager + Fragment + Tablayout 实现嵌套页面导航(一)
|
XML JSON Java
Android 侧滑抽屉菜单
Android 侧滑抽屉菜单
459 1
Android 侧滑抽屉菜单
|
XML Android开发 数据格式
Android Navigation + Fragment 制作APP主页面导航(步骤 + 源码)
Android Navigation + Fragment 制作APP主页面导航(步骤 + 源码)
398 0
Android Navigation + Fragment 制作APP主页面导航(步骤 + 源码)