侧滑框——SlidingMenu

一、将所下载的libary包导入到项目中
这里写图片描述
二、在项目中初始化侧滑菜单

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));
    }

创建相应的布局文件
这里写图片描述

<?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>

这里写图片描述

<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

            }
        });

点击按钮侧滑框拉出
这里写图片描述
这里写图片描述


 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();
            }
        });
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值