如何添加分隔在AndroidResideMenu项目? [英] How to add divider to items in AndroidResideMenu?

查看:225
本文介绍了如何添加分隔在AndroidResideMenu项目?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我创建其中正在使用 AndroidResideMenu 一个Android应用程序。
我想设置一个分隔在侧menu.I试图在library.But的XML添加一个布局分隔每个项目之间它不是working.Please帮助...

 <?XML版本=1.0编码=UTF-8&GT?;< LinearLayout中的xmlns:机器人=htt​​p://schemas.android.com/apk/res/android
              机器人:方向=横向
              机器人:layout_width =match_parent
              机器人:layout_height =WRAP_CONTENT
              机器人:重力=center_vertical
              机器人:paddingTop =15dp>    < ImageView的
            机器人:layout_width =20dp
            机器人:layout_height =20dp
            机器人:scaleType =centerCrop
            机器人:ID =@ + ID / iv_icon/>    <的TextView
            机器人:layout_width =match_parent
            机器人:layout_height =WRAP_CONTENT
            机器人:文字颜色=@机器人:彩色/白
            机器人:TEXTSIZE =13SP
            机器人:layout_marginLeft =10dp
            机器人:ID =@ + ID / tv_title/>
     <的LinearLayout              机器人:layout_width =match_parent
              机器人:layout_height =2DP
              机器人:背景=#000000>        < / LinearLayout中>
< / LinearLayout中>

这是将项目添加到菜单的方法

 私人无效setUpMenu(){    //附加到当前的活动;
    resideMenu =新ResideMenu(本);
    resideMenu.setBackground(R.drawable.menu_background);
    resideMenu.attachToActivity(本);
    resideMenu.setMenuListener(menu​​Listener);    resideMenu.setScaleValue(0.6f);    //创建菜单项;
    itemHome =新ResideMenuItem(这一点,R.drawable.icon_home,家);
    itemProfile =新ResideMenuItem(这一点,R.drawable.icon_profile,档案);
    itemCalendar =新ResideMenuItem(这一点,R.drawable.icon_calendar,日历);
    itemSettings =新ResideMenuItem(这一点,R.drawable.icon_settings,设置);    itemHome.setOnClickListener(本);
    itemProfile.setOnClickListener(本);
    itemCalendar.setOnClickListener(本);
    itemSettings.setOnClickListener(本);    resideMenu.addMenuItem(itemHome,ResideMenu.DIRECTION_LEFT);
    resideMenu.addMenuItem(itemProfile,ResideMenu.DIRECTION_LEFT);
    resideMenu.addMenuItem(itemCalendar,ResideMenu.DIRECTION_RIGHT);
    resideMenu.addMenuItem(itemSettings,ResideMenu.DIRECTION_RIGHT);    //您可以通过设置禁用一个方向 - >
    // resideMenu.setSwipeDirectionDisable(ResideMenu.DIRECTION_RIGHT);    findViewById(R.id.title_bar_left_menu).setOnClickListener(新View.OnClickListener(){
        @覆盖
        公共无效的onClick(查看视图){
            resideMenu.openMenu(ResideMenu.DIRECTION_LEFT);
        }
    });
    findViewById(R.id.title_bar_right_menu).setOnClickListener(新View.OnClickListener(){
        @覆盖
        公共无效的onClick(查看视图){
            resideMenu.openMenu(ResideMenu.DIRECTION_RIGHT);
        }
    });
}


解决方案

通过ResideMenu,每一个项目是 ResideMenuItem 的一个实例,这基本上是一个简单的的LinearLayout

我会使用的解决方案,如下:

  //创建菜单项;
itemHome =新ResideMenuItem(这一点,R.drawable.icon_home,家);
itemProfile =新ResideMenuItem(这一点,R.drawable.icon_profile,档案);
itemCalendar =新ResideMenuItem(这一点,R.drawable.icon_calendar,日历);
itemSettings =新ResideMenuItem(这一点,R.drawable.icon_settings,设置);itemHome.setOnClickListener(本);
itemProfile.setOnClickListener(本);
itemCalendar.setOnClickListener(本);
itemSettings.setOnClickListener(本);resideMenu.addMenuItem(itemHome,ResideMenu.DIRECTION_LEFT);
resideMenu.addMenuItem(itemProfile,ResideMenu.DIRECTION_LEFT);
resideMenu.addMenuItem(itemCalendar,ResideMenu.DIRECTION_RIGHT);
resideMenu.addMenuItem(itemSettings,ResideMenu.DIRECTION_RIGHT);//强制这些元素上边距
setMargin(itemHome);
setMargin(itemProfile);
setMargin(itemCalendar);
setMargin(itemSettings);

使用下面的方法来应用边距:

 私人无效setMargin(ResideMenuItem项)
{
    LinearLayout.LayoutParams PARAMS =(LinearLayout.LayoutParams)item.getLayoutParams();
    params.setMargins(0,dpToPx(15),0,0);
    item.setLayoutParams(PARAMS);
}

不要忘了落实 dpToPx 转换 15dp 到相应的像素大小。


要添加一个分隔线,你可以使用这样的事情:

 私人无效addSeparatorAfter(ResideMenuItem菜单项)
{
    的LinearLayout父=(的LinearLayout)((的ViewGroup)menuItem.getParent())的getParent();    浏览器=新的视图(本);
    LinearLayout.LayoutParams PARAMS =新LinearLayout.LayoutParams(LinearLayout.LayoutParams.MATCH_PARENT,dpToPx(2DP));
    params.setMargins(dpToPx(5),dpToPx(5),dpToPx(5),dpToPx(5));
    separator.setLayoutParams(PARAMS);
    separator.setBackgroundColor(0xFFCCCCCC);    parent.addView(分隔符);
}

和之后调用它的每个 addMenuItem 方法。

例如,你的情况,这将是:

  resideMenu.addMenuItem(itemHome,ResideMenu.DIRECTION_LEFT);
addSeparatorAfter(itemHome);
resideMenu.addMenuItem(itemProfile,ResideMenu.DIRECTION_LEFT);
addSeparatorAfter(itemProfile);
resideMenu.addMenuItem(itemCalendar,ResideMenu.DIRECTION_RIGHT);
addSeparatorAfter(itemCalendar);
resideMenu.addMenuItem(itemSettings,ResideMenu.DIRECTION_RIGHT);

I'm creating an android application in which am using AndroidResideMenu. I want to set a divider in between each item in side menu.I tried adding a layout for divider in the xml in library.But its not working.Please help...

 <?xml version="1.0" encoding="utf-8"?>

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
              android:orientation="horizontal"
              android:layout_width="match_parent"
              android:layout_height="wrap_content"
              android:gravity="center_vertical"
              android:paddingTop="15dp">

    <ImageView
            android:layout_width="20dp"
            android:layout_height="20dp"
            android:scaleType="centerCrop"
            android:id="@+id/iv_icon"/>

    <TextView
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:textColor="@android:color/white"
            android:textSize="13sp"
            android:layout_marginLeft="10dp"
            android:id="@+id/tv_title"/>


     <LinearLayout

              android:layout_width="match_parent"
              android:layout_height="2dp"
              android:background="#000000">

        </LinearLayout>
</LinearLayout>

This is the method for adding items to menu

private void setUpMenu() {

    // attach to current activity;
    resideMenu = new ResideMenu(this);
    resideMenu.setBackground(R.drawable.menu_background);
    resideMenu.attachToActivity(this);
    resideMenu.setMenuListener(menuListener);

    resideMenu.setScaleValue(0.6f);

    // create menu items;
    itemHome     = new ResideMenuItem(this, R.drawable.icon_home,     "Home");
    itemProfile  = new ResideMenuItem(this, R.drawable.icon_profile,  "Profile");
    itemCalendar = new ResideMenuItem(this, R.drawable.icon_calendar, "Calendar");
    itemSettings = new ResideMenuItem(this, R.drawable.icon_settings, "Settings");

    itemHome.setOnClickListener(this);
    itemProfile.setOnClickListener(this);
    itemCalendar.setOnClickListener(this);
    itemSettings.setOnClickListener(this);

    resideMenu.addMenuItem(itemHome, ResideMenu.DIRECTION_LEFT);
    resideMenu.addMenuItem(itemProfile, ResideMenu.DIRECTION_LEFT);
    resideMenu.addMenuItem(itemCalendar, ResideMenu.DIRECTION_RIGHT);
    resideMenu.addMenuItem(itemSettings, ResideMenu.DIRECTION_RIGHT);

    // You can disable a direction by setting ->
    // resideMenu.setSwipeDirectionDisable(ResideMenu.DIRECTION_RIGHT);

    findViewById(R.id.title_bar_left_menu).setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            resideMenu.openMenu(ResideMenu.DIRECTION_LEFT);
        }
    });
    findViewById(R.id.title_bar_right_menu).setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            resideMenu.openMenu(ResideMenu.DIRECTION_RIGHT);
        }
    });
}

解决方案

With ResideMenu, every item is an instance of ResideMenuItem which is basically a simple LinearLayout.

The solution I would use, is the following:

// create menu items;
itemHome     = new ResideMenuItem(this, R.drawable.icon_home,     "Home");
itemProfile  = new ResideMenuItem(this, R.drawable.icon_profile,  "Profile");
itemCalendar = new ResideMenuItem(this, R.drawable.icon_calendar, "Calendar");
itemSettings = new ResideMenuItem(this, R.drawable.icon_settings, "Settings");

itemHome.setOnClickListener(this);
itemProfile.setOnClickListener(this);
itemCalendar.setOnClickListener(this);
itemSettings.setOnClickListener(this);

resideMenu.addMenuItem(itemHome, ResideMenu.DIRECTION_LEFT);
resideMenu.addMenuItem(itemProfile, ResideMenu.DIRECTION_LEFT);
resideMenu.addMenuItem(itemCalendar, ResideMenu.DIRECTION_RIGHT);
resideMenu.addMenuItem(itemSettings, ResideMenu.DIRECTION_RIGHT);

// Force top margin for these elements
setMargin(itemHome);
setMargin(itemProfile);
setMargin(itemCalendar);
setMargin(itemSettings);

Use the following method to apply margins:

private void setMargin(ResideMenuItem item)
{
    LinearLayout.LayoutParams params = (LinearLayout.LayoutParams) item.getLayoutParams();
    params.setMargins(0, dpToPx(15), 0, 0);
    item.setLayoutParams(params);
}

Don't forget to implement dpToPx to convert 15dp into the corresponding pixel size.


To add a divider line, you could use something like that:

private void addSeparatorAfter(ResideMenuItem menuItem)
{
    LinearLayout parent = (LinearLayout) ((ViewGroup) menuItem.getParent()).getParent();

    View separator = new View(this);
    LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.MATCH_PARENT, dpToPx(2dp));
    params.setMargins(dpToPx(5), dpToPx(5), dpToPx(5), dpToPx(5));
    separator.setLayoutParams(params);
    separator.setBackgroundColor(0xFFCCCCCC);

    parent.addView(separator);
}

and call it right after each addMenuItem method.

For example, in your case, it would be:

resideMenu.addMenuItem(itemHome, ResideMenu.DIRECTION_LEFT);
addSeparatorAfter(itemHome);
resideMenu.addMenuItem(itemProfile, ResideMenu.DIRECTION_LEFT);
addSeparatorAfter(itemProfile);
resideMenu.addMenuItem(itemCalendar, ResideMenu.DIRECTION_RIGHT);
addSeparatorAfter(itemCalendar);
resideMenu.addMenuItem(itemSettings, ResideMenu.DIRECTION_RIGHT);

这篇关于如何添加分隔在AndroidResideMenu项目?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆