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

Flutter 源码系列:DropdownButton 源码浅析

DropdownButton 构造函数及简单使用 其实关于 DropdownButton 的构造函数和简单使用我在上一篇文章中已经有过讲解, 如有不懂怎么用的,可以看这篇文章:Flutter DropdownButton...下面重点说一下 DropdownButton 是如何实现的。 DropdownButton 的实现 我们需要带着如下几个问题去看源码: 1.DropdownButton 是用什么来实现的?...2.在点击 DropdownButton 的时候发生了什么?3.为什么每次弹出的位置都是我上次选择item的位置? 带着如上问题,我们开始。 DropdownButton 是用什么实现的?...我们在上一篇文章中已经了解到,DropdownButton 是一个 statefulWidget,那我们想要了解他是如何实现的,就直接跳转到他的 _DropdownButtonState 类中。...2.behavior:设置在命中的时候如何工作:HitTestBehavior.opaque 为不透明的可以被选中3.child:返回了 result Result 是什么 不看点击方法,先来找到 result

1.7K30

如何在 Flutter 中创建自定义图标【Flutter专题22】

在本文中,我将向您展示如何在 Flutter 中创建自定义图标 Flutter 提供了很多开箱即用的图标,使用这些图标非常容易。但是,您也可以使用自己的图标。...您需要的是一个 TTF(True Type Font)文件,其中包含您要使用的图标。生成 TTF 文件的最简单方法是使用 Fluttericon.com。...按下按钮以获取包含您需要的文件的 zip。 解压缩下载的 Zip 并复制文件。 在fonts文件夹里面,有一个.ttf文件。将其复制到项目中的目录中,例如assets/fonts....在要使用图标的文件中,导入下载的 .dart 文件,您就可以使用图标了。 import '....'Flutter DropdownButton Tutorial by jianguojs.cn'), ), body: Center(

3.4K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【Flutter 专题】104 图解自定义 ACEDropdownButton 下拉框

    和尚之前尝试过 Flutter 自带的 DropdownButton 下拉框,简单方便;但仅单纯的原生效果不足以满足各类个性化设计;于是和尚以 DropdownButton 为基础,调整部分源码...DropdownButton 源码 DropdownButton 源码整合在一个文件中,文件中有很多私有类,不会影响其它组件; 以和尚的理解,整个下拉框包括三个核心组件,分别是 DropdownButton...DropdownButton 是开发人员最直接面对的 StatefulWidget 有状态的组件,包含众多属性,基本框架是一个方便于视力障碍人员的 Semantics 组件,而其核心组件是一个层级遮罩...getMenuLimits 对于下拉框的尺寸位置,各子 item 位置等一系列位置计算;在这里可以确定下拉框展示的起始位置以及与屏幕两端距离判断,指定具体的约束条件;DropdownButton 同时还起到了衔接...避免遮挡 和尚选择自定义 ACEDropdownButton 下拉框最重要的原因是,Flutter 自带的 DropdownButton 在下拉框展示时会默认遮挡按钮,和尚预期的效果是: 若按钮下部分屏幕空间足够展示所有下拉

    2K20

    Flutter DropdownButton简单使用及魔改源码

    我们一般在写业务的时候多会用到下拉菜单, 前面讲过 ExpansionPanel, ExpansionPanel大部分情况用来实现展开列表等稍微复杂的业务逻辑。...而 DropdownButton 则是用来实现稍微简单一点的 点击选择 业务场景。...刚才我们看到的图中是有下划线的,如果想去除下划线的话,简单可以这么操作:underline: Container(), 也可以使用 DropdownButtonHideUnderline 包裹住 DropdownButton...中传入了一个 selectedIndex,那我们就可以想象的到,这肯定就是问题的根源。...Flutter 的源码真的是给与我们极大的方便,每一种控件都在一个文件内,我们直接复制出来就可以改。 最后再说一句:魔改一时爽,一直魔改一直爽。

    4.5K70

    【02】写一个注册页面以及配置打包选项打包安卓apk测试—开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程

    【02】写一个注册页面以及配置打包选项打包安卓apk测试开发背景上次我们安装了flutter 配置了vs-code的环境,这次我们来写一个注册页面,以及最基本的打包。...Scaffold 组件的关键属性appBar: 一个位于顶部的应用栏(AppBar),通常包含标题、导航按钮和其他操作项。body: 主体内容区域,用于放置应用的主要内容。...和 DropdownButtonFormField 是两个常用的组件,用于创建下拉菜单和表单中的下拉选择项。...这里只是用来做个样子,这里我们应该用选框组件,在 Flutter 中实现同意协议的勾选框(CheckBox)通常可以使用 Checkbox 组件。...并保持布局在页面底部,可以在 Expanded 组件中添加一个 Column 来包含这两个组件。

    8110

    Flutter lesson 6: Flutter组件之基础组件(二)

    Row Row这个Widget其实就是一个布局组件,类似于前端中flex-direction: row;。作用就是可以使Row中的子元素在水平方向上面排列,可以用来做走马灯轮播等效果。...取值的话也是前端中对其方式的几种取值 start end center spaceBetween spaceAround spaceEvenly 唯一不同的是,在Flutter中新增加了一个spaceEvenly...可以使相册中的图片或者是相机拍照的图片。 还有,你可能需要image_picker这个插件来完成图片的选择以及拍照。这个插件IOS需要配置一下,安卓不用。...fit 图片如何在Image控件中显示,有以下几个值可选 enum BoxFit { fill, // 填充整个容器,宽高都不超出容器 contain, // 按宽高中最小的那个来放大...这个属性就像是CSS中设置背景重复一样 ? 包含以上几种属性,一般很少设置重复属性的。 noRepeat: 不设置重复。

    2.2K20

    大前端开发中的路由管理之三:Android篇

    从启动对象来看,显式Intent通过明确启动对象的组件信息使得有固定的接收方,隐式Intent通过Intent Filter过滤匹配合适的启动对象;从使用场景上看,在同一项目下的页面跳转可以使用显式Intent...同时,Navigation 组件提供管理所有返回堆栈的功能,堆栈的顶部为当前屏幕,堆栈中记录着访问的目的地顺序,堆栈的底部是应用的起始地,同时提供了相关更改返回栈的方法,使得我们可以灵活在不同Fragment...实现的RN跳转到RN,此时页面栈交由路由导航中的堆栈管理;         ③以及RN跳转到原生,主要包含三步:定义Module类,继承ReactContextBaseJavaModule、定义Package...在原生页面中,通过理解AMS,重点关注Activity的启动模式、Fragment的Navigation路由框架以及两者之间涉及到的页面栈跳转方式;在混合开发页面中,从native方-跨平台方-双方交互这三个角度简化路由管理...----         至此,我们了解到了Android端是如何去实现路由管理的,那么,就请期待我们下一篇文章《大前端开发中的路由管理之四:iOS篇》吧,下篇文章将为大家揭秘iOS端是如何去做路由管理的

    3.3K11

    为Flutter应用程序添加交互性 顶

    在本教程中,您将为仅包含非交互式小部件的应用添加交互性。 具体来说,您将通过创建一个管理两个无状态小部件的自定义状态小部件来修改图标以使其可以点击。...状态对象包含小部件的状态和小部件的build()方法。 当小部件的状态改变时,状态对象调用setState(),告诉框架重绘小部件。 在本节中,您将创建一个自定义有状态小部件。...在这个例子中,切换星号是一个独立的操作,不会影响父窗口小部件或其他用户界面,因此窗口小部件可以在内部处理它的状态。 在管理状态中了解更多关于窗口小部件和状态的分离以及如何管理状态的信息。...在以下示例中,TapboxB通过回调将其状态导出到其父项。 由于TapboxB不管理任何状态,因此它的子类为无状态部件。...处理手势,Flutter Widget框架导览中的一部分:如何创建按钮并使其响应输入。 Flutter中的手势:Flutter手势机制的描述。

    4.2K20

    重走Flutter状态管理之路—Riverpod进阶篇

    这篇文章,我们将真正的深入了解,如何在不同的场景下,选择合适的种类的Provider,以及这些不同类型的Provider,都有哪些作用。...它存在于flutter_riverpod包中,以提供一个简单的从package:provider的迁移组件,并允许一些flutter特定的使用情况,如与一些Navigator 2包的集成。...你的状态中包含对校验逻辑 你的状态是一个复杂的对象,比如一个自定义类,一个List、Map等 状态的修改逻辑比较复杂 对于这些场景,你可以考虑使用StateNotifierProvider代替,并创建一个...更新状态的简化 参考下面的这个场景,有时候,我们需要根据前一个状态值,来修改后续的状态值,例如Flutter Demo中的加数器。...ChangeNotifierProvider是一个用来管理Flutter中的ChangeNotifier的Provider。

    4K11

    Jmeter(六) - 从入门到精通 - 建立数据库测试计划(详解教程)

    1.简介   在实际工作中,我们经常会听到数据库的性能和稳定性等等,这些有时候也需要测试工程师去评估和测试,因此这篇文章宏哥主要介绍了jmeter连接和创建数据库测试计划的过程,宏哥在文中通过示例和代码非常详细地介绍给大家...2.建立数据库测试计划   在本节中,您将学习如何创建基本的测试计划以测试数据库服务器和操作数据库(增、删、改、查)。本示例使用MySQL数据库驱动程序。...name:创建一个对象变量,保存所有返回结果 query timeout:查询超时时间 handle result set:定义如何处理由callable statements语句返回的结果 如下图所示...2、Update statement 这是一个更新语句类型(包含insert和update);如果JDBC Request中的Query内容为一条更新语句,则选择这种类型。...备注:后面的七项项涉及到数据库的事务控制等知识点,如果有不明白的地方请自行查询相关知识。 2.5添加侦听器以查看/存储测试结果 您需要添加到测试计划中的最后一个元件是 Listener。

    4.1K40

    使用导航组件: 对话框目的地 | MAD Skills

    概览 在本系列的 上一篇文章 中,我大致介绍了导航组件以及如何使用导航图。 在这篇文章中,我会介绍如何使用 API 来导航到对话框目的地 (dialog destination)。...我发现这样做很方便,即便我最终的界面跟模版应用根本不像,至少模版会帮我处理类似下载合适的依赖,以及创建基础代码和资源等工作。...id 将导航目的地改变为对话框,这里的 id 正是在导航图中创建目的地时所生成的。...在 DonutTracker 的导航图中有两个目的地 您会发现主页目的地依然存在,只不过叫做 donutList。这是那个包含甜甜圈列表 (使用 RecyclerView) 的 fragment。...注意: 点击返回按钮,同样会返回甜甜圈列表,因为导航组件已经自动为我们设置好了返回栈。 总结 通过这篇文章我们了解了如何使用内置的导航组件快速地创建一个新应用,并且学习了如何导航到对话框目的地。

    1.4K30

    导航组件概览 | MAD Skills

    概览 本文会简要概述导航组件,包括如何创建一个带有导航能力的、已启用导航的 UI 中有关包含层级的细节的新应用,以及对于一些主要 API 和导航组件工作原理的解释。...在导航图中的每个目的地都是 fragment,每个目的地都包括 0 个或更多的操作 (action),操作定义了如何导航到导航图中的其他目的地。...我发现,观察 UI 中的各个部分在包含层级中的相互关系对于理解它们如何一起工作十分有帮助。为了查看这个部分,让我们来使用 Navigation Drawer Activity 模板创建另一个新工程。...导航部件 我们已经在层级结构中查看了几个 UI 组件,以及它们彼此之间是如何关联的,接下来我想介绍一下几个重要部件,导航组件正是利用它们来在目的地之间实现导航。...在未来的文章和视频中,针对如何同特定导航 API 进行交互,我会介绍更多的技术细节,比如导航到对话框目的地、使用 SafeArgs 以及处理深层链接。

    1.7K30

    优化 Flutter 应用开发:探索 ViewModel 的威力

    ViewModel,顾名思义,就是视图的模型。在 Flutter 中,ViewModel 是一种用于管理视图状态和业务逻辑的重要概念。...因此,ViewModel 的重要性不言而喻。它是应用程序的核心架构之一,直接影响着应用程序的性能、可维护性和用户体验。1.3 为什么在 Flutter 中需要 ViewModel?...Flutter 中的状态管理概述2.1 基本概念:State、StatefulWidget、ChangeNotifier 等在 Flutter 中,状态管理是构建应用程序的关键部分。...网络请求和数据持久化:ViewModel 可以包含网络请求和数据持久化的逻辑,但应该将其封装成可复用的方法,便于在多个视图中共享和重用。...该应用程序包含一个输入框用于添加新的待办事项,以及一个列表用于显示已添加的待办事项。

    34010

    『Flutter』常用组件 按钮、图片

    1.前言 经过『Flutter』布局组件 Container、Row、Column、Stack上一篇文章的学习,我们大家可以了解到布局相关的组件,但是在实际开发中,我们还需要使用到其他的组件,比如按钮、...2.常用组件 在Flutter中,有多种按钮组件可以用于创建交互式界面。主要的按钮组件包括: 1. ElevatedButton:这是一个凸起的按钮,常用于主要的操作。...它可以包含图标而不是文本,适用于空间有限或需要图形化表示的地方。 5. FloatingActionButton:这是一个圆形的按钮,通常悬浮在内容上方,用于促进应用中的主要动作,如添加、编辑等。...Flutter 中,TextButton 组件的 onLongPress 属性允许你定义一个回调函数,当用户长按按钮时会被触发。...Flutter 中,用于显示图片的主要组件是 Image。

    9610

    为什么说Flutter让移动开发变得更好?

    下面看看如何在Flutter中实现上面的例子: 为电影项目创建一个无状态的Widget(无状态,因为包含静态属性),接收一个movie(例如Dart类)作为构造函数参数,并以声明方式描述布局,同时绑定电影的值...下面看看我是如何构建的: 该布局由SliverAppBar组成,其中包含电影图像的堆叠布局,渐变,气泡和文本图层。 能够以模块化的方式表达布局使得创建这种相当复杂的布局变得非常简单。...不过,在Flutter,这分分钟解决。能够将用户界面的一部分抽取到像Widget这样的自包含单元中,可以轻松地在应用程序中甚至跨不同应用程序重复使用这些小部件。...不再有多余的样板代码 。 既然两个app的功能几乎一样,我就比较好奇两种不同语言实现的代码量。 那么应该如何进行对比?(免责声明:Flutter版本中还没有实现持久化,原生代码写的也很乱)。...这是一项艰巨的任务,但这样做会帮助你理解为什么Flutter会出现。 公平地说,有很多应用程序(截至目前),我仍然会使用Kotlin去编写; Android可能会陷入困境,但它也有其特殊之处。

    2K10

    Flutter 2 渲染原理和如何实现视频渲染

    声网Agora跨平台开发工程师卢旭辉带来了《Flutter2 渲染原理和如何实现视频渲染》的主题分享,本文是对演讲内容的整理。 本次分享主要包括 3 个部分: Flutter2 概览。...国内很多公司可能还是选用 ReactNative 或者坚持原生开发,不过伴随着 Flutter2 的问世(全平台支持),以及阿里的北海框架(基于 Flutter Engine 的渲染能力实现的上层使用...Flutter 在处理 UI 时都是基于树形结构,从下图中我们可以看到 3 个树形结构,分别是 Widget Tree、Element Tree 和 Render Tree。...在 SurfaceSceneBuilder 的 build 函数执行后,生成的 SurfaceScene 中的 webOnlyRootElement 就已经包含了我们的整个 Html Element 了...至此,CanvasKit 渲染模式下的流程也差不多走完了,我们最后看一下最终是如何显示在HTML 中的。

    2K20

    【译】Flutter 1.20 发布

    为了继续提高 Flutter 的工作效率,我们对 Visual Studio Code 的 Flutter 扩展进行了更新,该扩展将 Dart DevTools 直接带入的 IDE 中,在移动文件时会自动更新了导入语句...实际上,这是 Flutter release 版本中包含的最多社区贡献,特别是向这些社区贡献者表示感谢: CareF 的 28个 PR; AyushBherwani1998 的 26个PR(包括 10...Flutter 和 Dart 的性能改进 在 Flutter 团队中,我们一直在寻找减少应用程序大小和延迟的新方法。...image 要查看如何将集成 InteractiveViewer 到自己的应用程序中,请查看API文档,你可以在 DartPad 中使用它。...Typesafe platform channels for platform interop 为了响应用户调查中插件作者的普遍需求,最近我们一直在尝试如何使 Flutter 与主机平台之间的通信对于插件和

    4K10

    开始使用-编写你的第一个Flutter应用程序 顶

    小部件的主要工作是提供一个build()方法,该方法描述如何根据其他较低级别的小部件来显示小部件。 此示例的小部件树由包含Text小部件的Center小部件组成。...第2步:使用外部包装 在这一步中,您将开始使用名为english_words的开源软件包,其中包含数千个最常用的英文单词以及一些实用功能。...在pubspec.yaml中,将english_words(3.1.0或更高版本)添加到依赖项列表。...在Flutter中,导航器管理包含应用程序路由的堆栈。 将路由推入导航器的堆栈,将显示更新为该路由。 从导航器的堆栈中弹出路由,将显示返回到前一个路由。...最喜欢的一些选择,并点击应用栏中的列表图标。 新路线显示包含收藏夹。 请注意,导航器会在应用栏中添加一个“返回”按钮。 你不必显式实现Navigator.pop。 点击后退按钮返回到主页路由。 ?

    9.5K20

    『Flutter』常用组件 按钮、图片

    1.前言 经过上一篇文章的学习,我们大家可以了解到布局相关的组件,但是在实际开发中,我们还需要使用到其他的组件,比如按钮、图片、文本、输入框等等,这些组件都是我们在开发中经常使用的,所以本篇文章我们就来学习一下这些常用组件...2.常用组件 在Flutter中,有多种按钮组件可以用于创建交互式界面。主要的按钮组件包括: ElevatedButton:这是一个凸起的按钮,常用于主要的操作。...当按下时,边框和文字颜色会变化,适用于需要强调边框而非背景色的场景。 IconButton:这是一个图标按钮,常用于工具栏和对话框中。它可以包含图标而不是文本,适用于空间有限或需要图形化表示的地方。...Flutter 中,TextButton 组件的 onLongPress 属性允许你定义一个回调函数,当用户长按按钮时会被触发。...Flutter 中,用于显示图片的主要组件是 Image。

    56931

    Flutter异步编程

    Flutter异步编程-Futures 本文大纲 1. 什么是Future? 2. 如何创建Future实例? 3. 一个令人迷惑的例子 4. 参考和更多阅读 1. 什么是Future?...本文小菜带大家认识和理解下 Futures 的用法以及原理。 经常听说 future,或者从其他语言见到类似的说法如 javascript 的 Promise。那么究竟什么是 future?...c)从上面工厂方法 Future.sync 源码截图中可以看到,先同步执行computation(于是打印"future4 init"),根据 computation() 返回值视情况进行 Future...因为 future1 已经 completed 了,所以 future1 在7这个位置再次用 then 注册的 callback 回调会被放在 microtask 中执行。...如何自定义Future? 无论是在做基础架构设计还是业务设计中,常常会需要自定义 Future。我们如何自定义 Future,其实可以参考源码的写法。 关键字 Completer!

    87240
    领券