侧滑框——SlidingMenu

一、将所下载的libary包导入到项目中
侧滑框——SlidingMenu_第1张图片
二、在项目中初始化侧滑菜单

public void initSlidingMenu() {
    SlidingMenu menu = new SlidingMenu(this);
            // 设置侧滑方式为左侧侧滑
            menu.setMode(SlidingMenu.LEFT);
            /* * 设置拖拽模式 SlidingMenu.TOUCHMODE_FULLSCREEN全屏触摸有效 * SlidingMenu.TOUCHMODE_MARGIN 拖拽边缘有效 SlidingMenu.TOUCHMODE_NONE * 不响应触摸事件 */
            menu.setTouchModeAbove(SlidingMenu.TOUCHMODE_FULLSCREEN);
            // 设置阴影的宽度
            menu.setShadowWidthRes(R.dimen.shadow_width);
            // 设置阴影的图片
            menu.setShadowDrawable(R.drawable.shadow);
            // 设置sldingMenu的剩余大小---=内容显示页对应的dp大小
            menu.setBehindOffsetRes(R.dimen.slidingmenu_offset);
            // 设置滑动时的渐变程度
            menu.setFadeDegree(0.35f);
            // 使SlidingMenu附加在Activity右边
            // SlidingMenu.SLIDING_CONTENT 将侧滑栏设置为在内容位置
            // SlidingMenu.SLIDING_WINDOW 将侧滑栏设置为在整个窗口呈现
            menu.attachToActivity(this, SlidingMenu.SLIDING_CONTENT);
            // 设置SlidingMenu关联的布局
            menu.setMenu(R.layout.menu_layout);
            // 在SlidingMenu关联布局中查询控件
            ListView lv_list = (ListView) menu.findViewById(R.id.lv);
            // 简单设置SlidingMenu界面显示内容


            ArrayList<String> strList = new ArrayList<String>();
            for (int i = 0; i < 20; i++) {
                strList.add("第" + i + "个条目");
            }
            // 设置数据适配器
            lv_list.setAdapter(new ArrayAdapter<String>(this,
                    android.R.layout.simple_list_item_1, strList));
    }

创建相应的布局文件
侧滑框——SlidingMenu_第2张图片

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" >

    <gradient  android:centerColor="#ccc" android:endColor="#ccc" android:startColor="#ccc" />

</shape>

侧滑框——SlidingMenu_第3张图片

<resources>

    <!-- Default screen margins, per the Android Design guidelines. -->
    <dimen name="activity_horizontal_margin">16dp</dimen>
    <dimen name="activity_vertical_margin">16dp</dimen>
    <dimen name="shadow_width">2dp</dimen>
    <dimen name="slidingmenu_offset">160dp</dimen>

</resources>

解决ViewPager与侧滑的冲突

vp_pager.setOnPageChangeListener(new OnPageChangeListener() {

            @Override
            public void onPageSelected(int arg0) {
                if (arg0 == 0) {
                    menu.setTouchModeAbove(
                            SlidingMenu.TOUCHMODE_FULLSCREEN);
                } else {
                    // 当在其他位置的时候,设置不可以拖拽出来(SlidingMenu.TOUCHMODE_NONE),或只有在边缘位置才可以拖拽出来TOUCHMODE_MARGIN
                    menu.setTouchModeAbove(
                            SlidingMenu.TOUCHMODE_NONE);
                }

            }

            @Override
            public void onPageScrolled(int arg0, float arg1, int arg2) {
                // TODO Auto-generated method stub

            }

            @Override
            public void onPageScrollStateChanged(int arg0) {
                // TODO Auto-generated method stub

            }
        });

点击按钮侧滑框拉出
侧滑框——SlidingMenu_第4张图片
侧滑框——SlidingMenu_第5张图片


 1. 第一种代码

iv_image.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {
                if (menu.isMenuShowing()) {
                    menu.showContent();
                } else {

                    menu.showMenu();
                }
            }
        });


 2. 第二种代码
 iv_image.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {
                //
                menu.toggle();
            }
        });

你可能感兴趣的:(侧滑框——SlidingMenu)