Flutter插件sdk_sdc_flutter的使用方法详解
Flutter插件sdk_sdc_flutter的使用方法详解
本插件桥接了Au10tix原生的Smart Document Capture (SDC) SDK。该插件提供了相关的API,可以用于创建自定义的SDC用户界面/用户体验,或者使用Au10tix SDC UI组件。
Flutter插件sdk_sdc_flutter开始使用
要开始使用,请参考我们的示例项目,并查看readme文件。
请注意,这里的示例标签仅展示了main.dart
,它演示了如何初始化SDK,但并未展示如何使用SDC组件。main
导入了一个名为sdc_page
的类,该类展示了如何使用SDC,并且可以在我们的示例项目中找到这里。
示例代码
以下是一个完整的示例,展示了如何使用sdk_sdc_flutter
插件:
// ignore_for_file: use_key_in_widget_constructors
import 'package:flutter/foundation.dart';
import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
import 'package:sdk_core_flutter/sdk_core_flutter.dart';
import 'package:sdk_sdc_flutter/sdk_sdc_flutter.dart';
import 'package:sdk_sdc_flutter_example/constants.dart';
import 'package:sdk_sdc_flutter_example/poa_page.dart';
import './sdc_page.dart';
import 'package:sdk_core_flutter/ui_config.dart';
void main() {
runApp(const MyApp());
}
class MyApp extends StatelessWidget {
const MyApp({Key? key}) : super(key: key);
[@override](/user/override)
Widget build(BuildContext context) {
return MaterialApp(
title: 'Au10tix Flutter SDC Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: HomePage(),
routes: {
SDCPage.routeName: (ctx) => SDCPage(),
POAPage.routeName: (ctx) => POAPage(),
},
);
}
}
class HomePage extends StatelessWidget {
static const String _authToken = workflowResponse;
var sdcUIResult;
Future<void> _prepareSDK(BuildContext context) async {
try {
final result = await Au10tix.init(_authToken);
if (result.containsKey("init")) {
_showToast(context, result["init"].toString(), Colors.green);
}
} on PlatformException catch (error) {
_showToast(context, error.message!, Colors.red);
// ignore: empty_catches
} catch (error) {}
}
Future<void> _sendWorkflowRequest(BuildContext context) async {
try {
final result = await Au10tix.sendWorkflowRequest();
if (result.containsKey("beKit")) {
_showToast(
context, result["beKit"]["message"].toString(), Colors.green);
}
} on PlatformException catch (error) {
_showToast(context, error.message!, Colors.red);
// ignore: empty_catches
} catch (error) {}
}
Future<void> _sendFEC(BuildContext context) async {
try {
final result =
await SdkSdcFlutter.performFEC(sdcUIResult['sdc']['croppedFilePath']);
if (result.containsKey("fec")) {
print(result["fec"].toString());
_showToast(
context,
'FEC Result = ${result["fec"]["classificationResult"].toString()}',
Colors.green);
}
} on PlatformException catch (error) {
_showToast(context, error.message!, Colors.red);
// ignore: empty_catches
} catch (error) {}
}
Future<void> _startSDCUI({bool isFrontSide = true}) async {
try {
//UI config is optional
UIConfig uiConfig = UIConfig(
showIntroScreen: true,
showCloseButton: true,
showPrimaryButton: true,
canUpload: true);
sdcUIResult = await SdkSdcFlutter.startSDCUI(
uiConfig: uiConfig, isFrontSide: isFrontSide);
if (kDebugMode) {
print(sdcUIResult.toString());
}
} on PlatformException catch (error) {
if (kDebugMode) {
print(error.message);
}
}
}
Future<void> _startPOAUI() async {
try {
//UI config is optional
UIConfig uiConfig = UIConfig(
showIntroScreen: true,
showCloseButton: true,
showPrimaryButton: true,
canUpload: true);
final result = await SdkSdcFlutter.startPOAUI(uiConfig: uiConfig);
if (kDebugMode) {
print(result.toString());
}
} on PlatformException catch (error) {
if (kDebugMode) {
print(error.message);
}
}
}
[@override](/user/override)
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: const Text('Plugin sdc example app'),
),
body: Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: [
ElevatedButton(
onPressed: () => _prepareSDK(context),
child: const Text("Prepare SDK"),
),
ElevatedButton(
onPressed: () => Navigator.of(context).pushNamed(
SDCPage.routeName,
arguments: {"isFrontSide": true}),
child: const Text("Start SDC - Front"),
),
ElevatedButton(
onPressed: () => Navigator.of(context).pushNamed(
SDCPage.routeName,
arguments: {"isFrontSide": false}),
child: const Text("Start SDC - Back"),
),
ElevatedButton(
onPressed: () => _startSDCUI(),
child: const Text("Start SDC UI - Front"),
),
ElevatedButton(
onPressed: () => _startSDCUI(isFrontSide: false),
child: const Text("Start SDC UI - Back"),
),
ElevatedButton(
onPressed: () =>
Navigator.of(context).pushNamed(POAPage.routeName),
child: const Text("Start POA"),
),
ElevatedButton(
onPressed: () => _startPOAUI(),
child: const Text("Start POA UI"),
),
ElevatedButton(
onPressed: () => _sendWorkflowRequest(context),
child: const Text("Send Workflow Request"),
),
ElevatedButton(
onPressed: () => _sendFEC(context),
child: const Text("Send FEC Request"),
),
],
),
),
);
}
}
void _showToast(BuildContext context, String message, Color bgColor) {
final scaffold = ScaffoldMessenger.of(context);
scaffold.showSnackBar(
SnackBar(
content: Text(message),
backgroundColor: bgColor,
),
);
}
更多关于Flutter插件sdk_sdc_flutter的使用方法详解的实战教程也可以访问 https://www.itying.com/category-92-b0.html
更多关于Flutter插件sdk_sdc_flutter的使用方法详解的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html
sdk_sdc_flutter
是一个 Flutter 插件,可能用于与某些特定的 SDK 或服务进行集成。由于这个插件的名称和功能并不常见,我无法提供具体的文档或使用指南。不过,我可以给你一些通用的步骤,帮助你探索和使用这个插件。
1. 查找插件文档
首先,尝试查找 sdk_sdc_flutter
插件的官方文档或 GitHub 仓库。通常,插件的文档会提供详细的安装和使用说明。
- 在 pub.dev 上搜索
sdk_sdc_flutter
,查看是否有相关插件。 - 在 GitHub 上搜索
sdk_sdc_flutter
,查看是否有开源项目或文档。
2. 安装插件
如果你找到了插件的 pub.dev 页面,可以按照以下步骤安装插件:
在你的 pubspec.yaml
文件中添加依赖:
dependencies:
sdk_sdc_flutter: ^版本号
然后运行 flutter pub get
来安装插件。
3. 导入插件
在你的 Dart 文件中导入插件:
import 'package:sdk_sdc_flutter/sdk_sdc_flutter.dart';
4. 初始化插件
通常,插件需要在使用前进行初始化。查看插件的文档,了解是否需要调用 initialize()
或其他初始化方法。
void main() async {
WidgetsFlutterBinding.ensureInitialized();
await SdkSdcFlutter.initialize();
runApp(MyApp());
}
5. 使用插件功能
根据插件的功能,尝试调用其提供的方法。例如,如果插件提供了某个 SDK 的功能,可能会有一个 doSomething()
方法:
void someFunction() async {
var result = await SdkSdcFlutter.doSomething();
print(result);
}
6. 调试和日志
如果插件提供了日志功能,启用日志以帮助调试:
SdkSdcFlutter.setLogLevel(LogLevel.debug);
7. 处理错误
确保你正确处理了插件可能抛出的错误或异常:
try {
var result = await SdkSdcFlutter.doSomething();
} catch (e) {
print('Error: $e');
}