当前位置:   article > 正文

Android使用DrawerLayout控件实现菜单侧滑_android drawerlayout 加fragment

android drawerlayout 加fragment

1.新建一个Activity 最外层使用DrawerLayout包裹 

DrawerLayout里部可创建一个LinearLayout LinearLayout的宽高都设置为match_parent 

LinearLayout里可以写当前页面要显示的布局

在LinearLayout下方创建一个fragment (并列关系)

<fragment
    android:id="@+id/fg_menu"
    android:name="XXX.MenuFragment"
    android:layout_width="300dp"
    android:layout_height="match_parent"
    android:layout_gravity="start"
    android:tag="LEFT"
    tools:layout="@layout/fragment_menu" />

PS: fragment里的layout_gravity代表方向 start表示从左边滑出 end代表从右边滑出

2.创建MenuFragment

单独创建一个布局文件 显示菜单栏要显示的东西

创建MenuFragment使其继承Fragment  这个布局的逻辑全部在MenuFragment里实现

在MenuFragment里点击菜单栏按钮实现菜单栏关闭的话

要在MenuFragment里定义一个变量 DrawerLayout drawerLayout 

定义一个方法 

public void setDrawerLayout(DrawerLayout drawerLayout){
    this.drawerLayout = drawerLayout;
}

PS: 这个方法会在MainActivity里调用 

在MenuFragment里关闭菜单的方法:drawerLayout.closeDrawer(Gravity.START)

PS:START代表左边 END代表右边

3.MainActivity里的逻辑

private FragmentManager fManager;
MenuFragment menuFragment;
fManager = getSupportFragmentManager();
menuFragment = (MenuFragment) fManager.findFragmentById(R.id.fg_menu);
menuFragment.setDrawerLayout(drawerLayout);

如果是左滑

drawerLayout.openDrawer(Gravity.START);

如果是右滑

drawer_layout.setDrawerLockMode(DrawerLayout.LOCK_MODE_LOCKED_CLOSED,
        Gravity.END);

drawer_layout.setDrawerListener(new DrawerLayout.DrawerListener() {
    @Override
    public void onDrawerSlide(View view, float v) {

    }

    @Override
    public void onDrawerOpened(View view) {

    }

    @Override
    public void onDrawerClosed(View view) {
        drawer_layout.setDrawerLockMode(
                DrawerLayout.LOCK_MODE_LOCKED_CLOSED, Gravity.END);
    }

    @Override
    public void onDrawerStateChanged(int i) {

    }
});

右滑显示:

drawer_layout.openDrawer(Gravity.END);
drawer_layout.setDrawerLockMode(DrawerLayout.LOCK_MODE_UNLOCKED,
        Gravity.END);    //解除锁定

右滑关闭:

drawer_layout.closeDrawer(Gravity.END);

 

本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号