SlidingMenu

侧边栏的实现效果,有许多方式。

我这里使用了github上的开源项目,首先要导入往开发工具中导入library包。

点击下载


也可以直接去下载源文件:

https://github.com/jfeinstein10/SlidingMenu


在界面的oncreate()方法中,加入侧边栏:

// 侧边栏
		menu = new SlidingMenu(this);
		// 设置滑动方向
		menu.setMode(SlidingMenu.LEFT);
		// 设置监听开始滑动的触碰范围
		menu.setTouchModeAbove(SlidingMenu.TOUCHMODE_MARGIN);
		// 设置边缘阴影的宽度,通过dimens资源文件中的ID设置
		menu.setShadowWidthRes(R.dimen.shadow_width);
		// 设置边缘阴影的颜色/图片,通过资源文件ID设置
		menu.setShadowDrawable(R.drawable.shadow);
		// 设置menu全部打开后,主界面剩余部分与屏幕边界的距离,通过dimens资源文件ID设置
		menu.setBehindOffsetRes(R.dimen.slidingmenu_offset);
		// 设置是否淡入淡出
		menu.setFadeEnabled(true);
		// 设置淡入淡出的值,只在setFadeEnabled设置为true时有效
		menu.setFadeDegree(0.35f);
		// 将menu绑定到Activity,同时设置绑定类型
		menu.attachToActivity(this, SlidingMenu.SLIDING_WINDOW);
		// 设置menu的layout
		menu.setMenu(R.layout.slide_menu);
		// 设置menu的背景
		menu.setBackgroundColor(getResources().getColor(
				android.R.color.background_light));
		// 获取menu的layout
		View menuroot = menu.getMenu();

在这里,你会因为缺少几个文件,而报错。

slide_menu:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="240dip"
    android:layout_height="fill_parent"
    android:background="@drawable/bitmap_book_read_chapterlist_repeat"
    android:orientation="vertical" >

    <RelativeLayout
        android:layout_width="240dip"
        android:layout_height="50.0dip" >

        <ImageView
            android:id="@+id/img_head"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginLeft="20dp"
            android:src="@drawable/ic_launcher" />

        <TextView
            android:id="@+id/tv_useName"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignBottom="@+id/img_head"
            android:layout_marginLeft="28dp"
            android:layout_toRightOf="@+id/img_head"
            android:text="会飞的鲨鱼"
            android:textColor="@android:color/white" />

        <ImageView
            android:id="@+id/img_vip"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentBottom="true"
            android:layout_marginLeft="16dp"
            android:layout_toRightOf="@+id/tv_useName"
            android:src="@drawable/ic_launcher" />

    </RelativeLayout>

    <TextView
        android:layout_width="240dip"
        android:layout_height="28.0dip"
        android:background="#ff313131"
        android:gravity="center_vertical"
        android:paddingLeft="15.0dip"
        android:text="分类"
        android:textColor="#ff959595"
        android:textSize="14.0sp" />

    <TextView
        android:id="@+id/tv_contacts"
        android:layout_width="240dip"
        android:layout_height="50.0dip"
        android:background="@drawable/selector_category_item"
        android:clickable="true"
        android:drawableLeft="@drawable/ic_category_mark"
        android:drawablePadding="1.0dip"
        android:gravity="center_vertical"
        android:paddingLeft="15.0dip"
        android:paddingRight="10.0dip"
        android:text="最近联系人"
        android:textColor="#ff959595"
        android:textSize="16.0sp" />

    <View
        android:layout_width="240dip"
        android:layout_height="2.0dip"
        android:background="@drawable/ic_shelf_category_divider" />

    <TextView
        android:id="@+id/tv_neighborinfor"
        android:layout_width="240dip"
        android:layout_height="50.0dip"
        android:background="@drawable/selector_category_item"
        android:clickable="true"
        android:drawableLeft="@drawable/ic_category_mark"
        android:drawablePadding="1.0dip"
        android:gravity="center_vertical"
        android:paddingLeft="15.0dip"
        android:paddingRight="10.0dip"
        android:text="附近信息"
        android:textColor="#ff959595"
        android:textSize="16.0sp" />

    <View
        android:layout_width="240dip"
        android:layout_height="2.0dip"
        android:background="@drawable/ic_shelf_category_divider" />
    <TextView
        android:id="@+id/tv_checktime"
        android:layout_width="240dip"
        android:layout_height="50.0dip"
        android:background="@drawable/selector_category_item"
        android:clickable="true"
        android:drawableLeft="@drawable/ic_category_mark"
        android:drawablePadding="1.0dip"
        android:gravity="center_vertical"
        android:paddingLeft="15.0dip"
        android:paddingRight="10.0dip"
        android:text="签到"
        android:textColor="#ff959595"
        android:textSize="16.0sp" />

    <View
        android:layout_width="240dip"
        android:layout_height="2.0dip"
        android:background="@drawable/ic_shelf_category_divider" />
    <TextView
        android:id="@+id/tv_setting"
        android:layout_width="240dip"
        android:layout_height="50.0dip"
        android:background="@drawable/selector_category_item"
        android:clickable="true"
        android:drawableLeft="@drawable/ic_category_mark"
        android:drawablePadding="1.0dip"
        android:gravity="center_vertical"
        android:paddingLeft="15.0dip"
        android:paddingRight="10.0dip"
        android:text="设置"
        android:textColor="#ff959595"
        android:textSize="16.0sp" />

    <View
        android:layout_width="240dip"
        android:layout_height="2.0dip"
        android:background="@drawable/ic_shelf_category_divider" />

</LinearLayout>

slidingmenu_offset 和 shadow_width:

在values中的dimens文件中加入:

  <dimen name="slidingmenu_offset">60dp</dimen>
    <dimen name="shadow_width">15dp</dimen>

shadow:

在drawable中加入文件:

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

    <gradient
        android:endColor="#33000000"
        android:centerColor="#11000000"
        android:startColor="#00000000" />

</shape>

注意:

1.侧边栏的显示和关闭:

// 点击后,显示或者隐藏侧边栏
			menu.showMenu();

showMenu()的方法,在点击事件中能监听到,但是在监听menu的时候,调用的时候只能显示,不能关闭。

另外一种方法,调用切换方法:

// 切换侧边栏状态
			menu.toggle();


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android Studio中实现滑动窗体可以使用第三方库SlidingMenuSlidingMenu是一个开源的Android库,可以让你的应用程序拥有侧滑菜单的功能。使用SlidingMenu可以轻松地实现左右两侧的侧滑菜单,同时也可以在菜单中添加Fragment等内容。具体实现步骤如下: 1. 在build.gradle文件中添加依赖:implementation 'com.jeremyfeinstein.slidingmenu:library:1.3.0@aar' 2. 在布局文件中添加SlidingMenu控件,并设置相关属性,如侧滑方向、宽度、菜单布局等。 3. 在Activity中初始化SlidingMenu,并将其附加到Activity上。 4. 可以在菜单布局中添加Fragment等内容。 示例代码如下: ``` //在build.gradle文件中添加依赖 implementation 'com.jeremyfeinstein.slidingmenu:library:1.3.0@aar' //在布局文件中添加SlidingMenu控件 <com.jeremyfeinstein.slidingmenu.lib.SlidingMenu xmlns:sliding="http://schemas.android.com/apk/res-auto" android:id="@+id/sliding_menu" android:layout_width="match_parent" android:layout_height="match_parent" sliding:viewAbove="@layout/content_frame" sliding:viewBehind="@layout/menu_frame" sliding:behindOffset="@dimen/slidingmenu_offset" sliding:behindWidth="@dimen/slidingmenu_width" sliding:touchModeAbove="margin" sliding:touchModeBehind="fullScreen" sliding:fadeEnabled="true" sliding:fadeDegree="0.35" sliding:selectorEnabled="true" sliding:selectorDrawable="@drawable/list_selector" sliding:shadowDrawable="@drawable/shadow" sliding:shadowWidth="10dp" sliding:shadowHeight="10dp" sliding:shadowOpacity="0.75" sliding:menuOffset="60dp" sliding:behindScrollScale="0.25" sliding:behindFadeDegree="0.0" sliding:mode="left"> </com.jeremyfeinstein.slidingmenu.lib.SlidingMenu> //在Activity中初始化SlidingMenu SlidingMenu menu = new SlidingMenu(this); menu.setMode(SlidingMenu.LEFT); //设置侧滑从左边画出 menu.setTouchModeBehind(SlidingMenu.TOUCHMODE_FULLSCREEN); //设置侧滑可以从全屏滑动出来 WindowManager wm = getWindowManager(); DisplayMetrics displayMetrics = new DisplayMetrics(); wm.getDefaultDisplay().getMetrics(displayMetrics); menu.setBehindWidth(displayMetrics.widthPixels / 2); //设置侧滑的宽度 menu.setFadeEnabled(false); menu.setMenu(R.layout.menu_left_layout); //设置侧滑的布局内容,可以自己创建一个布局文件随便定义里面的界面 // menu.setSecondaryMenu(R.layout.menu_right_layout); //添加依附的Activity menu.attachToActivity(this, SlidingMenu.SLIDING_CONTENT); //必须添加依附的activity,就是你初始化的那个activity,否则会报错 getSupportFragmentManager().beginTransaction().replace(R.id.fragment_menu_container, new LeftMenuFragment()).commit(); //可以在侧滑里面添加一个fragment menu.showMenu(); //显示侧滑 ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值