当前位置: 首页 > news >正文

陕西做教学成果网站的公司哈尔滨优化网站排名

陕西做教学成果网站的公司,哈尔滨优化网站排名,如何建设远程教育网站,做旅游网站运营flutter开发实战-第一帧布局完成回调实现 在开发中,我们有时候需要在第一帧布局完成后调用一些相关的方法。这里记录一下是实现过程。 Flutter中有多种不同的Binding,每种Binding都负责不同的功能。下面是Flutter中常见的Binding: 这里简单…

flutter开发实战-第一帧布局完成回调实现
在这里插入图片描述
在开发中,我们有时候需要在第一帧布局完成后调用一些相关的方法。这里记录一下是实现过程。

Flutter中有多种不同的Binding,每种Binding都负责不同的功能。下面是Flutter中常见的Binding:
这里简单说明一下WidgetsBinding

一、WidgetsBinding

WidgetsBinding:负责管理Flutter应用程序的生命周期,包括启动、暂停、恢复和停止等。
WidgetsBinding它用于监听用户设置的更改,如语言的修改。 不仅如此, WidgetsBinding 否是 Widgets 与 Flutter 引擎之间通信的桥梁,有两个主要的功能:
  * 1 负责处理Widgets结构变更的过程;
  * 2 第二个是触发渲染事件。
一些小组件的结构更改是 BuildOwner 来完成的,它跟踪需要重建的小部件,并处理应用于整个小部件结构的其他任务。

二、实现第一帧布局完成后调用相关方法

在WidgetsBinding中,我们可以看到endOfFrame方法,源码如下

/// Returns a Future that completes after the frame completes.////// If this is called between frames, a frame is immediately scheduled if/// necessary. If this is called during a frame, the Future completes after/// the current frame.////// If the device's screen is currently turned off, this may wait a very long/// time, since frames are not scheduled while the device's screen is turned/// off.Future<void> get endOfFrame {if (_nextFrameCompleter == null) {if (schedulerPhase == SchedulerPhase.idle) {scheduleFrame();}_nextFrameCompleter = Completer<void>();addPostFrameCallback((Duration timeStamp) {_nextFrameCompleter!.complete();_nextFrameCompleter = null;});}return _nextFrameCompleter!.future;}

方法中描述如下

该方法返回在帧完成后完成的Future。
如果在帧之前调用的时候,则会立即调度帧。如果在帧期间调用此操作,则Future将在当前帧完成后调用。
如果设备的屏幕当前已关闭,这可能会等待很长时间。

所以我们需要在initState中调用相关方法

WidgetsBinding.instance.endOfFrame.then((value) {if (mounted) {// TODO调用相关方法}},);

实现第一帧布局完成后调用完成代码如下

class AfterLayoutPage extends StatefulWidget {const AfterLayoutPage({super.key});@overrideState<AfterLayoutPage> createState() => _AfterLayoutPageState();
}class _AfterLayoutPageState extends State<AfterLayoutPage> {@overrideWidget build(BuildContext context) {return Scaffold(appBar: AppBar(title: const Text('AfterLayoutPage'),),body: Container(color: Colors.blueGrey,),);}@overridevoid initState() {// TODO: implement initStatesuper.initState();WidgetsBinding.instance.endOfFrame.then((value) {if (mounted) {showHelloWorld();}},);}void showHelloWorld() {showDialog(context: context,builder: (BuildContext context) {return AlertDialog(content: const Text('Hello World'),actions: <Widget>[TextButton(onPressed: () => Navigator.of(context).pop(),child: const Text('DISMISS'),)],);},);}
}

可以将该实现包装成一个Mixin

import 'dart:async';import 'package:flutter/widgets.dart';mixin AfterLayoutMixin<T extends StatefulWidget> on State<T> {@overridevoid initState() {super.initState();WidgetsBinding.instance.endOfFrame.then((_) {if (mounted) afterFirstLayout(context);},);}FutureOr<void> afterFirstLayout(BuildContext context);
}

调整后代码如下

class AfterLayoutPage extends StatefulWidget {const AfterLayoutPage({super.key});@overrideState<AfterLayoutPage> createState() => _AfterLayoutPageState();
}class _AfterLayoutPageState extends State<AfterLayoutPage> with AfterLayoutMixin<AfterLayoutPage> {@overrideWidget build(BuildContext context) {return Scaffold(appBar: AppBar(title: const Text('AfterLayoutPage'),),body: Container(color: Colors.blueGrey,),);}@overridevoid afterFirstLayout(BuildContext context) {// Calling the same function "after layout" to resolve the issue.showHelloWorld();}void showHelloWorld() {showDialog(context: context,builder: (BuildContext context) {return AlertDialog(content: const Text('Hello World'),actions: <Widget>[TextButton(onPressed: () => Navigator.of(context).pop(),child: const Text('DISMISS'),)],);},);}
}

三、小结

flutter开发实战-第一帧布局完成回调实现

学习记录,每天不停进步。

http://www.yayakq.cn/news/825491/

相关文章:

  • 网站开发用什么网站辽宁建设资质申报网站
  • 网站建设的图片叠加步骤过程广东网站建设专业公司哪家好
  • 大图模板网站农村未来10大暴利行业
  • 电商seo是指哈尔滨seo推广
  • 网站建设 sheji021农资网络销售平台
  • 黑河城乡建设局网站福州英文网站建设
  • 做网站怎么添加点击事件企业管理体系包含哪些内容
  • 重庆网站建设 渝icpwordpress返回顶部插件
  • 临沂网站建站专业公司品牌营销策划方案怎么做才好
  • 企业网站建设标准一个数据库两个网站wordpress登陆
  • 公司网站改版需要怎么做删除wordpress标志
  • 江西建设工程信息网站建筑模拟2015
  • 永久免费网站服务器谁能给个网址啊
  • 织梦 修改网站logo浙江高端建设网站
  • 做的比较炫的网站淮南房地产网站建设网站
  • 古风网站建设模板广州制作外贸网站
  • 电子商务网站平台不包括免费网站大全
  • 网站开发投票代码网站空间太小
  • 李洋网络做网站哪些网站不能备案
  • 计算机网络网站开发怎么用照片制作小视频
  • 新手怎么搭建网站python开发订阅号
  • 济南企业网站推广建设企业网站有什么好处
  • 做视频开头动画网站跨境电商平台企业
  • 电商网站备案小白如何自己做网站
  • 网站制作岗位职责建设银行陕西省分行网站
  • 做电子商务网站的意义wordpress the7 建站
  • 自学做网站可以吗wordpress文字黑提
  • 宽城网站制作做seo推广公司网站
  • 网站域名的根目录在哪里优秀个人网站案例
  • 如何查看域名以前是做什么网站的wordpress图片不能上传图片