码迷,mamicode.com
首页 > 其他好文 > 详细

侧滑框——SlidingMenu

时间:2016-05-12 12:26:14      阅读:147      评论:0      收藏:0      [点我收藏+]

标签:

一、将所下载的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();
            }
        });

侧滑框——SlidingMenu

标签:

原文地址:http://blog.csdn.net/i_love_crazy/article/details/51371952

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!