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

自定义View概述

前言 ---- 在前面的文章中我们学习了ExpansionPanelList的用法,使用ExpansionPanelList可以很轻松的实现可展开列表的效果,在文章的最后依然给大家留下了个小问题,实现如下效果...在前面已经提到了,使用ExpansionPanelList.radio()每次只能打开一个Item,当有一个item处于打开状态时在点击其他item就没有效果了,所以在这里我们依然要借助于ExpansionPanelList...来实现,其实实现起来还是很简单的,只不过是记录下打开的position而已。...Widget 当然,上面仅仅是自定义的流程,具体的实现还是有很多细节需要处理的。...Flutter中的坐标系 在Flutter中坐标系的坐标原点在左上角,X坐标越往右越大,Y坐标越往下越大 ?

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

    Flutter 库:强大的下拉刷新上拉加载框架——EasyRefresh

    Flutter 库:强大的下拉刷新上拉加载框架——EasyRefresh 一、概述 1、简介 EasyRefresh 是一个用于 Flutter 应用程序的简单易用的下拉刷新和上拉加载框架。...利用Flutter强大的动画功能,即使只是一个简单的控件也可以实现复杂的效果。EasyRefresh的目标是为Flutter创建一个功能强大、稳定和成熟的下拉刷新框架。...2、特征 EasyRefresh具有以下特性: 支持所有可滚动小部件 滚动物理范围,完全匹配可滚动小部件 集成多个酷页眉和页脚样式 支持自定义样式,实现各种动画效果 支持下拉刷新和上拉加载(可通过控制器触发和完成...) 支持指示器位置设置,结合监听器可以放置在任意位置 支持页面启动时刷新,并可自定义视图 支持安全区域,不会遮挡内容 可自定义滚动参数,允许列表具有不同的滚动反馈和惯性 3、在线演示 https://xuelongqy.github.io...下拉刷新逻辑 // ... }, onLoad: () async { // 上拉加载逻辑 // ... }, child: ListView(), ); 2、生成器构造函数

    13600

    Flutter 视图布局-前言

    大多为独立实现的作品,让我看了煞是羡慕。 不过说来惭愧我也学了一月有余,对于 Flutter 的整体认识程度还不是很高,还不能很全面的去讲解整个 Flutter 的体系。...那么接下来就来看一看 Flutter 的视图布局吧。...01 - 视图的布局方式 简单说一下我对 Flutter 视图布局的看法,在前篇中我有提到 Flutter 是使用了 Dart 语言进行编写,所以弱化了视图编辑的部分,视图的渲染、结构、布局都通过代码逻辑来生成...Flow 一个可以实现流式布局算法的 Widget。 Stack 可以允许其子元素简单的堆叠在一起。 IndexedStack 从一个子元素列表中显示单个子元素的 Stack。...每一种 Widget 都会影响其子元素最终的视图显示效果,如大小、位置、边框、背景等。

    2.3K110

    Flutter可滑动组件

    Flutter可滑动组件 1. ListView 1.1 ListView介绍 移动端数据量比较大时,一般都是通过列表来进行展示的,比如商品数据、聊天列表、通信录、朋友圈等。...在Flutter中,我们也有对应的列表Widget,就是ListView。 注意:在Flutter里面想要实现滑动效果,都需要在组件外部包裹滚动的视图。...在Flutter中我们可以使用GridView来实现,使用方式和ListView也比较相似。...如果我们想要在一个页面中,同时包含多个可滚动组件,且使它们的滑动效果能统一起来,比如一个滑动的视图中包括一个列表视图(ListView),一个网格视图(GridView),且让他们的滑动效果统一。...3.2 Flutter 中常用的 Sliver Sliver名称 功能 对应的可滚动组件 SliverList 列表 ListView SliverFixedExtentList 高度固定的列表 指定itemExtent

    7.2K30

    Flutter技术与实战(4)

    RenderObject RenderObject 是主要负责实现视图渲染的对象。 Flutter 通过控件树(Widget 树)中的每个控件(Widget)创建不同类型的渲染对象,组成渲染对象树。...在 Android 中是由 ListView 或 RecyclerView 实现的,在 iOS 中是用 UITableView 实现的;而在 Flutter 中,实现这种需求的则是列表控件 ListView...ListView 在 Flutter 中,ListView 可以沿一个方向(垂直或水平方向)来排列其所有子 Widget,因此常被用于需要展示一组连续视图元素的场景,比如通信录、优惠券、商家列表等。...childCount: 100,//列表元素个数 ), ), ]); 实现效果类似于可折叠式标题栏。...,如 1.0x、2.0x、3.0x 或其他任意倍数,Flutter 可以根据当前设备分辨率加载最接近设备像素比例的图片资源。

    10.9K20

    《Flutter》-- 6.高级组件

    参阅书籍: 《Flutter跨平台开发入门与实践》-- 向治洪(著) 6. 高级组件 6.1 可滚动组件 对于列表和长布局的显示溢出问题,可以使用Flutter提供的可滚动组件来处理。...目前,可滚动组件中的大部分组件都支持基于Sliver的延迟构建模型,如ListView、GridView。...:视图窗口内部长度,大小等于屏幕显示的列表长度; extentAfter:列表中未滑入视图窗口部分的长度; atEdge:是否滚动到了可滚动组件的边界。...,用于创建横轴数量固定的网格视图; 4)GridView.extent():SliverGridDelegateWithFixedCrossAxisCount实现类的简写,用于创建横轴子元素宽度固定的网格视图...,它继承自CustomScrollView,作用类似于Android的ViewPager,可以用它实现视图的左右滑动切换功能。

    10.7K20

    让 Flutter 在鸿蒙系统上跑起来

    美团外卖 MTFlutter 团队近期做了一次技术探索,成功地实现了 Flutter 对于鸿蒙系统的原生支持。...虽然Flutter 官方并没有适配鸿蒙的计划,但经过一段时间的探索和实践,美团外卖 MTFlutter 团队成功实现了 Flutter 对于鸿蒙系统的原生支持。...同样,我们参考 Flutter for Android 的实现,看一下 Android 系统是怎么做的: ?...可用于直接绘制的视图对象 鸿蒙系统的 UI 框架提供了很多常用视图组件(Component),比如按钮、文字、图片、列表等,但我们需要抛开这些上层组件,获得直接绘制的能力。...在最基本的运行和交互能力之上,我们更需要关注 Flutter 与鸿蒙自身生态的结合:如何优雅地适配鸿蒙的分布式技术?如何用 Flutter 实现设备之间的快速连接、资源共享?

    2.5K41

    Flutter完整开发实战详解(二十、 Android PlatformView 和键盘问题)

    这意味着默认情况下 Flutter UI 永远不会包含 Android Native 的控件,也就是说无法在 Flutter 中集成如 WebView 或 MapView 这些常用的控件。...但是,Android 平台并不支持这种模式,因为在 iOS 上框架渲染后系统会有回调通知,例如:当 iOS 视图向下移动 2px 时,我们也可以将其列表中的所有其他 Flutter 控件也向下渲染 2px...如果强行以这种方式在 Android 上使用,最终将产生很多如 AndroidView 与 Flutter UI 不同步的问题。...2.1.2、局限性 该实现逻辑会将新的 MotionEvent 直接分发给 AndroidView ,如果这个 View 又派生了其他视图,那么就可能会出现触摸信息被发送到错误的位置。...相关的 issue 专题高居不下,并且如 webview_flutter 插件的文档所述: 该插件依赖 Flutter 的新机制来嵌入 Android 和 iOS 视图。

    13.6K20

    Flutter-从入门到项目 03: Flutter初体验

    创建完毕我们就可以初体验运行一下 感受一下 Flutter 经典默认页面 欢庆双节 二、Flutter 声明式语法 命令式编程:命令“机器”如何去做事情(how),这样不管你想要的是什么(what),它都会按照你的命令实现...可能你这里通过这个还是无法明白什么是 命令式编程 什么是 声明式编程 我们以一个视图UI 做为?...(如 Flutter 的 Widget )是不可变的,它只是轻量的“蓝图”。...enter : 行尾自动添加分号,if后面自动加“(){ }” cmd + N : 快速生成getter/setter方法,构造方法,toString()方法等 cmd + J : 快速生成模版代码块,如if...③ flutter listView 列表界面class KCListView extends StatelessWidget { Widget _itemForRow(BuildContext

    1.1K10

    Flutter 性能优化的一些路径思考

    不可否认 Flutter 是一个非常强大的移动应用开发框架,我们在技术架构选型时就是选用的 Flutter,特别是跨端能力属实很优秀,but 也逐渐发现在复杂的应用程序实现中,App 的性能会受到一些影响...1、巧用链表(LinkedList)如果我们需要在列表中查找元素,那么使用哈希集(HashSet)会比使用列表(List)更高效。...使用性能分析工具Flutter其实有提供了一些性能分析工具,如 Flutter DevTools 和 DartDevTools。如果我们多善用这些工具可以帮助我们找出性能瓶颈,从而进行针对性的优化。...例如,我们可以使用 Flutter DevTools 的 Timeline 视图来查看应用的帧率,以及每一帧的构建、布局和绘制时间。...此外,我们在技术讨论的时候也发现,从图片缓存、JSON序列化、反序列化和拓展工具也可以实现。在Flutter中,可以使用缓存来提高应用的性能。

    58820

    Flutter 2.8 的新特性【flutter专题17】

    Flutter Web 使用 HtmlElementView Widget 实现了这一点,它允许开发者在 Flutter Web 应用程序中托管 HTML 元素。...在之前版本的 Flutter 中,platform view 会立即创建一个新的画布,每个额外的平台视图都会添加另一个画布,可是创建额外的画布是很昂贵的,因为每个画布都是整个窗口的大小。...所以该版本会复用早期平台视图创建的画布,这意味着开发者可以在 HtmlElementView 的 Web 应用中拥有多个实例而不会降低性能,同时还可以减少使用平台视图时的滚动卡顿。...DartPad DartPad 的改进,其中最大的改进是对更多包的支持,事实上现在有 23 个包可供导入,除了几个 Firebase 服务,该名单包含常用软件如 bloc,characters,collection...文章涉及到的链接 官网链家:https://flutter.dev/ 版本列表:https://flutter.cn/docs/development/tools/sdk/releases

    2.4K10

    Widget中的state到底是什么

    在上一篇文章Widget,构建Flutter界面的基石中,我们深入理解了Widget是Flutter构建界面的基石,,也认识了Widget、Element、RenderObject是如何互相配合,实现图形渲染工作的...; 与此不同的是,Flutter的视图开发是声明式的,其核心设计思想就是将视图和数据分离。...return result; } } 可以看到,在构造方法将其属性列表赋值后,build方法随即将子组件RichText通过其属性列表(如文本data、对齐方式textAlign、文本展示方向textDirection...而,Flutter框架则会标记视图状态,更新UI。...总结 在iOS、Android以及JavaScript中,视图开发都是命令式的;而在Flutter中,视图开发则是声明式的,我们只需要改变数据,然后通过Flutter框架触发Widget的重新渲染即可

    2.9K20

    UITableView在Flutter中是什么?

    这样的需求,在iOS中是用UITableView实现的;而在Flutter中,实现这种需求的则是列表控件ListView。...ListView 在Flutter中,ListView可以沿一个方向(垂直或者水平方向)来排列其所有子Widget,因此常被用于需要展示一组连续视图元素的场景,比如通讯录、优惠券、商家列表等。...但是,对于某些特殊交互场景,比如多个效果联动、嵌套滚动、精细滑动、视图跟随手势操作等,还需要嵌套多个ListView来实现。...在Flutter中,ScrollNotification通知的获取是通过NotificationListener来实现的。...总结 在处理展示一组连续、可滚动的视图元素的场景中,Flutter提供了比原生Android、iOS系统更为强大的列表组件ListView与CustomScrollView。

    5.6K10

    flutter鸿蒙版本通过底部导航栏的实现熟悉架构及语法

    写在前面 在这篇博客中,我们将深入分析一个 Flutter 应用的完整代码,该应用实现了一个底部导航栏,允许用户在不同页面之间切换。...引入 Flutter 包 import 'package:flutter/material.dart'; 这一行代码导入了 Flutter 的核心 Material Design 库。...实现状态类 class _HomePageState extends State { int _selectedIndex = 0; // 当前选中的底部导航项 // 页面列表...页面列表 _pages 列表包含了三个页面,分别是: Home Page Search Page Profile Page 每个页面都是一个 Center 小部件,里面包含一个 Text 小部件...; } class _HomePageState extends State { int _selectedIndex = 0; // 当前选中的底部导航项 // 页面列表

    10210

    大前端开发中的路由管理之五:Flutter篇

    在Flutter中,一切皆是Widget(组件),其中StatefulWidget(有状态的组件)和React中的组件类似,可以通过数据变化去手动更新视图,Flutter路由管理实现的核心组件Navigator...3、Flutter路由管理实现总结         从以上流程实现可以看出,Flutter页面栈的实现依赖于: Navigator持有路由栈,提供导航方法,当路由栈发生变化时同步更新页面栈。...Overlay持有页面栈,它实现页面栈到渲染用widget集合的转换过程,并能够接受到路由栈更新的通知去同步更新视图。...上面讲到是纯Flutter中路由管理的实现,但是在我们开发中可能还会遇到Flutter-Native混编的模式,对这块感兴趣的同学们可以在我们团队这篇文章 Flutter 核心原理与混合开发模式 中解锁更多知识...客户端开发,点击左下方“查看原文”投递简历~ 也可将简历发送至邮箱:tmezp@tencent.com ---- 文末为大家推荐一个技术号《腾讯音乐天琴实验室》,TME天琴实验室致力于对业内前沿科技如AI

    2.3K30

    如何响应用户交互事件

    第二类则是手势识别(Gesture Detector),表示多个原始指针事件的组合操作,如点击、双击、长按等,是指针事件的语义化封装。 接下来,我们先来看一下原始的指针事件。...指针事件 指针事件表示用户交互的原始触摸数据,如手指接触屏幕 PointerDownEvent、手指在屏幕上移动 PointerMoveEvent、手指抬起 PointerUpEvent,以及触摸取消...Flutter无法取消或停止事件的进一步分发,我们只能通过hitTestBehavior去调整组件在命中测试期内应该如何表现,比如把触摸事件交给子组件或者交给其视图层级之下的组件去响应。...那手势竞技场具体是怎样实现的呢? 实际上,GestureDetector 内部对每一个手势都建立了一个工厂类(Gesture Factory)。...有些时候我们可能会在应用中给多个视图注册同类型的手势监听器,比如微博的信息流列表中的微博,点击不同区域会有不同的响应:点击头像会进入用户个人主页,点击图片会进入查看大图页面,点击其他部分会进入微博详情页等

    2.2K10
    领券