热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

flutter友盟分享_flutter友盟统计之界面统计

2020.10.20日更新:最近发现了一种更好的方法,就是使用RouteAware监听路由,下面是实现代码初始化:Route

2020.10.20日更新:

最近发现了一种更好的方法,就是使用RouteAware监听路由,下面是实现代码

初始化:

RouteObserver需要申明为全局属性并作为参数传入MaterialApp中

static final RouteObserver routeObserver = RouteObserver();

@override

Widget build(BuildContext context) {

return MaterialApp(

navigatorObservers: [AppRoutesManager.routeObserver],

...

);

}

使用

abstract class BaseState extends State with RouteAware {

String pageName;

E viewModel;

void initState() {

super.initState();

}

@override

void didChangeDependencies() {

AppRoutesManager.routeObserver.subscribe(this, ModalRoute.of(context)); //订阅

super.didChangeDependencies();

print("didChangeDependencies: ${pageName}界面");

}

@override

void didPush() {

debugPrint("------> didPush-进入${pageName}");

super.didPush();

}

@override

void didPop() {

debugPrint("------> didPop离开${pageName}");

super.didPop();

}

@override

void didPopNext() {

debugPrint("------> didPopNext-进入${pageName}");

super.didPopNext();

}

@override

void didPushNext() {

debugPrint("------> didPushNext-${pageName}进入下一个界面");

super.didPushNext();

}

@override

void dispose() {

AppRoutesManager.routeObserver.unsubscribe(this); //取消订阅

super.dispose();

// print("dispose 离开${pageName}界面");

print("销毁${pageName}界面");

}

但是这个方法有一定的缺陷:

1,AlertView,showGeneralDialog等弹出框里面push的路由没有办法监听,我的解决办法是是写一个回调函数来让主界面来处理路由的push;

2,当使用PageView做界面切换时,监听也是不生效的,这个时候需要自己手动调用RouteAware里面的函数。

下面是之前的实现方法:

之前项目集成了友盟统计的功能,发现flutter界面统计无法实现,在iOS中我们可以通过Controller的生命周期中的viewWillAppear:来处理什么时候进入界面viewWillDisappear:来处理什么时候来开界面,离开界面的处理,flutter的组件虽然也有生命周期,但是它的生命周期不足以支持我们准确的统计,虽然我们可以用initState做进入的的逻辑,用dispose做离开的逻辑,但是initState 只有在组件第一次初始化的时候跳用,dispose只有在组件销毁的时候才会调用;当我们使用Navigator.push离开当前界面进入下一个界面时我们没有办法做处理,当然我们也可以选择在每一个push的地方做处理,但是这样就会出现大量的重复代码,显然不符合我们的初衷,经过思考我给出了下面这个方案:

1,写一个基类BaseState继承自State,其中有一个参数pageName

abstract class BaseState extends State {

String pageName;

void initState() {

// TODO: implement initState

super.initState();

print("initState 进入${pageName}界面");

FlutterBlUmpushPlugin.umengEnterViewWithName(pageName);

}

@override

Widget build(BuildContext context) {

return build(context);

}

@override

void dispose() {

// TODO: implement dispose

super.dispose();

print("dispose 离开${pageName}界面");

print("销毁${pageName}界面");

FlutterBlUmpushPlugin.umengOutViewWithName(pageName);

}

}

2,实现一个push函数,做统一的界面跳转,利用Future的特性做界面的离开,进入逻辑处理:

//跳转界面

void push({Widget page, Function popCallback}) {

print("push: 离开${pageName}界面");

FlutterBlUmpushPlugin.umengOutViewWithName(pageName);

Navigator.push(context, MaterialPageRoute(builder: (BuildContext context) {

return page;

})).then((data) {

print("pop 进入${pageName}界面");

FlutterBlUmpushPlugin.umengEnterViewWithName(pageName);

if (popCallback != null) {

popCallback(data);

}

});

}

//路由跳转

void routerPush({String route, Function popCallback}) {

print("routerPush: 离开${pageName}界面");

FlutterBlUmpushPlugin.umengOutViewWithName(pageName);

AppRoutesManager.router.navigateTo(context, route).then((data) {

print("pop 进入${pageName}界面");

FlutterBlUmpushPlugin.umengEnterViewWithName(pageName);

if (popCallback != null) {

popCallback(data);

}

});

}

使用:

class MinePage extends StatefulWidget {

@override

_MinePageState createState() => _MinePageState();

}

class _MinePageState extends BaseState with AutomaticKeepAliveClientMixin {

@override

bool get wantKeepAlive => true;

@override

void initState() {

// TODO: implement initState

pageName = "个人中心";

super.initState();

}

@override

Widget build(BuildContext context) {

return Scaffold(

appBar: CustomAppBar(

title: pageName,

),

body: GestureDetector(

onTap: () {

routerPush(route: AppRoutesManager.mall, popCallback: (data) {});

},

child: Container(

color: Colors.red,

),

),

);

}

}

注:如果是安卓的话可以通过initState(), deactivate()加一个bool类型的参数处理,不知道为什么iOS端的deactivate()函数在push下一个界面的时候不调用。



推荐阅读
  • Flutter中计算文本尺寸的方法
    在Flutter开发中,有时需要计算文本的宽度和高度。本文介绍了一种利用TextPainter类实现这一功能的方法。 ... [详细]
  • Flutter 2.* 路由管理详解
    本文详细介绍了 Flutter 2.* 中的路由管理机制,包括路由的基本概念、MaterialPageRoute 的使用、Navigator 的操作方法、路由传值、命名路由及其注册、路由钩子等。 ... [详细]
  • 使用 ListView 浏览安卓系统中的回收站文件 ... [详细]
  • 本文整理了一份基础的嵌入式Linux工程师笔试题,涵盖填空题、编程题和简答题,旨在帮助考生更好地准备考试。 ... [详细]
  • 【线段树】  本质是二叉树,每个节点表示一个区间[L,R],设m(R-L+1)2(该处结果向下取整)左孩子区间为[L,m],右孩子区间为[m ... [详细]
  • 本文介绍了在 Java 编程中遇到的一个常见错误:对象无法转换为 long 类型,并提供了详细的解决方案。 ... [详细]
  • 零拷贝技术是提高I/O性能的重要手段,常用于Java NIO、Netty、Kafka等框架中。本文将详细解析零拷贝技术的原理及其应用。 ... [详细]
  • 本文介绍如何使用线段树解决洛谷 P1531 我讨厌它问题,重点在于单点更新和区间查询最大值。 ... [详细]
  • 在多线程并发环境中,普通变量的操作往往是线程不安全的。本文通过一个简单的例子,展示了如何使用 AtomicInteger 类及其核心的 CAS 无锁算法来保证线程安全。 ... [详细]
  • 深入解析 Lifecycle 的实现原理
    本文将详细介绍 Android Jetpack 中 Lifecycle 组件的实现原理,帮助开发者更好地理解和使用 Lifecycle,避免常见的内存泄漏问题。 ... [详细]
  • poj 3352 Road Construction ... [详细]
  • 本文是Java并发编程系列的开篇之作,将详细解析Java 1.5及以上版本中提供的并发工具。文章假设读者已经具备同步和易失性关键字的基本知识,重点介绍信号量机制的内部工作原理及其在实际开发中的应用。 ... [详细]
  • 在C#编程中,设计流畅的用户界面是一项重要的任务。本文分享了实现Fluent界面设计的技巧与方法,特别是通过编写领域特定语言(DSL)来简化字符串操作。我们探讨了如何在不使用`+`符号的情况下,通过方法链式调用来组合字符串,从而提高代码的可读性和维护性。文章还介绍了如何利用静态方法和扩展方法来实现这一目标,并提供了一些实用的示例代码。 ... [详细]
  • JUC(三):深入解析AQS
    本文详细介绍了Java并发工具包中的核心类AQS(AbstractQueuedSynchronizer),包括其基本概念、数据结构、源码分析及核心方法的实现。 ... [详细]
  • 本文介绍了一种自定义的Android圆形进度条视图,支持在进度条上显示数字,并在圆心位置展示文字内容。通过自定义绘图和组件组合的方式实现,详细展示了自定义View的开发流程和关键技术点。示例代码和效果展示将在文章末尾提供。 ... [详细]
author-avatar
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有