Android:UI控件DrawerLayout、Fragment、SlidingLayout、侧滑菜单

简介:

DrawerLayout与Fragment的联用


1.xml代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
<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"  >
     <FrameLayout
         android:id= "@+id/fragment_layout"
         android:layout_width= "match_parent"
         android:layout_height= "match_parent"  >
     </FrameLayout>
     <RelativeLayout
         android:id= "@+id/menu_layout"
         android:layout_width= "300dp"
         android:layout_height= "match_parent"
         android:layout_gravity= "left"
         android:background= "#ff333333" >
         <ListView
             android:id= "@+id/menu_listView"
             android:layout_width= "match_parent"
             android:layout_height= "match_parent"  >
         </ListView>
     </RelativeLayout>
</android.support.v4.widget.DrawerLayout>


2.MainActivity继承FragmentActivity

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
73
74
75
76
77
78
79
80
81
82
83
84
85
import  android.os.Bundle;
import  android.app.Activity;
import  android.support.v4.app.Fragment;
import  android.support.v4.app.FragmentActivity;
import  android.support.v4.app.FragmentTransaction;
import  android.support.v4.widget.DrawerLayout;
import  android.view.Menu;
import  android.view.View;
import  android.widget.AdapterView;
import  android.widget.ArrayAdapter;
import  android.widget.ListView;
import  android.widget.RelativeLayout;
import  android.widget.AdapterView.OnItemClickListener;
public  class  MainActivity  extends  FragmentActivity
{
     /*
      * DrawerLayout与Fragment的联用
      * DrawerLayout相关:
      * 1.一般内容层使用framelayout
      * 2.slidingLayout需要设置一个layout_grative属性
      *   文档建议使用android:layout_gravity="start"
      */
                     
     public  static  final  String[] TITLES =
     "Henry IV (1)" "Henry V" "Henry VIII" "Richard II" "Richard III" "Merchant of Venice" "Othello" "King Lear"  };
     private  DrawerLayout mDrawer_layout;
     private  RelativeLayout mMenu_layout;
                     
     @Override
     protected  void  onCreate(Bundle savedInstanceState)
     {
         super .onCreate(savedInstanceState);
         setContentView(R.layout.activity_main);
                         
         mDrawer_layout = (DrawerLayout) findViewById(R.id.drawer_layout);
         mMenu_layout = (RelativeLayout) findViewById(R.id.menu_layout);
                         
         ListView menu_listview = (ListView) mMenu_layout.findViewById(R.id.menu_listView);
                         
         menu_listview.setAdapter( new  ArrayAdapter<String>( this , android.R.layout.simple_expandable_list_item_1, TITLES));
                         
         //监听菜单
         menu_listview.setOnItemClickListener( new  DrawerItemClickListener());
                         
     }
                     
     public  class  DrawerItemClickListener  implements  OnItemClickListener
     {
         @Override
         public  void  onItemClick(AdapterView<?> parent, View view,  int  position,  long  id)
         {
             FragmentTransaction ft = getSupportFragmentManager().beginTransaction();
             Fragment fragment =  null ;
                             
             //根据item点击行号判断启用哪个Fragment
             switch  (position)
             {
                 case  0 :
                     fragment =  new  FirstFragment();
                     break ;
                 case  1 :
                     fragment =  new  NextFragment();
                     break ;
                 default :
                     break ;
             }
             ft.replace(R.id.fragment_layout, fragment);
             ft.commit();
                             
             mDrawer_layout.closeDrawer(mMenu_layout); //点击后关闭mMenu_layout
         }
                         
     }
                     
                     
                     
                     
     @Override
     public  boolean  onCreateOptionsMenu(Menu menu)
     {
         getMenuInflater().inflate(R.menu.main, menu);
         return  true ;
     }
                     
}


3.Fragment类

1
2
3
4
5
6
7
8
9
10
11
12
13
14
import  android.os.Bundle;
import  android.support.v4.app.Fragment;
import  android.view.LayoutInflater;
import  android.view.View;
import  android.view.ViewGroup;
public  class  FirstFragment  extends  Fragment
{
     @Override
     public  View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState)
     {
         View layout = inflater.inflate(R.layout.firstlayout,  null );
         return  layout;
     }
}


1
2
3
4
5
6
7
8
9
public  class  NextFragment  extends  Fragment
{
     @Override
     public  View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState)
     {
         View layout = inflater.inflate(R.layout.nextlayout,  null );
         return  layout;
     }
}



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

目录
相关文章
|
6天前
|
搜索推荐 Android开发 开发者
探索安卓开发中的自定义视图:打造个性化UI组件
【10月更文挑战第39天】在安卓开发的世界中,自定义视图是实现独特界面设计的关键。本文将引导你理解自定义视图的概念、创建流程,以及如何通过它们增强应用的用户体验。我们将从基础出发,逐步深入,最终让你能够自信地设计和实现专属的UI组件。
|
7天前
|
人工智能 API Apache
推荐3款开源、美观且免费的WinForm UI控件库
推荐3款开源、美观且免费的WinForm UI控件库
|
28天前
|
缓存 前端开发 Android开发
Android实战之如何截取Activity或者Fragment的内容?
本文首发于公众号“AntDream”,介绍了如何在Android中截取Activity或Fragment的屏幕内容并保存为图片。包括截取整个Activity、特定控件或区域的方法,以及处理包含RecyclerView的复杂情况。
18 3
|
7天前
|
API C# 开发者
基于Material Design风格开源、免费的WinForms UI控件库
基于Material Design风格开源、免费的WinForms UI控件库!
|
1月前
|
Linux C# Android开发
分享3款开源、免费的Avalonia UI控件库
分享3款开源、免费的Avalonia UI控件库
125 0
|
2月前
|
XML Android开发 UED
💥Android UI设计新风尚!掌握Material Design精髓,让你的界面颜值爆表!🎨
随着移动应用市场的蓬勃发展,用户对界面设计的要求日益提高。为此,掌握由Google推出的Material Design设计语言成为提升应用颜值和用户体验的关键。本文将带你深入了解Material Design的核心原则,如真实感、统一性和创新性,并通过丰富的组件库及示例代码,助你轻松打造美观且一致的应用界面。无论是色彩搭配还是动画效果,Material Design都能为你的Android应用增添无限魅力。
65 1
|
3月前
|
存储 搜索推荐 Java
探索安卓开发中的自定义视图:打造个性化UI组件Java中的异常处理:从基础到高级
【8月更文挑战第29天】在安卓应用的海洋中,一个独特的用户界面(UI)能让应用脱颖而出。自定义视图是实现这一目标的强大工具。本文将通过一个简单的自定义计数器视图示例,展示如何从零开始创建一个具有独特风格和功能的安卓UI组件,并讨论在此过程中涉及的设计原则、性能优化和兼容性问题。准备好让你的应用与众不同了吗?让我们开始吧!
|
3月前
|
编解码 Android开发
【Android Studio】使用UI工具绘制,ConstraintLayout 限制性布局,快速上手
本文介绍了Android Studio中使用ConstraintLayout布局的方法,通过创建布局文件、设置控件约束等步骤,快速上手UI设计,并提供了一个TV Launcher界面布局的绘制示例。
57 1
|
3月前
|
API Android开发
Android项目架构设计问题之选择和使用合适的UI库如何解决
Android项目架构设计问题之选择和使用合适的UI库如何解决
48 0
|
3月前
|
C# 开发者 Windows
一款基于Fluent设计风格、现代化的WPF UI控件库
一款基于Fluent设计风格、现代化的WPF UI控件库