用fragment制作导航栏

时间: 2023-10-10 09:08:56 浏览: 33
1. 创建一个新的Android项目,并在项目中添加一个Navigation Drawer Activity。 2. 打开activity_main.xml文件,在其中添加以下代码: ``` <androidx.drawerlayout.widget.DrawerLayout android:id="@+id/drawer_layout" android:layout_width="match_parent" android:layout_height="match_parent"> <!-- The main content view --> <FrameLayout android:id="@+id/main_content" android:layout_width="match_parent" android:layout_height="match_parent" /> <!-- The navigation drawer --> <ListView android:id="@+id/nav_drawer" android:layout_width="240dp" android:layout_height="match_parent" android:layout_gravity="start" android:background="#FFFFFF" /> </androidx.drawerlayout.widget.DrawerLayout> ``` 这里我们使用DrawerLayout作为主布局,其中包含一个FrameLayout和一个ListView。 3. 创建一个新的Fragment,用于显示导航栏中的选项。在项目中右键点击app文件夹,选择New -> Fragment -> Fragment (Blank)。输入一个名称,如NavFragment。 4. 打开NavFragment.java文件,在其中添加以下代码: ``` public class NavFragment extends Fragment { private ListView mListView; public NavFragment() { // Required empty public constructor } @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { // Inflate the layout for this fragment View view = inflater.inflate(R.layout.fragment_nav, container, false); // Initialize the ListView mListView = view.findViewById(R.id.nav_list); // Create an ArrayAdapter to populate the ListView ArrayAdapter<String> adapter = new ArrayAdapter<String>(getActivity(), android.R.layout.simple_list_item_1, new String[]{"Option 1", "Option 2", "Option 3"}); // Set the adapter for the ListView mListView.setAdapter(adapter); return view; } } ``` 这里我们创建了一个名为NavFragment的Fragment,其中包含一个ListView,用于显示导航栏中的选项。我们在onCreateView()方法中初始化ListView,并使用一个ArrayAdapter来填充它。 5. 打开fragment_nav.xml文件,在其中添加以下代码: ``` <ListView xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/nav_list" android:layout_width="match_parent" android:layout_height="match_parent" /> ``` 这里我们只需要一个ListView,用于显示导航栏中的选项。 6. 回到activity_main.xml文件,找到DrawerLayout中的ListView,并将它的android:id属性修改为@+id/nav_drawer。然后,在MainActivity.java文件中添加以下代码: ``` public class MainActivity extends AppCompatActivity { private DrawerLayout mDrawerLayout; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); // Initialize the DrawerLayout mDrawerLayout = findViewById(R.id.drawer_layout); // Initialize the ActionBarDrawerToggle ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(this, mDrawerLayout, R.string.navigation_drawer_open, R.string.navigation_drawer_close); mDrawerLayout.addDrawerListener(toggle); toggle.syncState(); // Add the NavFragment to the navigation drawer getSupportFragmentManager().beginTransaction() .add(R.id.nav_drawer, new NavFragment()) .commit(); } } ``` 这里我们首先初始化DrawerLayout,并创建一个ActionBarDrawerToggle对象,用于处理导航栏的开/关事件。然后,我们通过getSupportFragmentManager()方法向NavFragment添加了一个实例。 7. 运行应用程序,你将看到一个带有导航栏的页面。单击导航栏中的选项,你将看到相应的内容显示在主内容区域中。

相关推荐

最新推荐

recommend-type

Android使用fragment实现左侧导航

主要为大家详细介绍了Android使用fragment实现左侧导航,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

Android 使用Fragment模仿微信界面的实例代码

自从Android 3.0中引入fragments 的概念,根据词海的翻译可以译为:碎片、片段。其目的是为了解决不同屏幕分辩率的动态和...下面通过本文给大家分享Android 使用Fragment模仿微信界面的实例代码,需要的的朋友参考下吧
recommend-type

AndroidX下使用Activity和Fragment的变化详解

主要介绍了AndroidX下使用Activity和Fragment的变化详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
recommend-type

Android使用TabLayout+Fragment实现顶部选项卡

本文通过实例代码给大家介绍了Android使用TabLayout+Fragment实现顶部选项卡功能,包括TabLyout的使用,感兴趣的朋友参考下本文吧
recommend-type

Android中Fragment管理及重叠问题的解决方法

最近做项目碰到了Fragment重叠的问题,后来通过种种方法得以解决了,所以想着总结下这个问题的解决方法,以及Android中Fragment的管理,方便自己也给有需要的朋友们提供以帮助,感兴趣的朋友们下面通过这篇文章一...
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

机器学习怎么将excel转为csv文件

机器学习是一种利用计算机算法和统计数据的方法来训练计算机来进行自动学习的科学,无法直接将excel文件转为csv文件。但是可以使用Python编程语言来读取Excel文件内容并将其保存为CSV文件。您可以使用Pandas库来读取Excel文件,并使用to_csv()函数将其保存为CSV格式。以下是代码示例: ```python import pandas as pd # 读取 Excel 文件 excel_data = pd.read_excel('example.xlsx') # 将数据保存为 CSV 文件 excel_data.to_csv('example.csv', index=
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。