Flutter视频直播插件vidvliveness_flutter_plugin的使用

Flutter视频直播插件vidvliveness_flutter_plugin的使用

Getting Started

这个项目是一个新的Flutter插件项目。它包含适用于Android和/或iOS的平台特定实现代码。

示例代码

以下是一个完整的示例代码,展示了如何在Flutter应用中使用vidvliveness_flutter_plugin插件。

import 'package:flutter/material.dart';
import 'dart:async';
import 'dart:convert';
import 'dart:io';
import 'package:http/http.dart' as http;
import 'package:flutter/services.dart';
import 'package:image_picker/image_picker.dart';
import 'package:vidvliveness_flutter_plugin/vidvliveness_flutter_plugin.dart';
import 'package:pretty_http_logger/pretty_http_logger.dart';

void main() {
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: LivenessPage(),
    );
  }
}

class LivenessPage extends StatefulWidget {
  @override
  _LivenessPageState createState() => _LivenessPageState();
}

class _LivenessPageState extends State<LivenessPage> {
  final String baseURL = 'https://www.valifystage.com/';
  final String bundleKey = 'ad44eb94ca6747beaf99eef02407221f';
  final String userName = 'mobileusername';
  final String password = '3B8uGe8bNTquN84';
  final String clientID = 'aKM21T4hXpgHFsgNJNTKFpaq4fFpoQvuBsNWuZoQ';
  final String clientSecret = 'r0tLrtxTue8c4kNmPVgaAFNGSeCWvL4oOZfBnVXoQe2Ffp5rscXXAAhX50BaZEll8ZRtr2BlgD3Nk6QLOPGtjbGXYoCBL9Fn7QCu5CsMlRKDbtwSnUAfKEG30cIv8tdW';

  //  final String baseURL = "https://www.yfilav.com";
  // final String userName = "iosteam";
  // final String password = "dGsS#pj3wTkJjxG";
  // final String clientID = "k9zsWUI8hTmhadldFl98NNKlmDCYz6wa87GrhtEX";
  // final String clientSecret = "gyqKT05CMIVvmwZ5USJyR0OSL9dGJJfERt6Nlh3IqJNgrhUUAegid6sB3Hnu4cvLiPaEBvjoxv7HOMxvCwDjB4gMLgGShp2gqw1NJKW6lwZxncVuOa8XoMeX217L5pZ0";
  // final String bundleKey = "80f0ea4958a04685bf016a6ce10cff83";
  // final String hmacBundle = "46fadad8ebc0e2836f49439ee65caa4b42eb2bb1741e6cc69fd7c4024dda34e10a070c1fd8f855c99359c57c110c242e7685432f70504696b6f9ecbd749da8c3";

  String _livenessResult = '';
  String base64Image = "";
  String imagePicked = "No Image Picked";

  Future<String?> getToken() async {
    final String url = '$baseURL/api/o/token/';
    HttpWithMiddleware httpWithMiddleware = HttpWithMiddleware.build(middlewares: [
      HttpLogger(logLevel: LogLevel.BODY),
    ]);
    final Map<String, String> headers = {
      'Content-Type': 'application/x-www-form-urlencoded',
    };

    final String body =
        'username=$userName&password=$password&client_id=$clientID&client_secret=$clientSecret&grant_type=password';

    final http.Response response = await httpWithMiddleware.post(
      Uri.parse(url),
      headers: headers,
      body: body,
    );

    if (response.statusCode == 200) {
      final Map<String, dynamic> jsonResponse = json.decode(response.body);
      return jsonResponse['access_token'];
    } else {
      print('Failed to retrieve token: ${response.statusCode}');
      return null;
    }
  }

  Future<void> pickImage() async {
    final ImagePicker _picker = ImagePicker();
    final XFile? image = await _picker.pickImage(source: ImageSource.gallery);

    if (image != null) {
      final bytes = await File(image.path).readAsBytes();
      final base64 = base64Encode(bytes);
      setState(() {
        imagePicked = "Image Picked Successfully";
        base64Image = base64;
      });
    } else {
      setState(() {
        base64Image = '';
      });
    }
  }

  Future<void> startLiveness() async {
    String? token;

    try {
      token = await getToken();
      if (token == null) {
        setState(() {
          _livenessResult = 'Failed to get token';
        });
        return;
      }
    } catch (e) {
      setState(() {
        _livenessResult = 'Error retrieving token: $e';
      });
      return;
    }
    Map<String, dynamic> params = {
      'base_url': baseURL,
      'access_token': token,
      'bundle_key': bundleKey,
      'language': 'en',
      'liveness_time_per_action': '10',
      'liveness_number_of_instructions': '5',
      'enable_smile': false,
      'enable_look_right': true,
      'enable_close_eyes': true,
      'enable_voiceover': true,
      'primary_color': '#FF5733',
      'show_error_message': true,
      'facematch_image': base64Image,
    };

    try {
      final result = await VidvlivenessFlutterPlugin.startLiveness(params);
      setState(() {
        _livenessResult = result.toString();
      });
    } catch (e) {
      setState(() {
        _livenessResult = 'Error: $e';
      });
    }
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Liveness Detection'),
      ),
      body: Padding(
        padding: const EdgeInsets.all(16.0),
        child: Column(
          children: [
            ElevatedButton(
              onPressed: pickImage,
              child: Text('Select Image from Gallery'),
            ),
            SizedBox(height: 10),
            if (base64Image.isNotEmpty)
              Text(
                'Image Selected',
                style: TextStyle(color: Colors.green),
              ),
            ElevatedButton(
              onPressed: startLiveness,
              child: Text('Start Liveness Detection'),
            ),
            SizedBox(height: 20),
            SingleChildScrollView(
              child: Column(
                children: [
                  Text('Liveness Result: $_livenessResult'),
                ],
              ),
            ),
          ],
        ),
      ),
    );
  }
}

使用说明

  1. 初始化项目: 确保你的Flutter项目已经设置好,并且可以运行。

  2. 添加依赖: 在pubspec.yaml文件中添加vidvliveness_flutter_pluginimage_picker依赖:

    dependencies:
      flutter:
        sdk: flutter
      vidvliveness_flutter_plugin:
      image_picker:
    

更多关于Flutter视频直播插件vidvliveness_flutter_plugin的使用的实战教程也可以访问 https://www.itying.com/category-92-b0.html

1 回复

更多关于Flutter视频直播插件vidvliveness_flutter_plugin的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html


vidvliveness_flutter_plugin 是一个用于视频直播的 Flutter 插件,通常用于集成活体检测和视频流功能。使用这个插件可以帮助开发者在 Flutter 应用中实现视频直播、活体检测等功能。

以下是一个基本的使用步骤和示例代码,帮助你理解如何使用 vidvliveness_flutter_plugin

1. 添加依赖

首先,你需要在 pubspec.yaml 文件中添加 vidvliveness_flutter_plugin 插件的依赖。

dependencies:
  flutter:
    sdk: flutter
  vidvliveness_flutter_plugin: ^1.0.0  # 请根据实际情况填写版本号

然后运行 flutter pub get 来获取依赖。

2. 导入插件

在你的 Dart 文件中导入插件:

import 'package:vidvliveness_flutter_plugin/vidvliveness_flutter_plugin.dart';

3. 初始化插件

在使用插件之前,通常需要对其进行初始化。你可以在 initState 方法中进行初始化。

class VideoLivePage extends StatefulWidget {
  [@override](/user/override)
  _VideoLivePageState createState() => _VideoLivePageState();
}

class _VideoLivePageState extends State<VideoLivePage> {
  VidvLivenessFlutterPlugin _vidvPlugin;

  [@override](/user/override)
  void initState() {
    super.initState();
    _vidvPlugin = VidvLivenessFlutterPlugin();
    _vidvPlugin.initialize();
  }

  [@override](/user/override)
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Video Live'),
      ),
      body: Center(
        child: Text('Video Live Page'),
      ),
    );
  }
}

4. 开始视频直播

你可以使用插件提供的方法来开始视频直播。以下是一个简单的示例:

void _startVideoLive() async {
  try {
    await _vidvPlugin.startVideoLive();
  } catch (e) {
    print('Failed to start video live: $e');
  }
}

5. 处理活体检测

如果插件支持活体检测功能,你可以在视频直播过程中进行活体检测。以下是一个简单的示例:

void _performLivenessCheck() async {
  try {
    bool isLive = await _vidvPlugin.performLivenessCheck();
    if (isLive) {
      print('Liveness check passed');
    } else {
      print('Liveness check failed');
    }
  } catch (e) {
    print('Failed to perform liveness check: $e');
  }
}

6. 停止视频直播

在不需要视频直播时,你可以停止直播:

void _stopVideoLive() async {
  try {
    await _vidvPlugin.stopVideoLive();
  } catch (e) {
    print('Failed to stop video live: $e');
  }
}

7. 处理生命周期

确保在页面销毁时释放资源:

[@override](/user/override)
void dispose() {
  _vidvPlugin.dispose();
  super.dispose();
}

完整示例代码

以下是一个完整的示例代码,展示了如何使用 vidvliveness_flutter_plugin 进行视频直播和活体检测:

import 'package:flutter/material.dart';
import 'package:vidvliveness_flutter_plugin/vidvliveness_flutter_plugin.dart';

class VideoLivePage extends StatefulWidget {
  [@override](/user/override)
  _VideoLivePageState createState() => _VideoLivePageState();
}

class _VideoLivePageState extends State<VideoLivePage> {
  VidvLivenessFlutterPlugin _vidvPlugin;

  [@override](/user/override)
  void initState() {
    super.initState();
    _vidvPlugin = VidvLivenessFlutterPlugin();
    _vidvPlugin.initialize();
  }

  void _startVideoLive() async {
    try {
      await _vidvPlugin.startVideoLive();
    } catch (e) {
      print('Failed to start video live: $e');
    }
  }

  void _performLivenessCheck() async {
    try {
      bool isLive = await _vidvPlugin.performLivenessCheck();
      if (isLive) {
        print('Liveness check passed');
      } else {
        print('Liveness check failed');
      }
    } catch (e) {
      print('Failed to perform liveness check: $e');
    }
  }

  void _stopVideoLive() async {
    try {
      await _vidvPlugin.stopVideoLive();
    } catch (e) {
      print('Failed to stop video live: $e');
    }
  }

  [@override](/user/override)
  void dispose() {
    _vidvPlugin.dispose();
    super.dispose();
  }

  [@override](/user/override)
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Video Live'),
      ),
      body: Center(
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          children: [
            ElevatedButton(
              onPressed: _startVideoLive,
              child: Text('Start Video Live'),
            ),
            SizedBox(height: 20),
            ElevatedButton(
              onPressed: _performLivenessCheck,
              child: Text('Perform Liveness Check'),
            ),
            SizedBox(height: 20),
            ElevatedButton(
              onPressed: _stopVideoLive,
              child: Text('Stop Video Live'),
            ),
          ],
        ),
      ),
    );
  }
}
回到顶部