首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

从导航抽屉中调用时,Activity为空。But按钮显示填充的活动

从导航抽屉中调用时,Activity为空是因为在调用时没有正确设置Activity的上下文。这可能是由于以下几个原因导致的:

  1. 上下文传递错误:在调用导航抽屉时,需要确保正确传递当前Activity的上下文。可以通过使用getApplicationContext()或者this关键字来获取当前Activity的上下文,并将其传递给导航抽屉的调用方法。
  2. 调用方法错误:确保使用正确的方法来调用导航抽屉。通常,导航抽屉会提供一个方法来打开或关闭抽屉,例如openDrawer()closeDrawer()。确保在调用这些方法时传递正确的Activity上下文。
  3. 布局文件配置错误:检查导航抽屉的布局文件是否正确配置。确保在布局文件中正确引用了导航抽屉的相关组件,并将其与Activity正确关联。

解决此问题的方法是:

  1. 检查代码中是否正确传递了Activity的上下文。例如,可以使用以下方式获取当前Activity的上下文:
代码语言:txt
复制
Context context = getApplicationContext();

或者

代码语言:txt
复制
Context context = this;

然后将其传递给导航抽屉的调用方法。

  1. 确保使用正确的方法来调用导航抽屉。例如,如果要打开导航抽屉,可以使用以下代码:
代码语言:txt
复制
navigationDrawer.openDrawer(GravityCompat.START);

其中,navigationDrawer是导航抽屉的实例。

  1. 检查导航抽屉的布局文件是否正确配置。确保在布局文件中正确引用了导航抽屉的相关组件,并将其与Activity正确关联。例如,在布局文件中可以使用以下代码引用导航抽屉:
代码语言:txt
复制
<androidx.drawerlayout.widget.DrawerLayout
    ...
    android:id="@+id/drawer_layout"
    ...>

    <com.google.android.material.navigation.NavigationView
        ...
        android:id="@+id/navigation_view"
        .../>

    <androidx.constraintlayout.widget.ConstraintLayout
        ...
        android:id="@+id/main_content"
        ...>
        
        <!-- 主要内容布局 -->
        
    </androidx.constraintlayout.widget.ConstraintLayout>

</androidx.drawerlayout.widget.DrawerLayout>

其中,drawer_layout是导航抽屉的ID,navigation_view是导航抽屉的ID,main_content是主要内容布局的ID。

总结: 当从导航抽屉中调用时,Activity为空可能是由于上下文传递错误、调用方法错误或布局文件配置错误导致的。通过检查代码中的上下文传递、调用方法和布局文件配置,可以解决此问题。

腾讯云相关产品推荐:

  • 如果您需要在云上部署应用程序并管理资源,可以使用腾讯云的云服务器(CVM)产品。了解更多信息,请访问:腾讯云云服务器
  • 如果您需要在云上存储和管理数据,可以使用腾讯云的对象存储(COS)产品。了解更多信息,请访问:腾讯云对象存储
  • 如果您需要在云上构建和管理数据库,可以使用腾讯云的云数据库MySQL产品。了解更多信息,请访问:腾讯云云数据库MySQL
  • 如果您需要在云上进行人工智能相关的开发和部署,可以使用腾讯云的人工智能平台(AI)产品。了解更多信息,请访问:腾讯云人工智能平台
页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

Android开发(37) 使用DrawerLayout实现抽屉导航菜单

概述 最近流行 左侧抽屉导航条菜单,知乎,360,QQ都使用了这样导航菜单,我们也了解下: Android Design 流行趋势:Navigation Drawer 导航抽屉 参考这篇文章:http...特点 1.标题栏(或者actionBar) 做有个 菜单图标按钮(三条线或者其他)。一般这样标题栏左侧和右侧都会有图标按钮。如图1所示。...2.点击图标按钮 左侧向右 慢慢退出一个 菜单视图(View),遮盖在 内容页(首页)视图上,同时,产生遮盖层。如图2所示。 实 官方示例 参考自谷歌开发者网站示例,在这个页面可以下载到示例。...MainActivity需要 DrawerLayout 注册一个回事件接口ActionBarDrawerToggle ,这个事件实现者监听器会获得 抽屉弹出(onDrawerOpened)和关闭(...打开后 public void onDrawerOpened(View drawerView) { // 显示导航菜单标题

3.5K00

导航组件概览 | MAD Skills

本系列文章致力于帮助开发者们打造更好现代 Android 开发体验,敬请关注。今天大家发布本系列文章第一篇: 导航 (Navigation) 组件概览。...这一功能并不是使用导航组件库所必须,但它可以帮助集合所有必要模块,从而极大地简化了创建新应用时使用导航流程。 ? 我们将使用这些模板之一 Basic Activity 模板来创建一个新应用。...Basic Activity 模板可以创建两个目的地 点选这些目的地,您可以右边属性表单查看它们相关信息,比如下图中展示了这个目的地使用了 Fragment 类。 ?...该视图现在是不可见,我们需要点击 ActionBar 菜单按钮来将它显示到屏幕上。...应用展示了 NavigationView (抽屉导航栏) 覆盖在 activity 内容上方 接下来是 NavigationView,它是一个左边划入抽屉导航栏。

1.6K30

iOS 与 Android APP 设计差异

在Android应用中被大家熟知导航模式是抽屉和标签形式组合。 抽屉导航其实是一个菜单,通过点击汉堡图标,然后左侧或右侧滑出。...左侧就是抽屉导航;右侧是标签栏 在Material Design还有一个组件叫做底部导航。这个组件对于安卓原生应用来说也非常重要。底部菜单项很容易点击和操作。...但是安卓规范其实不建议同时使用底部导航和标签,因为它可能会在导航时引起混乱。 底部导航(Material Design) 在Apple的人机交互规范,没有类似抽屉菜单标准导航控件。...左边是标准Android按钮;右边是标准iOS按钮 还有一种非常有特点按钮类型——在Android上叫做浮动按钮,在iOS上叫做活动按钮。浮动按钮用来展示应用主要操作。...而在iOS与之类似的按钮则叫做活动按钮,通常会放在底部导航中间 左边是标准iOS活动按钮;右侧是标准Android浮动按钮 IOS与Android底部操作视图差异 在Android中有两种不同类型底部操作视图

3.2K10

深入浅出 NavigationUI | MAD Skills

打造您首个 app bundle | MAD Skills 今天大家发布本系列文章第一篇。...在本文中,我们将为大家讲解另外一个用例,即类似操作栏 (Action Bar)、底部标签栏或者抽屉导航栏之类 UI 组件如何在应用实现导航功能。...△ 标题更新了并且也显示了返回按钮 底部标签栏 目前为止还算顺利,但是应用还不能导航到 coffeeList Fragment。接下来我们将解决这个问题。 我们添加底部标签栏入手。...setupWithNavController(navController) } 现在当我在屏幕较宽设备上运行应用时,可以看到抽屉导航栏已经设置了 MenuItem,并且在导航图中,MenuItem...Donut Tracker 应用并不需要底部标签栏或者抽屉导航栏,但是添加了新功能和目的页面后,NavigationUI 可以很大程度上帮助我们处理应用导航功能。

3K30

Anroid Wear OS 手表应用开发 - UI

,圆形布局内容,不会超过显示边界: 导航抽屉栏 为了节省宝贵显示空间,通常手表应用是没有标题栏,在使用 ViewPager 时候,也没有 TabLayout 显示,但因此我们无法很好的确认当前页面...导航栏 WearableNavigationDrawerView 就是用来解决这个问题,我们先看看它效果: 手表顶部向下滑,会出现一个导航栏,显示当前页面的图标和标题。...操作抽屉栏 当需要对当前页面进行一些操作时候,但页面里又没有空间再放按钮了怎么办?既然可以顶部下拉出导航栏,要不在底部上拉出一个操作栏?...,controller.peekDrawer() 会在底部露出一小部分操作栏,如果当前页面是一个列表,这一部分会在列表滑动时隐藏,在列表到顶部和底部时显示: 露出部分默认会显示操作栏第一项图标,可以在布局添加...自定义抽屉导航栏 WearableNavigationDrawerView 和 操作栏 WearableActionDrawerView 用起来很简单,但是它们样式是固定,一个只能显示图标加标题

2.5K30

Android侧滑菜单之DrawerLayout用法详解

来实现这个功能,完全可以替代SlidingMenu,这里我们来学习DrawerLayout用法 一)创建DrawerLayout 1)在布局文件里将布局设置DrawerLaout,而且因为是v4包功能...,动态添加碎片进入主视图 1)给抽屉列表项添加点击事件,每点击列表项,让其在主内容视图里添加一个Fragment,让这个Fragment里显示点击列表项里内容,先写这个FragmentLayout...里布局,这里让其显示一段文本 <?...,因此要调用invalidateOptionsMenu()会重绘actionBar上菜单项,执行这个方法时候会回onPreareOptionsMenu(),所以我们可以在这里通过判断抽屉处于打开还是关闭状态...既然要隐藏,那么前提是我们得有菜单项,这里先给actionbar添加一个搜索按钮,关于给ActionBar添加按钮办法,在关于ActionBar博客里已经讲过了,所以这里直接操作 res/values

1.9K10

Flutter开发-容器类组件

我们实现一个页面,它包含: 一个导航导航栏右边有一个分享按钮 有一个抽屉菜单 有一个底部导航 右下角有一个悬浮动作按钮 代码如下: class ScaffoldRoute extends StatefulWidget...下面我们看看AppBar定义: AppBar({ Key key, this.leading, //导航栏最左侧Widget,常见抽屉菜单按钮或返回按钮。..., // 导航栏右侧菜单 this.bottom, // 导航栏底部菜单,通常Tab按钮组 this.elevation = 4.0, // 导航栏阴影 this.centerTitle,...//其它属性见源码注释 }) 如果给Scaffold添加了抽屉菜单,默认情况下Scaffold会自动将AppBarleading设置菜单按钮(如上面截图所示),点击它便可打开抽屉菜单。...如果开发者提供了抽屉菜单,那么当用户手指屏幕左(或右)侧向里滑动时便可打开抽屉菜单。

3.5K20

AngularDart Material Design 应用布局 顶

自述 应用布局 应用程序布局是一个样式,指令和组件系统,当它们一起使用时,可以提供材质外观和感知应用程序层叠关系。 它根据材料规格提供应用栏,抽屉导航样式。...material-drawer-button 行一个按钮位于左侧,用于导航。 material-header-title 头部标题。...material-spacer 占用标题和任何导航链接之间空间。 需要在标题之后和任何导航元素之前放置。 material-navigation 导航元素将显示在头部左侧。...-- Content here --> 导航样式 抽屉导航元素样式也由app_layout提供。...当可堆叠抽屉打开时,任何现有的可堆叠抽屉将被展开以填充背景屏幕。 适用于延期内容。 Inputs: visible bool  抽屉可见性。

4K30

Android 8.0 功能和 API(翻译自Google官网)

操作组件纵横比和其他配置设置均由 args 指定。如果 args 任何字段,系统将使用您上次调用 Activity.setPictureInPictureParams() 时所设置值。...如果您应用需要设置最大纵横比,请使用定义您操作组件清单文件 maxAspectRatio 属性。 多显示器支持 Android 8.0 开始,此平台显示器提供增强支持。...以一个包含五个导航键区操作组件例,用户可以使用键盘导航键区快捷键进行导航。键区按以下布局显示:顶部面板、左侧面板、主内容区域、底部面板和浮动操作按钮。...在具有触摸屏设备,您可以将某个键区指定 ViewGroup 对象 android:touchscreenBlocksFocus 元素设置 true,仅允许键区导航进入和离开此键区。...无障碍功能按钮无障碍服务现在可以请求在系统导航区域显示无障碍功能按钮,该按钮让用户可从其设备上任意位置快速激活您服务功能。

2.8K30

Flutter 全栈式——页面框架

按钮text等 localeListResolutionCallback LocaleListResolutionCallback 该回负责在应用启动时以及用户更改设备区域设置时选择应用区域设置...showSemanticsDebugger bool true时,打开Widget边框,显示布局边界 debugShowCheckedModeBanner bool true时,在debug模式下显示右上角... ActionBar body Widget 当前页面所显示主要内容 floatingActionButton Widget Material中所定义FAB,是一个悬浮功能按钮 floatingActionButtonLocation...persistentFooterButtons List 在底部显示一组按钮 drawer Widget 开始部分(左边)抽屉菜单 endDrawer Widget 结束部分(右边...默认为 ThemeData.scaffoldBackgroundColor bottomNavigationBar Widget 显示在底部导航栏 bottomSheet Widget 底部永久性显示提示框

2.8K30

测一测你对「Activity了解

2、Activity生命周期 Activity生命周期直接影响到与用户交互,因此生命周期很重要。当用户浏览、退出和返回到应用时,应用Activity会在其生命周期不同状态间转换。...应用大部分核心功能都是在onResume()方法实现。此类输入事件可包括接到来电、用户导航到另一个Activity,或设备屏幕关闭。...onPause()执行完毕后,下一个回方法onStop()或onResume(),具体取决于 Activity进入“已暂停”状态后发生情况。...onRestart() 当处于“已停止”状态Activity即将重启时,系统就会调用此回。onRestart() 会 Activity停止时状态恢复Activity。...如果Activity位于前台,并且用户点按了返回按钮Activity将依次经历onPause()、onStop() 和onDestroy() 回活动不仅会被销毁,还会返回堆栈移除。

85110

Android开发之Activity创建跳转及传值

Activity Name: 活动名字,Layout Name: 活动对应布局文件名字,Titile: 上面导航显示名字。...下方是添加了一个Button, 并且Button上TextShowToast(Toast是安卓显示信息用组件)。 ?...Go Second Activity按钮就会跳转到第二个Activity,并且把第一个页面值会在第二个Activity中进行显示。...3.返回中Activity获取值 从上面的实例可知,我们可以把值从一个Activity传入到下一个Activity。接下来要做事情刚好相反,是返回页面获取值。...会跳转到ThirdActivity,然后ThirdActivity中点击Back按钮进行返回就会在上一个ActivityTextView上显示ThirdActivity返回值,具体效果如下所示

3.1K100

1.ActionBar

Activity自带actionBar 2.Android3.0(APIlever11)开始,所有使用Theme.Holo主题(或者它子类)activity都包含了actionbar,当 targetSdkVersion...所以,activity添加actionbar,只需简单地设置属性11或者更大。 常用操作: 搜索  Actionbar允许你当前上下文中最重要操作添加按钮。...那些直接出现在actionbaricon和/或文本被称作action buttons(操作按钮)。安排不下或不足够重要操作被隐藏在actionoverflow。...1.所有的操作按钮和actionoverflow其他可用条目都被定义在菜单资源XML文件。通过在项目的res/menu目录 新增一个XML文件来actionbar添加操作。...  在不是主要入口其他所有屏activity不位于主屏时),需要在actionbar用户提供一个导航到逻辑父屏up button(向上按钮)。

91650

1.ActionBar

Activity自带actionBar 2.Android3.0(APIlever11)开始,所有使用Theme.Holo主题(或者它子类)activity都包含了actionbar,当 targetSdkVersion...所以,activity添加actionbar,只需简单地设置属性11或者更大。 常用操作: 搜索 Actionbar允许你当前上下文中最重要操作添加按钮。...那些直接出现在actionbaricon和/或文本被称作action buttons(操作按钮)。安排不下或不足够重要操作被隐藏在actionoverflow。...1.所有的操作按钮和actionoverflow其他可用条目都被定义在菜单资源XML文件。通过在项目的res/menu目录 新增一个XML文件来actionbar添加操作。...在不是主要入口其他所有屏activity不位于主屏时),需要在actionbar用户提供一个导航到逻辑父屏up button(向上按钮)。

57410

Flutter学习

你可以将它类比成为网页html标签,且它自带路由、主题色等功能。 Scaffold Scaffold通常被用作MaterialApp子Widget,它会填充可用空间,占据整个窗口或设备屏幕。..., // floatingActionButton移动到一个新位置时动画 this.persistentFooterButtons, // 多状态按钮 this.drawer, // 左侧抽屉菜单...this.endDrawer, // 右'侧抽屉菜单 this.bottomNavigationBar,// 底部导航栏。...默认值 ThemeData.primaryIconTheme centerTitle 标题是否居中显示,默认值根据不同操作系统,显示方式不一样。...在Flutter导航器管理应用程序路由栈。将路由推入(push)到导航,将会显示更新该路由页面。 导航栈中弹出(pop)路由,将显示返回到前一个路由。

2.6K20

android侧滑菜单控件DrawerLayout使用方法详解

使用步骤: 创建一个DrawerLayout 为了添加导航抽屉,你需要在你布局界面声明一个DrawerLayout对象作为布局根节点。...同时在DrawerLayout内部添加两个view: 添加一个View,它包含应用主内容(当抽屉隐藏时你主要布局); 添加另一个View它包含了导航抽屉; 如下面例子所示:该布局使用了DrawerLayout...主内容View被设置成匹配父View宽和高,因为当导航抽屉隐藏时候它要填充整个UI。...为了满足从右到左约定,声明它”start” 代替 “left”(因此这个抽屉将会在右面呈现当布局是RTL时) 在导航View声明时:宽度用dp单位、高度匹配父View。...为了保证用户无论怎样都能看到主内容一部分,导航抽屉宽度不能超过320dp 初始化Drawer List 在你Activity,要做第一件事是初始化导航抽屉列表项。

2.2K10

Flutter 全栈式——基础控件

需使用Text.rich构造方法创建 Image 构造方法 Image : ImageProvider获取图片 Image.asset :加载资源目录图片 Image.network:加载网络图片...,这9个点其实就是八个方向加上正中 gaplessPlayback bool 当ImageProvider发生变化时,显示新图片过程,如果值true则保留旧图片直至显示出新图片为止;如果false...labelStyle TextStyle 设置labelText样式 helperText String 帮助文本,位于输入框下方,如果errorText则不会显示 helperStyle TextStyle...,则使用fillColor指定颜色填充 fillColor Color 输入框背景颜色 errorBorder InputBorder errorText不为,且输入框没有焦点时要显示边框 focusedBorder...InputBorder 输入框禁用时显示边框,errorText必须 enabledBorder InputBorder 输入框可用时显示边框,errorText必须 border InputBorder

3.8K40

Flutte部件目录-Material Components 顶

实现Material Design指南视觉,行为和运动丰富小部件。 应用程序结构和导航 按钮 输入和选择 对话框,弹出框和面板 信息显示 布局 查看Flutter窗口小部件目录更多小部件。...WidgetsApp 一个便利类,它包装了应用程序通常需要许多小部件。 ? Drawer Material Design面板,展示台边缘水平滑动,以在应用程序显示导航链接。 ?...浮动动作按钮最常用于Scaffold.floatingActionButton字段。 ? FlatButton 平面按钮是在材料组件部件上打印部分,通过填充颜色对触摸作出反应。 ?...IconButton 图标按钮是一个打印在材质小部件上图片,通过填充颜色(墨水)对触摸作出反应。 ?...将按钮封装在工具提示窗口小部件,以便在按下窗口小部件时(或者当用户采取其他适当操作时)显示标签。 ? DataTable 数据表显示一组原始数据。 它们通常出现在桌面企业产品

9.4K40

Python应用开发——30天学习Streamlit Python包进行APP构建(4)

创建 Streamlit 应用时要做第一件事就是将 streamlit 库导入 st,并且导入要用到 requests 库: import streamlit as st import requests...) 然后我们会像下面这样将建议活动显示出来 st.header('Suggested activity') st.info(suggested_activity['activity']) 最后,我们也会显示所建议活动随附信息...材料符号库(轮廓样式)图标,格式":material/icon_name:",其中 "icon_name "是蛇形图标的名称。...# # 解决方法就是创建一个在点击时回按钮 # 我们函数实际上不需要做任何事...# 你可以创建一个函数,或者直接使用不带参数 sync() # # 然后每当你点击按钮时候,onClick 回函数会被调用

13610
领券