iis服务器助手广告广告
返回顶部
首页 > 资讯 > 移动开发 >Android抽屉导航Navigation Drawer实例解析
  • 581
分享到

Android抽屉导航Navigation Drawer实例解析

Android 2022-06-06 08:06:50 581人浏览 八月长安
摘要

我们重点来研究一下Android抽屉导航 NavigationDrawer。先来感性认识一下这种效果吧: 看了很多应用,觉得这种侧滑的抽屉效果的菜单很好。不用切换到另一个页

我们重点来研究一下Android抽屉导航 NavigationDrawer。先来感性认识一下这种效果吧:


看了很多应用,觉得这种侧滑的抽屉效果的菜单很好。不用切换到另一个页面,也不用去按菜单的硬件按钮,直接在界面上一个按钮点击,菜单就滑出来,而且感觉能放很多东西。

最简单就是用官方的抽屉导航 NavigationDrawerLayout 来实现。DrawerLayout这个类是在Support Library里的,需要加上android-support-v4.jar这个包。然后程序中用时在前面导入import android.support.v4.widget.DrawerLayout;

如果找不到这个类,首先用SDK Manager更新一下Android Support Library,然后在Android SDK\extras\android\support\v4路径下找到android-support-v4.jar,复制到项目的libs路径,将其Add to Build Path.

当你新建一个 Android 项目的时候,你可以选择使用 Navigation Drawer:

我们来简要看看代码,首先是 NavigationDrawerFragment.java 这个类,加载了哪些布局文件。


@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
    Bundle savedInstanceState) {
  // 给抽屉ListView找到对应的XML布局
  mDrawerListView = (ListView) inflater.inflate(
      R.layout.fragment_navigation_drawer, container, false);
  // 给抽屉ListView绑定点击监听器,点击时,选中点击的项
  mDrawerListView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
    @Override
    public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
      selectItem(position);
    }
  });
  // 给抽屉ListView绑定一个适配器
  mDrawerListView.setAdapter(new ArrayAdapter<String>(
      getActionBar().getThemedContext(),
      android.R.layout.simple_list_item_activated_1,
      android.R.id.text1,
      new String[]{
          getString(R.string.title_section1),
          getString(R.string.title_section2),
          getString(R.string.title_section3),
          getString(R.string.title_section4),
          getString(R.string.title_section5),
      }));
  //mDrawerListView.setAdapter(new DrawerAdapter(getActivity()));
  // 设置抽屉ListView以显示某一选中项的形态出现。
  mDrawerListView.setItemChecked(mCurrentSelectedPosition, true);
  // 将处理后的抽屉ListView返回
  return mDrawerListView;
}

NavigationDrawer 主要是一个 ListView,这个 ListView 使用了 fragment_navigation_drawer.xml:


<ListView xmlns:android="Http://schemas.android.com/apk/res/android"
  xmlns:tools="http://schemas.android.com/tools"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:background="@color/image_bg_green"
  android:choiceMode="singleChoice"
  android:divider="@color/image_bg_lightgreen"
  android:dividerHeight="1dp"
  tools:context="net.nowamagic.magicapp_v7.NavigationDrawerFragment" />

这个 ListView 就是抽屉导航直观上看到的那个 ListView。同时 ListView 里面每个格子都由一个相对布局填充,其 XML 为 fragment_main.xml:


<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  xmlns:tools="http://schemas.android.com/tools"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:paddingBottom="@dimen/activity_vertical_margin"
  android:paddingLeft="@dimen/activity_horizontal_margin"
  android:paddingRight="@dimen/activity_horizontal_margin"
  android:paddingTop="@dimen/activity_vertical_margin"
  tools:context="net.nowamagic.magicapp_v7.MainActivity$PlaceholderFragment" >
  <TextView
    android:id="@+id/section_label"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content" />
</RelativeLayout>

新建一个基于 NavigationDrawer 的项目,大概效果如下:

您可能感兴趣的文章:Android 自定义View实现抽屉效果Android自定义控件仿QQ抽屉效果Android DrawerLayout实现抽屉效果实例代码Android 抽屉效果的导航菜单实现代码实例Android实现自定义滑动式抽屉效果菜单Android App中DrawerLayout抽屉效果的菜单编写实例Android SlidingDrawer 抽屉效果的实现Android实现3种侧滑效果(仿qq侧滑、抽屉侧滑、普通侧滑)Android实现右边抽屉Drawerlayout效果Android组件之DrawerLayout实现抽屉菜单Android提高之多方向抽屉实现方法Android编程实现抽屉效果的方法详解


--结束END--

本文标题: Android抽屉导航Navigation Drawer实例解析

本文链接: https://www.lsjlt.com/news/24962.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Drawer Builder组件实现flutter侧边抽屉效果示例分析
    目录前言Drawer 与 UserAccountsDrawerHeader定制唤出按钮并引出 Builder 组件整体代码最后前言 平时开发中难免会碰到抽屉效果,如果自己写肯定要费一...
    99+
    2022-11-13
    Drawer Builder flutter侧边抽屉 flutter侧边抽屉
  • Android中导航组件Navigation的实现原理
            对于导航组件的使用方式不是本文的重点,具体使用可以参考官方文档,导航组件框架是通过fragment来实现的,其核心类主要可以分...
    99+
    2024-04-02
  • Android实现底部导航栏方法(Navigation篇)
    Navigation实现底部导航栏 前言导入和基本使用导入基础使用创建nav文件编辑Nav文件添加页面(代码版)添加页面(图解版) 创建导航动作 action创建action(代码版)...
    99+
    2023-10-10
    android
  • 一文详解Jetpack Android新一代导航管理Navigation
    目录前言创建导航视图添加NavHost导航findNavControllerToolBar总结前言 不知道小伙伴们是否注意到,用AS创建一个默认的新项目后,MainActivity...
    99+
    2023-03-15
    Jetpack Android导航管理Navigation Jetpack Android
  • HTML导航栏实例分析
    本篇内容主要讲解“HTML导航栏实例分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“HTML导航栏实例分析”吧! 导航栏 = 链接列表 导航栏需要标准的 ...
    99+
    2024-04-02
  • Android侧滑导航栏的实例代码
    今天学习的新内容是侧滑导航栏,我想大家肯定都比较熟悉了,因为这个效果在qq里面也有,最近一直跟室友们玩的游戏是快速让自己的头像的点赞量上千。当然我的效果跟qq是没有办法比的,因为那里面的功能是在是太强大了。下面我来展示一下我做的效果截图。我...
    99+
    2023-05-31
    android 侧滑 导航栏
  • Android 中ActionBar+fragment实现页面导航的实例
    Android 中ActionBar+fragment实现页面导航的实例为保证android2.0以上均能运行,使用support.v7库下的actionbar及fragment继承自AppCompatActivity(ActionBarA...
    99+
    2023-05-30
    android actionbar fragment
  • ANDROID BottomNavigationBar底部导航栏的实现示例
    第一种介绍的就是使用开源库,因为使用开源库最简单,也更加的符合我们的审美标准,同时BottomNavigationBar还是符合当前的Material Design标准的。效果展示依赖compile'com.ashokvarma.andro...
    99+
    2023-05-30
    android bottomnavigationbar ott
  • Vue Router4路由导航守卫实例全面解析
    目录前言一、什么是导航守卫二、全局前置守卫可选的第三个参数 next三、全局解析守卫四、全局后置钩子五、路由独享的守卫六、组件内的守卫可用的配置 API使用组合 API七、...
    99+
    2022-11-16
    Vue Router4路由导航 Vue Router
  • WPF中的导航框架实例分析
    本篇内容主要讲解“WPF中的导航框架实例分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“WPF中的导航框架实例分析”吧!有的时候,我们需要一个支持页面跳转的UI,例如文件浏览器,开始向导等。对...
    99+
    2023-07-02
  • Android开发快速实现底部导航栏示例
    目录Tint 着色器依赖(AndroidX)布局编写渲染颜色选择器-tint_selector_menu_colormenu 文件中 icon-nav_bottom_menuBott...
    99+
    2024-04-02
  • Android实现字母导航控件的示例代码
    目录自定义属性Measure测量坐标计算绘制Touch事件处理数据组装显示效果今天分享一个以前实现的通讯录字母导航控件,下面自定义一个类似通讯录的字母导航 View,可以知道需要自定...
    99+
    2024-04-02
  • Android编程实现的简易路径导航条功能示例
    本文实例讲述了Android编程实现的简易路径导航条功能。分享给大家供大家参考,具体如下:这里要实现的是如图所示的路径导航条, 类似于文件管理器的效果。该导航条包含三个功能: 支持追加任意个子路径(文字一行写不下时可左右滑动);2. 支持返...
    99+
    2023-05-31
    android 路径 导航
  • 浅析php怎么实现滚动隐藏导航(代码示例)
    在网页设计中,导航栏是网页的一个重要组成部分之一,其作用是方便用户访问不同页面和功能。然而,对于一些需要保持页面美观性和简洁性的项目,通常会采用滚动隐藏导航。这种技术既可以改善用户体验,也可以节省页面空间。在本文中,将分享一些基于PHP语言...
    99+
    2023-05-14
  • jQuery实现电梯导航案例详解(切换 网页区域)
    目录前言:一:效果展示二:实现原理剖析  2.1 网页结构: 2.2 显示隐藏函数 实现分析: 2.3 点击导航滚至对应板块 实现分析:&nb...
    99+
    2024-04-02
  • 解析Android AIDL的实例与原理
    目录一、概述二、创建 .aidl 文件三、生成 .java 文件四、传输复杂数据五、建立 service六、获取服务七、分析调用过程一、概述 简单来说,AIDL 就是定义一个接口,客...
    99+
    2024-04-02
  • 实例讲解Vue怎么实现左侧导航栏右侧标签页功能
    Vue是一款流行的JavaScript框架,它可以用于创建强大的Web应用程序。在本文中,我们将介绍如何使用Vue实现左侧导航栏右侧标签页。首先,我们需要创建一个Vue实例,以便我们可以使用Vue的组件和指令。我们可以通过使用Vue-cli...
    99+
    2023-05-14
  • Android使用OKHTTP解析JSON数据的实例代码
    为了代码重用,我们首先封装一个类。这个类是HttpUtilHttpUtil.javapackage com.example.asus.networktest; import okhttp3.OkHttpClient;import okhtt...
    99+
    2023-05-31
    okhttp json roi
  • Android NFC开发详解 总结和NFC读卡实例解析
    文章目录 前言一、什么是NFC?二、基础知识1.什么是NDEF?2.NFC技术的操作模式3.标签的技术类型4.实现方式的分类5.流程 三、获取标签内容1.检查环境2.获取NFC标签2.1 Manifest中注册的方式获取Tag2...
    99+
    2023-08-24
    android 物联网 嵌入式硬件 android studio java
  • android多开器解析与检测实现方法示例
    目录多开理论基础多开实现原理解析代码实现:多开包名代码实现:多用户总结多开理论基础 app多开常用于做一些不合法的事情,如高羊毛,黑灰产,甚至会对app的功能做破坏修改。因此多开在...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作