Flutter——Android原生View是如何通过Flutter进行加载

原生视图是如何通过Flutter进行加载渲染和交互

  • 介绍
  • 一句话概括
    • [1.在 Android 原生代码中注册 PlatformView](#1.在 Android 原生代码中注册 PlatformView)
    • [2.Flutter 中使用 PlatformViewLink 加载这个原生 View](#2.Flutter 中使用 PlatformViewLink 加载这个原生 View)

介绍

Flutter 中加载 Android 原生视图(View) ,这是完全可以实现的,Flutter 提供了官方支持:PlatformView(平台视图)机制。

一句话概括

在 Flutter 中通过 PlatformView 将 Android 原生视图(如 TextView、WebView、MapView 等)嵌入到 Flutter 的 Widget 树中。

1.在 Android 原生代码中注册 PlatformView

先创建NativeViewFactory视图类

kotlin 复制代码
class NativeTextView(context: Context, id: Int, creationParams: Map<String?, Any?>?) : PlatformView {
    private val textView: TextView = TextView(context).apply {
        text = "这是原生 Android TextView"
        textSize = 20f
        setTextColor(Color.RED)
    }

    override fun getView(): View {
        return textView
    }

    override fun dispose() {}
}

class NativeTextViewFactory(private val messenger: BinaryMessenger) : PlatformViewFactory(StandardMessageCodec.INSTANCE) {
    override fun create(context: Context, id: Int, obj: Any?): PlatformView {
        val creationParams = obj as? Map<String?, Any?>
        return NativeTextView(context, id, creationParams)
    }
}

然后在创建Plugin类,并进行注册:

kotlin 复制代码
class NativeViewPlugin : FlutterPlugin {
    override fun onAttachedToEngine(flutterPluginBinding: FlutterPlugin.FlutterPluginBinding) {
        flutterPluginBinding
            .platformViewRegistry
            .registerViewFactory("native-text-view", NativeTextViewFactory(flutterPluginBinding.binaryMessenger))
    }

    override fun onDetachedFromEngine(binding: FlutterPlugin.FlutterPluginBinding) {}
}

创建Widget视图,进行渲染

dart 复制代码
import 'package:flutter/material.dart';
import 'package:flutter/services.dart';

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

  @override
  Widget build(BuildContext context) {
    const String viewType = 'native-text-view';
    return AndroidView(
      viewType: viewType,
      layoutDirection: TextDirection.ltr,
      creationParams: {},
      creationParamsCodec: const StandardMessageCodec(),
    );
  }
}

在Flutter页面中使用

dart 复制代码
import 'package:flutter/material.dart';
import 'native_text_view.dart';

class MyPage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      body: Center(
        child: SizedBox(
          height: 100,
          width: 300,
          child: NativeTextView(),
        ),
      ),
    );
  }
}
相关推荐
weiggle5 小时前
第七篇:状态提升与单向数据流——架构设计的核心
android
xingpanvip5 小时前
星盘接口开发文档:本命盘接口指南
android·开发语言·css·php·lua
goldenrolan5 小时前
A公司物料替代测试系统 v1.7:从需求到 exe/apk 的 AI 辅助全链路实践
android·自动化测试·软件测试·python·ai
AC赳赳老秦6 小时前
用 OpenClaw 搭建服务器故障应急响应系统,自动处理 80% 常见运维故障
android·运维·服务器·python·rxjava·deepseek·openclaw
风华圆舞7 小时前
Flutter + 鸿蒙 Intents Kit:页面直达能力的完整接入方案
flutter·ui·华为·harmonyos
韩曙亮7 小时前
【Flutter】Flutter 组件 ④ ( 组件渲染 的 三棵树理论 | Widget 树 → Element 树 → RenderObject 树 )
flutter·element·widget·renderobject
骇客之技术7 小时前
AutoLua:在安卓上写 Lua 脚本
android·junit·lua
kiros_wang8 小时前
Android 常见面试题
android
货拉拉技术9 小时前
Hook植入日志协助定位问题方案
android
FlightYe9 小时前
Android投屏MirrorCast全链路
android