Flutter自动化控制插件mbautomation的使用
Flutter自动化控制插件mbautomation的使用
MBAutomation
MBAutomation 是一个插件库,用于从 MBurger 平台创建自动推送通知和内嵌消息。它依赖于 MBMessages
和 MBAudience
。通过这个库,你还可以跟踪用户事件和视图。
- MBAutomation 依赖于以下包:
mburger
mbmessages
mbaudience
http
path
path_provider
shared_preferences
sqflite
安装
你可以通过 pub 安装 MBAudience SDK,将以下内容添加到你的 pubspec.yaml
文件中:
dependencies:
mbautomation: ^2.0.0
然后在命令行中安装这些包:
$ flutter pub get
初始化
初始化自动化需要将 MBAutomation
作为 MBurger
插件插入。通常与 MBMessages
和 MBAudience
插件一起使用。
MBManager.shared.plugins = [
MBAutomation(),
... other plugins
];
MBAutomation
可以用三个可选参数初始化:
trackingEnabled
: 如果启用了追踪功能。eventsTimerTime
: 发送事件和视图到 MBurger 的的频率。
触发器
每个来自 MBurger 的的内嵌消息或推送通知都可以有一个触发器数组,这些触发器由 MBAutomation SDK 管理并评估,只有当定义的条件满足时才会显示消息。
触发器可以分为两种方法:
any
: 一旦其中一个触发器变为真,则向用户显示消息。all
: 所有触发器都需要为真才能显示消息。
以下是自动化 SDK 管理的触发器列表:
-
App 开启
MBAppOpeningTrigger
: 当应用被打开 n 次(times
属性)时变为真,检查在应用启动时。
-
事件
MBEventTrigger
: 当事件发生 n 次(times
属性)时变为真。
-
无活动用户
MBInactiveUserTrigger
: 用户在 n 天内没有打开应用时变为真(days
参数)。
-
位置
MBLocationTrigger
: 用户进入指定经纬度范围内的位置时变为真(latitude
、longitude
和radius
)。此触发器可以在延迟 n 天后激活(afterDays
属性)。位置数据来自 MBAudience SDK。
-
标签更改
MBTagChangeTrigger
: 当 MBAudience SDK 中的标签更改并与值相等或不相等时变为真。它具有tag
属性(需要检查的标签)和value
属性(需要等于或不同的值来激活触发器)。
-
视图
MBViewTrigger
: 用户进入视图 n 次(times
属性)时变为真。如果secondsOnView
需要用户停留秒数来激活触发器。
发送事件
你可以使用 MBAutomation
发送事件:
MBAutomation.sendEvent('EVENT_NAME');
你可以指定两个可选参数:name
(名称,将在 MBurger 控制台中显示)和 metadata
(额外字段的映射)。
MBAutomation.sendEvent(
'purchase',
name: "PURCHASE",
metadata: {"quantity": 1},
);
事件保存在本地数据库中,并每 10 秒发送到服务器。你可以通过设置 eventsTimerTime
属性来更改频率。
视图跟踪
为了自动跟踪视图,请将一个实例的 MBAutomationNavigatorObserver
添加到 navigatorObservers
中:
[@override](/user/override)
Widget build(BuildContext context) {
return MaterialApp(
navigatorObservers: [MBAutomationNavigatorObserver()],
home: ...,
);
}
导航观察者会在每次新路由推入或弹出时将 PageRoute
的名称(route.settings.name
)发送给 MBurger。
如果你不想使用导航观察者,可以手动使用此函数来跟踪视图:
MBAutomation.trackScreenView('VIEW');
就像事件一样,视图保存在本地数据库中,并每 10 秒发送到服务器。你可以通过设置 eventsTimerTime
属性来更改频率。
示例代码
下面是一个完整的示例代码,展示了如何使用 MBAutomation
进行自动化控制:
import 'package:flutter/material.dart';
import 'package:mbautomation/mbautomation.dart';
import 'package:mburger/mburger.dart';
import 'package:mbaudience/mbaudience.dart';
import 'package:mbmessages/mbmessages.dart';
void main() {
runApp(const MyApp());
}
class MyApp extends StatefulWidget {
const MyApp({Key? key}) : super(key: key);
[@override](/user/override)
State<MyApp> createState() => _MyAppState();
}
class _MyAppState extends State<MyApp> {
[@override](/user/override)
void initState() {
MBManager.shared.apiToken = 'YOUR_API_TOKEN';
MBManager.shared.plugins = [
MBAutomation(),
MBAudience(),
MBMessages(
onButtonPressed: (button) {
debugPrint(button.toString());
},
),
];
_configurePushNotifications();
super.initState();
}
Future<void> _configurePushNotifications() async {
MBMessages.pushToken = 'YOUR_PUSH_API_KEY';
MBMessages.onToken = (token) async {
debugPrint("Token received $token");
await MBMessages.registerDevice(token).catchError(
(error) => debugPrint(error),
);
await MBMessages.registerToTopics(
[
await MBMessages.projectPushTopic(),
await MBMessages.devicePushTopic(),
const MPTopic(code: 'Topic'),
],
).catchError(
(error) => debugPrint(error),
);
debugPrint('Registered');
};
MBMessages.configurePush(
onNotificationArrival: (notification) {
debugPrint("Notification arrived: $notification");
},
onNotificationTap: (notification) {
debugPrint("Notification tapped: $notification");
},
androidNotificationsSettings: const MPAndroidNotificationsSettings(
channelId: 'mpush_example',
channelName: 'mpush',
channelDescription: 'mpush',
icon: '@mipmap/icon_notif',
),
);
MBMessages.requestToken();
Map<String, dynamic>? launchNotification =
await MBMessages.launchNotification();
debugPrint(launchNotification?.toString());
}
[@override](/user/override)
Widget build(BuildContext context) {
return MaterialApp(
navigatorObservers: [MBAutomationNavigatorObserver()],
home: MBMessagesBuilder(
child: Scaffold(
appBar: AppBar(
title: const Text('MBAutomation example app'),
),
body: Center(
child: TextButton(
child: const Text('Send Event'),
onPressed: () => _sendEvent(),
),
),
),
),
);
}
void _sendEvent() {
MBAutomation.sendEvent('EVENT_NAME');
}
}
更多关于Flutter自动化控制插件mbautomation的使用的实战教程也可以访问 https://www.itying.com/category-92-b0.html
更多关于Flutter自动化控制插件mbautomation的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html
当然,关于Flutter自动化控制插件mbautomation
的使用,下面是一个简单的代码示例,展示如何集成和使用该插件来进行一些基本的自动化控制操作。请注意,实际使用中你可能需要根据具体需求进行进一步的配置和调整。
首先,确保你已经在pubspec.yaml
文件中添加了mbautomation
依赖:
dependencies:
flutter:
sdk: flutter
mbautomation: ^最新版本号 # 替换为实际的最新版本号
然后,运行flutter pub get
来安装依赖。
接下来是一个简单的Flutter应用示例,展示如何使用mbautomation
插件:
import 'package:flutter/material.dart';
import 'package:mbautomation/mbautomation.dart';
void main() {
runApp(MyApp());
}
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter mbautomation Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: MyHomePage(),
);
}
}
class MyHomePage extends StatefulWidget {
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
MbAutomationController? _mbAutomationController;
@override
void initState() {
super.initState();
// 初始化MbAutomationController
_mbAutomationController = MbAutomationController();
// 示例:注册一个设备并设置一些参数(这里需要根据实际设备进行调整)
_mbAutomationController!.registerDevice(
deviceId: 'your_device_id',
deviceType: 'your_device_type',
ip: 'your_device_ip',
port: your_device_port, // 替换为整数类型的端口号
);
// 示例:执行一个简单的自动化操作,比如点击某个坐标
_mbAutomationController!.click(
deviceId: 'your_device_id',
x: 100,
y: 200,
).then((result) {
print('Click operation result: $result');
}).catchError((error) {
print('Click operation error: $error');
});
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('Flutter mbautomation Demo'),
),
body: Center(
child: Text('Check the console for automation operation results.'),
),
);
}
@override
void dispose() {
// 释放资源
_mbAutomationController?.dispose();
super.dispose();
}
}
注意:
- 在上面的代码中,
deviceId
,deviceType
,ip
,port
等参数需要根据你实际使用的设备进行调整。 MbAutomationController
的具体方法和参数可能会根据插件的版本有所不同,因此请参考最新的官方文档或插件源码来获取最准确的信息。- 由于
mbautomation
插件可能涉及与具体硬件设备的通信,因此在实际开发中,你可能需要处理更多的错误检查和异常处理逻辑。
这个示例只是一个简单的起点,展示了如何集成和使用mbautomation
插件。根据你的具体需求,你可能需要实现更复杂的功能,比如滑动、输入文本、获取屏幕截图等。你可以参考插件的官方文档或源码来获取更多详细信息和示例代码。