Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/213.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Android 包括导航抽屉底部的行_Android_Navigation Drawer - Fatal编程技术网

Android 包括导航抽屉底部的行

Android 包括导航抽屉底部的行,android,navigation-drawer,Android,Navigation Drawer,我在这里有一个导航抽屉: 我想在导航列表的末尾添加“设置”和“退出”,但我不能 这是我的抽屉活动\u main.xml的代码: ` ` 我尝试将文本添加到ListView的末尾,并将它们包装在RelativeLayout中,与底部对齐。但到目前为止还没有成功 这是我的主要活动: public class MainActivity extends Activity { private DrawerLayout mDrawerLayout; private ListView mDrawerLi

我在这里有一个导航抽屉:

我想在导航列表的末尾添加“设置”和“退出”,但我不能

这是我的抽屉
活动\u main.xml的代码:

`


`
我尝试将文本添加到ListView的末尾,并将它们包装在RelativeLayout中,与底部对齐。但到目前为止还没有成功

这是我的主要活动:

public class MainActivity extends Activity {
private DrawerLayout mDrawerLayout;
private ListView mDrawerList;
private ActionBarDrawerToggle mDrawerToggle;

// nav drawer title
private CharSequence mDrawerTitle;

// used to store app title
private CharSequence mTitle;

// slide menu items
private String[] navMenuTitles;
private TypedArray navMenuIcons;

private ArrayList<NavDrawerItem> navDrawerItems;
private NavDrawerListAdapter adapter;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    mTitle = mDrawerTitle = getTitle();

    // load slide menu items
    navMenuTitles = getResources().getStringArray(R.array.nav_drawer_items);

    // nav drawer icons from resources
    navMenuIcons = getResources()
            .obtainTypedArray(R.array.nav_drawer_icons);

    mDrawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout);
    mDrawerList = (ListView) findViewById(R.id.list_slidermenu);

    navDrawerItems = new ArrayList<NavDrawerItem>();

    // adding nav drawer items to array
    // Home
    navDrawerItems.add(new NavDrawerItem(navMenuTitles[0], navMenuIcons.getResourceId(0, -1)));
    // Find People
    navDrawerItems.add(new NavDrawerItem(navMenuTitles[1], navMenuIcons.getResourceId(1, -1)));
    // Photos
    navDrawerItems.add(new NavDrawerItem(navMenuTitles[2], navMenuIcons.getResourceId(2, -1)));
    // Communities, Will add a counter here
    navDrawerItems.add(new NavDrawerItem(navMenuTitles[3], navMenuIcons.getResourceId(3, -1), true, "22"));
    // Pages
    navDrawerItems.add(new NavDrawerItem(navMenuTitles[4], navMenuIcons.getResourceId(4, -1)));
    // What's hot, We  will add a counter here
    navDrawerItems.add(new NavDrawerItem(navMenuTitles[5], navMenuIcons.getResourceId(5, -1), true, "50+"));


    // Recycle the typed array
    navMenuIcons.recycle();

    mDrawerList.setOnItemClickListener(new SlideMenuClickListener());

    // setting the nav drawer list adapter
    adapter = new NavDrawerListAdapter(getApplicationContext(),
            navDrawerItems);
    mDrawerList.setAdapter(adapter);

    // enabling action bar app icon and behaving it as toggle button
    getActionBar().setDisplayHomeAsUpEnabled(true);
    getActionBar().setHomeButtonEnabled(true);

    mDrawerToggle = new ActionBarDrawerToggle(this, mDrawerLayout,
            R.drawable.ic_drawer, //nav menu toggle icon
            R.string.app_name, // nav drawer open - description for accessibility
            R.string.app_name // nav drawer close - description for accessibility
    ) {
        public void onDrawerClosed(View view) {
            getActionBar().setTitle(mTitle);
            // calling onPrepareOptionsMenu() to show action bar icons
            invalidateOptionsMenu();
        }

        public void onDrawerOpened(View drawerView) {
            getActionBar().setTitle(mDrawerTitle);
            // calling onPrepareOptionsMenu() to hide action bar icons
            invalidateOptionsMenu();
        }
    };
    mDrawerLayout.setDrawerListener(mDrawerToggle);

    if (savedInstanceState == null) {
        // on first time display view for first nav item
        displayView(0);
    }
}
公共类MainActivity扩展活动{
私人抽屉布局mDrawerLayout;
私有列表视图mDrawerList;
私有操作bardrawertoggle mDrawerToggle;
//导航抽屉标题
私有字符序列mDrawerTitle;
//用于存储应用程序标题
私有字符序列mTitle;
//幻灯片菜单项
私有字符串[]navMenuTitles;
专用型雷达导航仪;
私人ArrayList NavWrites;
专用导航适配器;
@凌驾
创建时受保护的void(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mTitle=mDrawerTitle=getTitle();
//加载幻灯片菜单项
navMenuTitles=getResources().getStringArray(R.array.nav\u抽屉\u项目);
//参考资料中的导航抽屉图标
navMenuIcons=getResources()
.obtainTypedArray(R.array.nav_drawer_图标);
mDrawerLayout=(抽屉布局)findViewById(R.id.抽屉布局);
mDrawerList=(ListView)findViewById(R.id.list\u slidermenu);
navDrawerItems=新的ArrayList();
//将导航抽屉项添加到阵列
//家
添加(新的NavDrawerItem(navMenuTitles[0],navMenuIcons.getResourceId(0,-1));
//找人
添加(新的NavDrawerItem(navMenuTitles[1],navMenuIcons.getResourceId(1,-1));
//照片
添加(新的NavDrawerItem(navMenuTitles[2],navMenuIcons.getResourceId(2,-1));
//社区,将在此处添加一个计数器
添加(新的NavDrawerItem(navMenuTitles[3],navMenuIcons.getResourceId(3,-1),true,“22”);
//页数
add(新的NavDrawerItem(navMenuTitles[4],navMenuIcons.getResourceId(4,-1));
//什么是热的,我们将在这里加一个计数器
add(新的NavDrawerItem(navMenuTitles[5],navMenuIcons.getResourceId(5,-1),true,“50+”));
//回收类型化数组
navMenuIcons.recycle();
setOnItemClickListener(新的SlideMenuClickListener());
//设置导航抽屉列表适配器
适配器=新的NavDroperListAdapter(getApplicationContext(),
纳维特姆斯);
mDrawerList.setAdapter(适配器);
//启用操作栏应用程序图标并将其作为切换按钮
getActionBar().setDisplayHomeAsUpEnabled(true);
getActionBar().setHomeButtonEnabled(true);
mDrawerToggle=新操作BarDrawerToggle(此,mDrawerLayout,
R.drawable.ic_抽屉,//导航菜单切换图标
R.string.app_name,//导航抽屉打开-可访问性说明
R.string.app_name//nav抽屉关闭-可访问性说明
) {
公共无效onDrawerClosed(视图){
getActionBar().setTitle(mTitle);
//调用onPrepareOptions菜单()以显示操作栏图标
无效操作菜单();
}
打开图纸上的公共空白(视图抽屉视图){
getActionBar().setTitle(mDrawerTitle);
//调用onPrepareOptions菜单()隐藏操作栏图标
无效操作菜单();
}
};
mDrawerLayout.setDrawerListener(mDrawerToggle);
如果(savedInstanceState==null){
//第一个导航项目的首次显示视图
显示视图(0);
}
}

我只想在导航抽屉中的列表末尾添加另一行,与列表的其余部分分开。类似如下:


我认为你应该在线性布局中添加抽屉列表。如下所示

<FrameLayout
android:id="@+id/frame_container"
android:layout_width="match_parent"
android:layout_height="match_parent" />
<LinearLayout
android:id="@+id/ne"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@color/setting_background"
android:orientation="vertical" >

<ListView
    android:id="@+id/list_slidermenu"
    android:layout_width="wrap_content"
    android:layout_height="0dip"
    android:layout_gravity="start"
    android:layout_weight=".85"
    android:background="@color/list_background"
    android:choiceMode="singleChoice"
    android:divider="@color/list_divider"
    android:dividerHeight="1dp"
    android:listSelector="@drawable/list_selector" />

<LinearLayout
    android:layout_width="fill_parent"
    android:layout_height="0dip"
    android:layout_alignParentBottom="true"
    android:layout_below="@+id/newslist_drawer"
    android:layout_weight=".15"
    android:orientation="horizontal" >

    <Button
        android:id="@+id/newslist_done"
        android:layout_width="wrap_content"
        android:layout_height="fill_parent"
        android:layout_weight="0.5"
        android:text="  setting"
        android:visibility="gone" />

    <Button
        android:id="@+id/newslist_cancel"
        android:layout_width="wrap_content"
        android:layout_height="fill_parent"
        android:layout_weight="0.5"
        android:text="  exit"
        android:visibility="gone" />
</LinearLayout>
 </LinearLayout>
     <android.support.v4.widget.DrawerLayout>

  • DrawLayout包含两个子项,一个是主显示,另一个是抽屉,因此您可以将所有内容包装在两个视图组中

  • 像gravity start这样的特殊属性现在需要在相对布局中,因为它现在是抽屉布局的直接子级


  • 响应太晚了!但我刚刚做了一件非常类似的事情,解决了这个问题,根本没有修改xml

    每个抽屉布局都有一个addHeader(视图v)函数和一个addFooter(视图v)函数。它们接受膨胀视图作为参数

    View footer = getLayoutInflater().inflate(R.layout.comic_drawer_footer, null);
    mDrawerLayout = (DrawerLayout) findViewById(R.id.drawer_content);
    mDrawerList = (ListView) findViewById(R.id.bookmark_list);
    mDrawerList.addFooterView(footer);
    

    对于仍在寻找完整答案的人,这里有几点。
    1) 如果将linearlayout或relativelayout添加为容器,请不要忘记将容器布局标记为开始-这是让DroperLayout将容器视为滑动抽屉的关键,否则您将收到错误

    <RelativeLayout
    android:layout_width="240dp"
    android:layout_height="match_parent" 
    android:layout_gravity="start"
    >
    
    3) 至少有3个地方需要使用relativelayout

    mDrawerToggle = new ActionBarDrawerToggle(this, mDrawerLayout,
                R.drawable.ic_drawer, //nav menu toggle icon
                R.string.app_name, // nav drawer open - description for accessibility
                R.string.app_name // nav drawer close - description for accessibility
        ) {
            public void onDrawerClosed(View view) {
                getActionBar().setTitle(mTitle);
                // calling onPrepareOptionsMenu() to show action bar icons
                mDrawerLayout.close(mRelativeLayout); 
                invalidateOptionsMenu();
            }
    
            public void onDrawerOpened(View drawerView) {
                getActionBar().setTitle(mDrawerTitle);
                // calling onPrepareOptionsMenu() to hide action bar icons
                mDrawerLayout.open(mRelativeLayout);
                invalidateOptionsMenu();
            }
        };
    
    最后一个是selectedItem方法调用
    mDrawerLayout.closeDrawer(mContainerLayout);

    我不能100%确定您是否正在尝试向listview添加元素,或者在listview之后添加内容。我的导航抽屉中有一个列表。但是列表从列表的顶部开始,在底部结束。我想在列表的末尾添加一行,但与列表的其余项目分开。您能更具体地说明什么如果你的ListVIEW很短,你会看到页脚实际上只是在屏幕中间浮动。你可以改变抽屉的高度来匹配父母,这样就可以解决这个问题。如果你在一个问题上发表你的问题,我会尽我最大的努力去回答它。我不能帮助你只得到一些信息的评论。这些问题。在我搜索这些主题时,ns已经被问了好几次。人们正在使用包含listview和其他小部件的linearlayout作为解决方案。我的第一次尝试是设置布局高度。这不会成功
    <RelativeLayout
    android:layout_width="240dp"
    android:layout_height="match_parent" 
    android:layout_gravity="start"
    >
    
    RelativeLayout mRelativeLayout;
    public void onCreate(){
    
       mRelativeLayout = ..
    }
    
    mDrawerToggle = new ActionBarDrawerToggle(this, mDrawerLayout,
                R.drawable.ic_drawer, //nav menu toggle icon
                R.string.app_name, // nav drawer open - description for accessibility
                R.string.app_name // nav drawer close - description for accessibility
        ) {
            public void onDrawerClosed(View view) {
                getActionBar().setTitle(mTitle);
                // calling onPrepareOptionsMenu() to show action bar icons
                mDrawerLayout.close(mRelativeLayout); 
                invalidateOptionsMenu();
            }
    
            public void onDrawerOpened(View drawerView) {
                getActionBar().setTitle(mDrawerTitle);
                // calling onPrepareOptionsMenu() to hide action bar icons
                mDrawerLayout.open(mRelativeLayout);
                invalidateOptionsMenu();
            }
        };