【AndroidUI设计】主界面设计-Toolbar的简单使用

news/2024/10/30 19:24:58/

文章目录

    • 一、引言
    • 二、了解
    • 三、编码
      • 1、UI设计
      • 2、编码

一、引言

  • 描述:需要设计一个主界面,菜单通过主界面的左边界划入,实现点击跳转修改主界面内容的一个效果,并且点击非内容区域恢复原界面的一个效果。做到菜单的弹出,其实还可以加难度,通过向右滑动实现菜单的弹出。这里就作为一个思考问题,其实在我之前的几篇博客里都有使用到这个方法,就看看初学者有没有仔细去了解那些代码,与其双手奉上,不是自己创造
  • 知识点:Toolbar的使用
  • 难度:简单
  • 效果
    在这里插入图片描述

二、了解

       用于应用程序内容的标准工具栏(图片截取自官网关于Toolbar的介绍)。其主要元素组合:导航按钮、品牌徽标图像、标题和副标题、标题和副标题、可选溢出菜单。

  • 导航按钮:向上箭头、导航菜单切换、关闭、折叠、完成或应用选择的其他字形。
  • 品牌徽标图像:延伸到条形的高度,并且可以任意宽。
  • 标题和副标题:是工具栏在导航层次结构中的当前位置以及其中包含的内容的路标
  • 自定义视图:可以向工具栏添加任意子视图,它们将显示在布局中的此位置。
  • 可选溢出菜单:提供一些频繁、重要或典型的操作

在这里插入图片描述

三、编码

1、UI设计

       关于菜单内容,我就随便添加了几个按钮和图片,进行修饰一下,如果需要设计的精美可以查看同栏目下的【AndroidUI设计】个人信息界面 这篇博客,进行进一步的个性化设计。

<?xml version="1.0" encoding="utf-8"?>
<androidx.drawerlayout.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"xmlns:app="http://schemas.android.com/apk/res-auto"android:id="@+id/drawerlayout_drawer"><RelativeLayoutandroid:id="@+id/drawerlayout_main_layout"android:layout_width="match_parent"android:layout_height="match_parent"><androidx.appcompat.widget.Toolbarandroid:id="@+id/drawer_layout_rl_toolbar"android:layout_width="match_parent"android:layout_height="wrap_content"><TextViewandroid:id="@+id/title_name"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="XXX软件"/></androidx.appcompat.widget.Toolbar><TextViewandroid:id="@+id/main_text"android:layout_width="match_parent"android:layout_height="match_parent"android:gravity="center"android:text="主界面"android:textColor="@color/colorAccent"android:textSize="22sp" /></RelativeLayout><LinearLayoutandroid:id="@+id/drawerlayout_side_tv"android:layout_width="200dp"android:layout_height="match_parent"android:layout_gravity="left"android:orientation="vertical"><!--    菜单内容    --><ImageViewandroid:layout_width="200dp"android:layout_height="200dp"android:background="@drawable/b"/><Buttonandroid:id="@+id/user"android:layout_width="match_parent"android:layout_height="wrap_content"android:textSize="25dp"android:text=">我的账号"/><Buttonandroid:id="@+id/shezhi"android:layout_width="match_parent"android:layout_height="wrap_content"android:textSize="25dp"android:text=">设置"/><Buttonandroid:id="@+id/cy"android:layout_width="match_parent"android:layout_height="wrap_content"android:textSize="25dp"android:text=">创意"/></LinearLayout>
</androidx.drawerlayout.widget.DrawerLayout>

2、编码

       关于Toolbar和ActionBar的使用,请参考官方给出的方案。因为最近有点忙,就不进行详细介绍了,直接copy即可(可以直接使用)。

  • 控件初始化

       控件的绑定我就不详细讲了,这在前几篇博客已经讲烂了,始终记住代码规范,主要是方便定位bug位置和简化代码排列。

	private DrawerLayout drawerLayout;private Button user,shezhi,cy;private TextView title, main;// 初始化代码private void init() {user = findViewById(R.id.user);shezhi = findViewById(R.id.shezhi);cy = findViewById(R.id.cy);title = findViewById(R.id.title_name);main = findViewById(R.id.main_text);}
  • 导航控制

       侧滑菜单的一个控制部分,分别导航按钮的显示和隐藏、内容的切换(这里只是简单的将内容进行了更替,至于具体设计则看需求如何)

	private void initToolbar() {final Toolbar toolbar = findViewById(R.id.drawer_layout_rl_toolbar);setSupportActionBar(toolbar);                   //传入ToolBar实例ActionBar actionBar = getSupportActionBar();    //得到ActionBar实例if (actionBar != null){//显示导航按钮actionBar.setDisplayHomeAsUpEnabled(true);//设置导航按钮图片actionBar.setHomeAsUpIndicator(R.drawable.j5);}drawerLayout = findViewById(R.id.drawerlayout_drawer);//设置toolbar的导航按钮监听事件toolbar.setNavigationOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View view) {//显示侧滑菜单drawerLayout.openDrawer(GravityCompat.START);}});user.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {title.setText("我的账号");main.setText("我的账号");}});shezhi.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {title.setText("设置");main.setText("设置");}});cy.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {title.setText("创意");main.setText("创意");}});}
  • onCreate

生命周期-初始化,仅有一次运行

    @Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);init();initToolbar();}

http://www.ppmy.cn/news/513120.html

相关文章

LLM系列 |10: 如何编写思维链Prompt?以智能客服为例

简介 黄梅时节家家雨&#xff0c;青草池塘处处蛙。 小伙伴们好&#xff0c;我是微信公众号《小窗幽记机器学习》的小编&#xff1a;卖红枣粽的小女孩。紧接前面几篇ChatGPT Prompt工程系列文章&#xff1a; 04:ChatGPT Prompt编写指南05:如何优化ChatGPT Prompt&#xff1f;…

NUCLEO-F411RE RT-Thread 体验 (8) - GCC环境 TIM定时器的驱动移植以及基本使用

NUCLEO-F411RE RT-Thread 体验 (8) - GCC环境 TIM定时器驱动移植与基本使用 驱动移植 定时器驱动文件位于drv_hwtimer.c中&#xff0c;对应components层的文件位于rt-thread/components/drivers/hwtimer/hwtimer.c中。 修改Makefile&#xff0c;将其编译进去。 在rtconfig.h…

网络打印机打印超慢或者打印不出的问题解决方法

网络打印机打印超慢或者打印不出 1。检查打印服务器本地打印是否正常 如果本地打印不出&#xff0c;检查打印机硬件是否完好&#xff0c;打印机与计算机连接线是否有断裂&#xff0c;重新安装打印驱动。 2。检查网络连接是否正常&#xff0c;是否能连通打印服务器 如果不能…

2021-11-11

安装SSMS时提示安装失败&#xff0c;证书已被颁发者直接吊销(0x800B010C)解决方法 网上有教程说下载什么什么软件解决的&#xff0c;最后也没解决。其实没那么复杂&#xff0c;直接到官网下载个新版本安装就可以了。点击这里获取官方下载地址。 找到需要的语言下载就可以&#…

Mac打印机提示“光电导元件已报废”无法打印

问题原因 驱动不匹配&#xff0c;去官网下载驱动&#xff0c;然后重新添加打印机即可。 注意事项 重新添加打印机的时候&#xff0c;不要通过ip添加。 直接通过安装好的驱动来添加即可。

打印机添加或者设置流程

作者&#xff1a;蓝眼泪 这里以震旦打印机的添加作为参考 环境准备&#xff1a;xp&#xff0c;win7或者win10操作系统&#xff0c;震旦打印机驱动。 1 开始 运行 输入命令 control 2 选择类别&#xff0c;打印机 3 添加打印机-我需要的打印机未列出&#xff0c;tcp/it,下一步…

win10系统安装打印机失败如何解决?

驱动人生说道&#xff0c;随着win10系统的普及&#xff0c;越来越多的小伙伴用上了win10系统。基本你win10安装好系统之后就能自动帮你打好驱动了&#xff0c;不需要你自己去安装驱动 但是&#xff0c;小编还是用的win7&#xff0c;因为习惯问题感觉用win10挺变扭的&#xff0…

Django操作MySQL数据库的优化方法

Django 是一个很流行的 Web 框架&#xff0c;而 MySQL 是常用的关系型数据库之一。在使用 Django 开发 Web 应用时&#xff0c;我们经常需要使用 MySQL 存储数据&#xff0c;因此如何加速 MySQL 是我们需要关注的问题。本文将介绍一些方法来优化 Django 中 MySQL 的性能。 使用…