饭宝 发表于 2025-1-22 22:40:58

Flutter中PlatformView在鸿蒙中的使用

概述

集成平台视图(后称为平台视图)允许将原生视图嵌入到 Flutter 应用中,所以你可以通过 Dart 将变换、裁剪和不透明度等结果应用到原生视图。
例如,这使你可以通过使用平台视图直接在 Flutter 应用内部使用鸿蒙中的原生舆图。
在Flutter中的处置惩罚

首先我们需要再Flutter中创建一个视图,用来加载Ohos平台的view。
import 'dart:async';

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

typedef OnViewCreated = Function(CustomViewController);

class CustomOhosView extends StatefulWidget {
final OnViewCreated onViewCreated;
const CustomOhosView(this.onViewCreated, {super.key});

@override
State<CustomOhosView> createState() => _CustomOhosViewState();
}

class _CustomOhosViewState extends State<CustomOhosView> {
late MethodChannel _channel;

@override
Widget build(BuildContext context) {
    return _getPlatformFaceView();
}

Widget _getPlatformFaceView() {
    // 加载platformview
    /**
   * viewType:传递给Native侧,告知插件需要创建那个PlatformView,这个PlatformView需要在插件初始化时注册。
      onPlatformViewCreated:PlatformView创建成功时的回调。
      creationParams:传递给PlatformView的初始化参数。
   */
    return OhosView(
      viewType: 'com.rex.custom.ohos/customView',
      onPlatformViewCreated: _onPlatformViewCreated,
      creationParams: const <String, dynamic>{'initParams': 'hello world'},
      creationParamsCodec: const StandardMessageCodec(),
    );
}

void _onPlatformViewCreated(int id) {
    print("platformview==================创建成功");
    _channel = MethodChannel('com.rex.custom.ohos/customView$id');
    final controller = CustomViewController._(
      _channel,
    );
    widget.onViewCreated(controller);
}
}

// 用于实现Dart侧与Native侧的交互
class CustomViewController {
final MethodChannel _channel;
final StreamController<String> _controller = StreamController<String>();

CustomViewController._(
      this._channel,
      ) {
    _channel.setMethodCallHandler(
          (call) async {
      switch (call.method) {
          case 'getMessageFromOhosView':
          // 从native端获取数据
            final result = call.arguments as String;
            _controller.sink.add(result);
            break;
      }
      },
    );
}

Stream<String> get customDataStream => _controller.stream;

// 发送数据给native
Future<void> sendMessageToOhosView(String message) async {
    await _channel.invokeMethod(
      'getMessageFromFlutterView',
      message,
    );
}
}
鸿蒙端

创建内嵌的鸿蒙视图

该视图就是我们ohos平台中的组件, 示例代码如下:
@Component
export struct PlatformView_Custom {
@Prop params: Params

// customView: video_Customview = this.params.platformView as video_Customview

build() {
    Column() {
      Column() {
      Button("测试按钮")
          .onClick(() => {
            console.log("点击按钮时间")
          })

      }
      .backgroundColor(Color.Orange)
      .height('230vp')
      .width('100%')
      .justifyContent(FlexAlign.End)
    }
    .backgroundColor(Color.Pink)
      .width('100%')
      .height('100%')

}
}
注意:PlatformView_Custom 嵌入到Flutter页面中时, 体系实际上是在我们的这个组件又包裹了一层空间, 并且默认是布满Flutter父空间的全部空间。
创建PlatformView

我们需要创建一个PlatformView的子类,并实现并且实现MethodCallHandler接口。
该类有两个作用:

[*]通过类中的getView(): WrappedBuilder<>{}方法把上面创建的鸿蒙组件加载到这个PlatformView上
[*]实现MethodCallHandler接口, 负责和Flutter的相干通信
示例代码如下:
/**
* @ProjectName : ohos
* @FileName : PlatformView_plugin
* @Author : issuser
* @Time : 2024/10/11 9:33
* @Description : 文件描述
*/
import {
BinaryMessenger,
MethodCall, MethodCallHandler, MethodChannel, MethodResult, PlatformView,
StandardMethodCodec } from '@ohos/flutter_ohos';
import { Params } from '@ohos/flutter_ohos/src/main/ets/plugin/platform/PlatformView';
import { PlatformView_Custom } from './PlatformView_Custom';
import { common } from '@kit.AbilityKit';

export class PlatformView_plugin extends PlatformView implements MethodCallHandler {
numValue: string = "test";

methodChannel: MethodChannel;
index: number = 1;

// 构造方法
constructor(context: common.Context, viewId: number, args: ESObject, message: BinaryMessenger) {
    super();

    // 注册消息通道,消息通道根据具体需求添加,代码仅作为示例
    this.methodChannel = new MethodChannel(message, `com.rex.custom.ohos/video_CustomView${viewId}`, StandardMethodCodec.INSTANCE);
    // 给通道添加监听
    this.methodChannel.setMethodCallHandler(this);
}

// 实现onMethodCall接口
onMethodCall(call: MethodCall, result: MethodResult): void {
    // 接受Dart侧发来的消息
    let method: string = call.method;
    let link1: SubscribedAbstractProperty<number> = AppStorage.link('numValue');
    switch (method) {
      case 'video_getMessageFromFlutterView':
      let value: ESObject = call.args;
      this.numValue = value;
      link1.set(value)
      console.log("nodeController receive message from dart: " + this.numValue);
      result.success(true);
      break;
    }
}

//返回鸿蒙要展示的视图
getView(): WrappedBuilder<> {
    return new WrappedBuilder(platformBuilder)
}

// 生命周期方法 销毁时
dispose(): void {
    throw new Error('Method not implemented.');
}

}

// 全局的build函数,通过这个bbuilder函数返回我们的组件view
@Builder
function platformBuilder(param: Params) {
PlatformView_Custom({params: param})
    .backgroundColor(Color.Green)
}
创建PlatformViewFactory

PlatformView类的创建是通过PlatformViewFactory来创建, 所以我们需要创建一个工厂类继承自PlatformViewFactory。
示例代码:
// 通过工厂方法创建一个plaugin示例
export class CustomFactory extends PlatformViewFactory {
message: BinaryMessenger;
constructor(message: BinaryMessenger, createArgsCodes: MessageCodec<Object>) {
    super(createArgsCodes);
    this.message = message;
}

public create(context: Context, viewId: number, args: Object): PlatformView {
    return new PlatformView_plugin(context, viewId, args, this.message);
}
}
创建plugin,注册platformview

新建一个继承于FlutterPlugin的CustomPlugin插件,在onAttachedToEngine中,注册自定义的PlatformViewFactory
示例代码:
import { StandardMessageCodec } from '@ohos/flutter_ohos';
import {
FlutterPlugin,
FlutterPluginBinding
} from '@ohos/flutter_ohos/src/main/ets/embedding/engine/plugins/FlutterPlugin';
import { CustomFactory } from './CustomFactory';

export class CustomPlugin implements FlutterPlugin {
getUniqueClassName(): string {
    return 'CustomPlugin'
}
       
// 当插件挂载到引擎上时
onAttachedToEngine(binding: FlutterPluginBinding): void {
    // 在插件挂在在引擎的时候, 我们需要注册我们的view
    binding.getPlatformViewRegistry()?.
    registerViewFactory('com.rex.custom.ohos/customView',
      new CustomFactory(binding.getBinaryMessenger(), StandardMessageCodec.INSTANCE));
}

onDetachedFromEngine(binding: FlutterPluginBinding): void {
    throw new Error('Method not implemented.');
}
}
注册插件

在EntryAblitity中注册我们创建的自定义插件:
export default class EntryAbility extends FlutterAbility {
configureFlutterEngine(flutterEngine: FlutterEngine) {
    super.configureFlutterEngine(flutterEngine)
    GeneratedPluginRegistrant.registerWith(flutterEngine)
    // 注册platformview的自定义插件
    this.addPlugin(new CustomPlugin());
}
}
然后执行flutter build hap命令进行编译, 配置相干证书, 运行。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: Flutter中PlatformView在鸿蒙中的使用