对于没有相关基础的人,在正式学习App的UI之前,建议先了解Material Design相关的知识 关于Material Design设计风格的资料 MaterialApp MaterialApp代表使用...用于指定当前App打开时显示的页面 routes Map 路由表,定义页面跳转规则 initialRoute String 初始路由名称 onGenerateRoute...debug横幅 debugShowMaterialGrid bool debug模式下是否显示Material网格 // 在构建UI前,设置一些属性 MaterialApp( builder...,将整个页面分为如下的几个部分 [l0p8slqyns.jpeg] Scaffold属性 属性 类型 简述 appBar PreferredSizeWidget 界面顶部的一栏控件,相当于 Android...drawer Widget 开始部分的(左边)抽屉菜单 endDrawer Widget 结束部分的(右边)抽屉菜单 drawerScrimColor Color 打开侧滑菜单时遮盖在主要内容区的蒙层颜色
flutter简介Flutter是谷歌的移动UI框架,可以运行在ios与android系统上,可以以完成app的开发,使用情况页面大多数涉及到flutter 开发的app 都是混合开发,占比并不多。...GPU和UI曲线图,可即时查看当前流畅度情况19. checkerboardRasterCacheImages当为true时,打开光栅缓存图像的棋盘格20. checkerboardOffscreenLayers...当为true时,打开呈现到屏幕位图的层的棋盘格21. showSemanticsDebugger当为true时,打开Widget边框,类似Android开发者模式中显示布局边界22. debugShowCheckedModeBanner...当为true时,在debug模式下显示右上角的debug字样的横幅,false即为不显示Scaffold 有下面几个主要属性:appBar - 显示在界面顶部的一个 AppBar。...drawer - 抽屉菜单控件。backgroundColor - 内容的背景颜色,默认使用的是 ThemeData.scaffoldBackgroundColor 的值。
推荐将 Navigation drawer 用于: ·具有五个或更多一级页面的 app ·具有两个或更多级导航层次结构的 app ·快速导航不相关的目的地 ? 超过5个一级页面时使用 ?...如果优先考虑进行帐户切换,则可以将帐户切换器放置在导航抽屉的 header 区域 ?...行为 滚动 Navigation drawers 可以垂直滚动,独立于屏幕内容和 UI 的其余部分。...·如果抽屉内容低于屏幕高度的50%,则 drawer 全部打开 ·如果 drawer 内容大于屏幕高度的50%,请先将其打开至50%,然后允许用户将 drawer 向上拖动至其全高或屏幕高度(以先到者为准...滚动 Bottom navigation drawers 一旦打开至全屏高度,就可以在内部滚动。 当最初打开到屏幕高度的50%时,在显示其他项目之前,必须将 drawer 拖到屏幕高度。
一、项目背景 在现代应用中,导航是关键元素,特别是使用侧边栏(Drawer Menu)切换不同页面的场景。...:ui:$compose_version") implementation("androidx.compose.material3:material3:$compose_version")...2.4 开发DrawerMenu UI DrawerMenuApp 是应用的核心,它通过 ModalNavigationDrawer 和 Scaffold 组件构建侧边菜单布局和顶部应用栏: @Composable...在点击菜单项时,会关闭抽屉并切换到对应的页面内容。 2.5 定义Drawer菜单项内容 DrawerContent 负责展示菜单项内容。...ModalDrawerSheet (1) 场景:ModalDrawerSheet 是最常见的 Drawer 类型,用于显示在应用的内容之上,当 Drawer 打开时,主界面会被覆盖,需要用户手动关闭或点击其他地方来收起抽屉
剪裁Widget 作用 ClipOval 子组件为正方形时剪裁为内贴圆形,为矩形时,剪裁为内贴椭圆 ClipRRect 将子组件剪裁为圆角矩形 ClipRect 剪裁子组件到实际占用的矩形大小(溢出部分剪裁...//其它属性见源码注释 }) 如果给Scaffold添加了抽屉菜单,默认情况下Scaffold会自动将AppBar的leading设置为菜单按钮(如上面截图所示),点击它便可打开抽屉菜单。...如果开发者提供了抽屉菜单,那么当用户手指从屏幕左(或右)侧向里滑动时便可打开抽屉菜单。...抽屉菜单页由顶部和底部组成,顶部由用户头像和昵称组成,底部是一个菜单列表,用ListView实现 FloatingActionButton FloatingActionButton是Material设计规范中的一种特殊...Button,通常悬浮在页面的某一个位置作为某种常用动作的快捷入口 SafeArea 使用 SafeArea 可以让 child widget 在顶部和底部腾出足够的空间方便处理 iPhoneX 这类的手机
最后,将打开/关闭抽屉动作连系到抽屉。使用引用变量语法最容易完成。持久抽屉指令将其自身导出为抽屉,这允许其它操作可以轻松使用它。toggle()可用于打开/关闭抽屉。...抽屉支持deferredConent指令,允许开发人员在抽屉不可见(关闭)时从页面添加/删除内容。...临时抽屉具有可选的overlay属性,可用于在抽屉打开时在非抽屉内容上方显示透明覆盖。...当可堆叠抽屉打开时,任何现有的可堆叠抽屉将被展开以填充背景中的屏幕。 适用于延期内容。 Inputs: visible bool 抽屉的可见性。...isExpanded bool 当抽屉扩展到全屏时,“True”。 Outputs: visibleChange Stream 抽屉的可见性发生变化时触发事件。
现在,多数标注工具都支持 dp 标注功能,比如 MarkMan,如果UI设计者是按照1280*720的尺寸设计的效果图,在标注时选择xhdpi即可: 编辑 使用 MarkMan 进行 dp 标注 DP...示例中呈现的分隔线是一种弱规则,弱到不会去打扰到用户对内容的关注。 编辑 列表中有头像、图片等元素时,使用内嵌分隔线,左端与文字对齐。 ...编辑 滚动时,如果列表较长,小标题会固定在顶部,直到下一个小标题将它顶上去。 编辑 存在浮动按钮时,小标题要让出位置,与文字对齐。 ...手机端的侧边抽屉距离屏幕右侧56dp。 编辑 侧边抽屉支持滚动。如果内容过长,设置和帮助反馈可以固定在底部。抽屉收起时,会保留之前的滚动位置。 ...编辑 编辑 列表较短不需要滚动时,设置和帮助反馈跟随在列表后面。
它可用于容纳搜索字段、以及在页面之间导航的按钮,或者只是页面标题。由于它是一个如此常用的组件,因此 Flutter 为该功能提供了一个名为AppBar的专用小部件。...Flutter AppBar 是根据Material Design指南构建的应用程序组件。它通常位于屏幕顶部,并且能够在其布局中包含其他小部件。...示例包括返回上一页的导航箭头或打开抽屉的菜单图标。 当上一条路线可用时,导航箭头会自动出现。...添加Drawer到Scaffold时 ,会分配一个菜单图标leading来打开抽屉。...背景颜色 以下代码将 AppBar 的背景颜色更改为深橙色。500添加以访问颜色的特定阴影,900即最暗和最亮50。
配置抽屉组件 1. drawer 左侧抽屉。值的类型为Widget; 2. endDrawer 右侧抽屉。...抽屉头 DrawerHeader 常见的属性如下: 1. decoration 装饰。可用于设置背景颜色和图片,值的类型为BoxDecoration; 2. child 子组件。...Expanded( child:TabBar( // 多个标签时滚动加载...), ], ) ) ); } } 在抽屉中进行路由跳转后返回页面时...,可以先调用 Navigator.of(context).pop() 关闭之前打开的效果。
iOS默认在底部,安卓默认在顶部 swipeEnabled:是否允许在标签之间进行滑动 animationEnabled:是否在更改标签时显示动画 lazy:是否在app打开的时候将底部的标签栏全部加载...下面可以来做导航的跳转操作 为了实现跳转操作的功能,需要先新建一个页面,并且将这个页面添加到导航中去。 导入页面到App.js文件 import ChatScreen from '....定义抽屉导航 HomeScreen与MineScree是导入外界的两个界面,将它们定义到DrawerNavigator中。在抽屉导航中,将组件的属性也一起设置好。...: '#fff', // 未选中背景颜色 style: { // 样式 } } } ); 在render方法中返回抽屉组件 export...如果指定的是DrawerOpen,意思就是打开抽屉。
实现教程 XWCatergoryView - 一个轻量级的顶部分类视图控件,只需要通过简单的设置,你就可以快速集成该控件,控件目前暂时有底部横条移动,椭圆背景移动,文字缩放,文字颜色变化和文字颜色渐变五种效果...其他UI AwesomeMenu - 最多人用的路径菜单。 DCPathButton - Path,4.0的弹出菜单,呼出或者关闭菜单时,多个小图标会分别按照逆时针和顺时针的方向进行滚动。...iOS Material Design库 - 该项目借鉴于谷歌的Material Design guideline,用户可自定义背景色。...MediumScrollFullScreen - Medium的可扩展滚动页面,上下滚动时,全屏显示内容,并自然消隐上下菜单。...仿LOL滚动视图 - 仿LOL滚动视图。 答案选择切换页 - 将scrollview和tableview封装在一起,在初始的时候简单的将数据带上,就可以一页一页的左右来回滑动。
2、FAB 在尾部 ? 在需要 FAB 和三到四个附加操作的手机屏幕上使用FAB 3、无 FAB ?...滚动 滚动时, bottom app bar 可以出现或消失: 向下滚动隐藏 bottom app bar, 如果有FAB,则它会脱离 bar 并保留在屏幕上。...当 bar 脱离FAB时,会恢复到默认的形状。 在返回到屏幕并重新附着 FAB 后,bar 重新获得了缺口形状。 ? ---- 海拔 Bottom app bar 的海拔高度为8dp。...底部的导航抽屉从底部的应用栏打开。 抽屉在底部应用程序栏前打开,并显示顶部应用程序栏以在达到完整高度时关闭抽屉。...Drawer 在 bottom app bar 前面打开,并显示 top app bar 以在达到完整高度时关闭抽屉。
Part1:什么是Material design 自2014年谷歌在I/O大会发布Material Design,至今已经两年多,其遵循纸片与墨水的视觉设计,并将物理运动带入到UI设计中,google...因为Material Design本是一种考虑事物本质的设计,将电子屏幕里的UI元素看成是一种不存在于现实世界的新的材质,并赋予它类似纸片与墨水的物理特性。...高度包含了静态高度与组件高度,一般UI高度是个固定值,只有状态不一致可能上下移动,但是在变化过后都会自动恢复到自身的静态高度。下面的图表对比了多种元素的静止高度和动态高度偏移。 ?...enterAlwaysCollapsed:当你的视图已经设置minHeight属性又使用此标志时,你的视图只能以最小高度进入,只有当滚动视图到达顶部时才扩大到完整高度。 ...中利用DrawerToggle.syncState()和actionbar相关联,将开关的图片显示在了action上,如果不设置,也可以有抽屉的效果,不过是默认的图标 ActivityOptionsCompat
移动开发中,drawerLayout抽屉视图是比较常用的一种控件。一般将用户的头像,用户名等信息在抽屉视图中呈现。 drawer中也可以提供一些选项,比如跳转去设置页,跳转去用户资料页面等等。...Flutter提供了Drawer组件;结合ListView等组件,开发者可以快速地制作出抽屉视图。...使用material中的UserAccountsDrawerHeader 使用material中的UserAccountsDrawerHeader,设置accountName和currentAccountPicture...DrawerHeader设置padding为0,充满整个顶部 DrawerHeader的child使用Stack,目的是放置背景图片 在Stack偏左下的位置放置头像和用户名 先用Align确定对齐方式为...同一个UI效果,做法也不止一种。
由于矩阵变化只会作用在绘制阶段,所以在某些场景下,在UI需要变化时,可以直接通过矩阵变化来达到视觉上的UI改变,而不需要去重新触发build流程,这样会节省layout的开销,所以性能会比较好。...icon: Icon(Icons.share) ) ], ), 效果图如下: undefined 代码中打开抽屉菜单的方法在...如果开发者提供了抽屉菜单,那么当用户手指从屏幕左(或右)侧向里滑动时便可打开抽屉菜单。...,然后将浮动按钮至于底部导航栏中间,以达到下面的效果: undefined 5.6 页面body 最后就是页面的 Body 部分了,Scaffold 有一个 body...属性,接收一个 Widget,我们可以传任意的 Widget ,在后面介绍滑动组件时,会涉及到 TabBarView,它是一个可以进行页面切换的组件,在多 Tab 的 App 中,一般都会将 TabBarView
,在 UI 需要变化是,可以通过矩阵变换来达到视觉上的 UI 变化,而不是重新 build 流程,这样会节省 layout 的开销,所以性能会比较好,例如 Flow 组件,内部就是使用矩阵变换来更新 UI...幸运的是 Flutter Material 组件库中提供了一些现成的组件来减少我们的开发任务 Scaffold Scaffold 是一个路由页的骨架,使用它可以很容易的拼装出一个完整的页面 我们实现一个页面...//其它属性见源码注释 }) 复制代码 如果给 Scaffold 添加了抽屉菜单,默认情况下, Scaffold 会自动将 AppBar 的 leading 设置为菜单按钮(如上面截图所示),点击它可以打开抽屉菜单...() => {Scaffold.of(context).openDrawer()}, ); }), ........... ) 复制代码 可以看到左侧的菜单已经替换成功 打开抽屉的方法在...裁剪 Widget 作用 ClipOval 子组件为正方形时剪裁为内贴圆形,为矩形时,裁切Wie内贴椭圆 ClipRRect 将子组件剪裁为圆角矩形 ClipRect 剪裁子组件到实际占用的矩形大小(溢出部分裁切
例如,将主要内容放置在卡的顶部,或使用排版来强调最重要的内容。 图像可以强化卡片中的其他内容。 但是,它们在卡内的大小和位置取决于图像是主要内容还是用于补充卡片上的其他内容。...背景图像 当文字放置在纯色背景上时,文字清晰度最高,且文字对比度足够高。 放置在图像背景上的文本应该保留文本的易读性。 ? 左:不同布局的卡片 右:排版方式能突出重点内容 ?...在这种情况下,卡片将随卡片集合一起滚动。 ? ? 左:卡片可留有展开入口 右:手机端不要在卡片内放置可滚动区域,会存在两条很难分开的滚动条 ?...pc端卡片可展开和内部滚动 卡片聚焦 当遍历卡片上的焦点时,在移动到下一张卡片之前访问所有可聚焦元素。...对于依赖焦点遍历进行导航(手柄和键盘)的页面,卡片应具有主要操作或打开包含主要和补充操作的新视图。 ? 选择操作 ?
应用程序栏通常用在Scaffold.appBar属性中,该属性将应用程序栏作为固定高度的小部件放置在屏幕的顶部。...对于可滚动的应用程序栏,请参阅SliverAppBar,该应用程序将AppBar嵌入长条中以用于CustomScrollView。...下图显示了当书写语言是从左到右(例如英语)时,每个插槽出现在工具栏中的位置: ? 如果省略了leading小部件,但AppBar位于带有抽屉的展示台中,则会插入一个按钮以打开抽屉。...TabBar, 如果屏幕有多个页面排列在选项卡中,它通常放置在AppBar的bottom插槽中. IconButton,它用于在应用栏上显示按钮的actions....适当的颜色是常量颜色(0xFF616161)(中等灰度),在白色背景下.
应避免使用以下声音: 通过屏幕阅读器播放不必要的声音,例如打开网页时自动播放的背景音乐。如果有背景音乐,请确保用户可以安全的暂停或停止背景音乐。...用户可以在 “通过触摸浏览” 和 “线性导航” 模式之间切换。当页面使用合适的语义化标签时,一些无障碍技术允许用户在页面的这些标记(例如标题)之间导航。...重要操作:将重要操作放在屏幕的顶部或底部(使用快捷方式即可访问) 相关项目:将相似层级的相关项目放在彼此相邻的位置 正确示例 通过把重要的操作放在屏幕顶部,使它们在层次结构中显得更重要。...错误示例 当把重要的操作嵌入到其他内容中时,就不清楚什么是页面中最重要的元素。 焦点顺序 输入焦点应该按照视觉布局的顺序排列,从屏幕顶部到底部。它应该从最重要的项目到最不重要的项目进行遍历。...建议你也: 在打开各种无障碍技术的情况下,测试应用从开始到结束的完整的任务流程。例如,在 TalkBack 中打开 “通过触摸浏览” ,并改变大声说出文本的速度。
Flutter框架将依次构建这些widget,直到构建到最底层的子widget时,这些最低层的widget通常为RenderObject,它会计算并描述widget的几何形状。...构建一个material design风格的App。...MaterialApp 引入了 Material Design,还是相当漂亮的,开发者几乎不需要做额外的布局、样式 编码就能达到产品级视觉效果, 当然可以根据需求进行微调。...,其中的提供了一些组件属性 appBar:顶部标题栏 body:用来展示 APP 的主体部分。...:Stack与Row和Clomn类似,只不过适用于子Wight没那么规则化的布局,可以允许其子widget简单的堆叠在一起 5、添加本地资源 在根目录下新建文件夹,命名为images,将lake.png