Flutter图像显著性检测插件apple_vision_saliency的使用

Flutter图像显著性检测插件apple_vision_saliency的使用

apple_vision_saliency 是一个用于在 Flutter 应用中实现苹果视觉显著性检测功能的插件。通过该插件,您可以利用 Apple 的 Vision 框架进行图像显著性检测。

插件信息

Apple Vision Saliency Detection 是一个使 Flutter 应用能够使用 Apple Vision Saliency Segmentation 的插件。

注意: 此插件并非由 Apple 赞助或维护。作者是一些希望为 macOS 开发类似 Google ML Kit 的开发者。

系统需求

MacOS

  • 最低 macOS 部署目标:10.15
  • Xcode 13 或更新版本
  • Swift 5
  • ML Kit 仅支持 64 位架构(x86_64 和 arm64)

iOS

  • 目前不支持开发
  • 最低 iOS 部署目标:13.0
  • Xcode 13 或更新版本
  • Swift 5
  • ML Kit 仅支持 64 位架构(x86_64 和 arm64)

使用步骤

首先,在 Dart 文件中导入 apple_vision_saliency 包:

import 'package:apple_vision_saliency/apple_vision_saliency.dart';

初始化控制器和设置相机

initState 方法中初始化 AppleVisionSaliencyController 控制器,并设置相机。

class VisionSaliency extends StatefulWidget {
  const VisionSaliency({
    Key? key,
    this.onScanned
  }):super(key: key);

  final Function(dynamic data)? onScanned; 

  [@override](/user/override)
  _VisionSaliency createState() => _VisionSaliency();
}

class _VisionSaliency extends State<VisionSaliency>{
  final GlobalKey cameraKey = GlobalKey(debugLabel: "cameraKey");
  late AppleVisionSaliencyController visionController = AppleVisionSaliencyController();
  InsertCamera camera = InsertCamera();
  Size imageSize = const Size(640,640*9/16);
  String? deviceId;
  bool loading = true;

  List<Uint8List?>? saliencyImage;
  late double deviceWidth;
  late double deviceHeight;

  [@override](/user/override)
  void initState() {
    camera.setupCameras().then((value){
      setState(() {
        loading = false;
      });
      camera.startLiveFeed((InputImage i){
        if(i.metadata?.size != null){
          imageSize = i.metadata!.size;
        }
        if(mounted) {
          Uint8List? image = i.bytes;
          visionController.processImage(
            SaliencySegmentationData(
              image: rgba2bitmap(image!, imageSize.width.toInt(), imageSize.height.toInt()),//image!, 
              imageSize: i.metadata!.size,
              type: SaliencyType.object
            )
          ).then((data){
            saliencyImage = data;
            setState(() {
              
            });
          });
        }
      });
    });
    super.initState();
  }

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

构建UI

构建一个包含相机预览和显著性检测结果的 UI。

[@override](/user/override)
Widget build(BuildContext context) {
  deviceWidth = MediaQuery.of(context).size.width;
  deviceHeight = MediaQuery.of(context).size.height;
  return ListView(
    children:<Widget>[
      SizedBox(
        width: 320, 
        height: 320*9/16, 
        child: loading?Container():CameraSetup(camera: camera, size: imageSize)
      ),
      if(saliencyImage?[0] != null) SizedBox(
        width: 320, 
        height: 320*9/16,  
        child: Stack(children: [
          Image.memory(
            saliencyImage![0]!,
            fit: BoxFit.fitHeight,
          )
        ],)
      )
    ]
  );
}

加载指示器

创建一个加载指示器以在加载过程中显示。

Widget loadingWidget(){
  return Container(
    width: deviceWidth,
    height: deviceHeight,
    color: Theme.of(context).canvasColor,
    alignment: Alignment.center,
    child: const CircularProgressIndicator(color: Colors.blue)
  );
}

示例代码

以下是一个完整的示例代码,展示了如何使用 apple_vision_saliency 插件进行图像显著性检测。

import 'package:apple_vision_saliency/apple_vision_saliency.dart';
import 'package:flutter/material.dart';
import '../camera/camera_insert.dart';
import 'package:flutter/foundation.dart';
import 'package:flutter/services.dart';
import 'camera/input_image.dart';

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

class MyApp extends StatelessWidget {
  const MyApp({super.key});

  [@override](/user/override)
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: const VisionSaliency(),
    );
  }
}

class VisionSaliency extends StatefulWidget {
  const VisionSaliency({
    Key? key,
    this.onScanned
  }):super(key: key);

  final Function(dynamic data)? onScanned; 

  [@override](/user/override)
  _VisionSaliency createState() => _VisionSaliency();
}

class _VisionSaliency extends State<VisionSaliency>{
  final GlobalKey cameraKey = GlobalKey(debugLabel: "cameraKey");
  late AppleVisionSaliencyController visionController = AppleVisionSaliencyController();
  InsertCamera camera = InsertCamera();
  Size imageSize = const Size(640,640*9/16);
  String? deviceId;
  bool loading = true;

  List<Uint8List?>? saliencyImage;
  late double deviceWidth;
  late double deviceHeight;

  [@override](/user/override)
  void initState() {
    camera.setupCameras().then((value){
      setState(() {
        loading = false;
      });
      camera.startLiveFeed((InputImage i){
        if(i.metadata?.size != null){
          imageSize = i.metadata!.size;
        }
        if(mounted) {
          Uint8List? image = i.bytes;
          visionController.processImage(
            SaliencySegmentationData(
              image: rgba2bitmap(image!, imageSize.width.toInt(), imageSize.height.toInt()),//image!, 
              imageSize: i.metadata!.size,
              type: SaliencyType.object
            )
          ).then((data){
            saliencyImage = data;
            setState(() {
              
            });
          });
        }
      });
    });
    super.initState();
  }

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

  [@override](/user/override)
  Widget build(BuildContext context) {
    deviceWidth = MediaQuery.of(context).size.width;
    deviceHeight = MediaQuery.of(context).size.height;
    return ListView(
      children:<Widget>[
        SizedBox(
          width: 320, 
          height: 320*9/16, 
          child: loading?Container():CameraSetup(camera: camera, size: imageSize)
        ),
        if(saliencyImage?[0] != null) SizedBox(
          width: 320, 
          height: 320*9/16,  
          child: Stack(children: [
            Image.memory(
              saliencyImage![0]!,
              fit: BoxFit.fitHeight,
            )
          ],)
        )
      ]
    );
  }

  Widget loadingWidget(){
    return Container(
      width: deviceWidth,
      height: deviceHeight,
      color: Theme.of(context).canvasColor,
      alignment: Alignment.center,
      child: const CircularProgressIndicator(color: Colors.blue)
    );
  }
}

更多关于Flutter图像显著性检测插件apple_vision_saliency的使用的实战教程也可以访问 https://www.itying.com/category-92-b0.html

1 回复

更多关于Flutter图像显著性检测插件apple_vision_saliency的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html


apple_vision_saliency 是一个用于在 Flutter 中进行图像显著性检测的插件,它基于 Apple 的 Vision 框架。显著性检测是指识别图像中最显著(即最吸引人注意力)的区域。这个插件可以帮助你在 Flutter 应用中实现图像显著性检测功能。

安装插件

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

dependencies:
  flutter:
    sdk: flutter
  apple_vision_saliency: ^x.x.x  # 请使用最新版本

然后运行 flutter pub get 来安装插件。

使用插件

以下是一个简单的示例,展示如何使用 apple_vision_saliency 插件进行图像显著性检测。

import 'package:flutter/material.dart';
import 'package:apple_vision_saliency/apple_vision_saliency.dart';
import 'package:image_picker/image_picker.dart';
import 'dart:io';

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

class _SaliencyDetectionPageState extends State<SaliencyDetectionPage> {
  File? _image;
  List<SaliencyRegion>? _saliencyRegions;

  Future<void> _pickImage() async {
    final pickedFile = await ImagePicker().getImage(source: ImageSource.gallery);

    setState(() {
      if (pickedFile != null) {
        _image = File(pickedFile.path);
        _saliencyRegions = null;
      } else {
        print('No image selected.');
      }
    });

    if (_image != null) {
      _detectSaliency();
    }
  }

  Future<void> _detectSaliency() async {
    if (_image == null) return;

    final saliencyDetector = AppleVisionSaliency();
    final saliencyRegions = await saliencyDetector.detectSaliency(_image!);

    setState(() {
      _saliencyRegions = saliencyRegions;
    });
  }

  [@override](/user/override)
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Saliency Detection'),
      ),
      body: Column(
        children: [
          _image != null
              ? Image.file(_image!)
              : Text('No image selected.'),
          if (_saliencyRegions != null)
            Expanded(
              child: ListView.builder(
                itemCount: _saliencyRegions!.length,
                itemBuilder: (context, index) {
                  final region = _saliencyRegions![index];
                  return ListTile(
                    title: Text('Region ${index + 1}'),
                    subtitle: Text('Confidence: ${region.confidence}'),
                  );
                },
              ),
            ),
        ],
      ),
      floatingActionButton: FloatingActionButton(
        onPressed: _pickImage,
        tooltip: 'Pick Image',
        child: Icon(Icons.image),
      ),
    );
  }
}

void main() {
  runApp(MaterialApp(
    home: SaliencyDetectionPage(),
  ));
}
回到顶部