鸿蒙Flutter三方库适配指南-02.Flutter相关知识基础

鸿蒙Flutter三方库适配指南:Flutter相关知识基础

Flutter 三层结构

  1. Dart 层(Framework 层)

使用 Dart 语言 编写

提供了 UI 框架(widgets、material、cupertino) 和 渲染、手势、动画 等上层 API

面向开发者,负责 业务逻辑 与 界面搭建

  1. C/C++ 层(Engine 层)

Flutter 的 引擎核心,主要用 C/C++ 编写

包含 Skia/Impeller 图形渲染引擎、文本排版(libtxt)、Dart VM

负责 图形渲染、文本排版、GPU 加速 等底层性能相关工作

  1. Platform-dependent 层(Embedder 层)

负责与 宿主操作系统(Android、iOS、HarmonyOS、Windows、macOS、Linux) 的交互

提供 事件处理(输入、手势)、系统 API 调用、插件通信(Platform Channels)

不同平台有各自的 embedder 实现,使 Flutter 可以运行在不同系统上

Dart 语言基础知识

Dart 是一种面向对象的编程语言,Flutter 使用 Dart 作为其主要开发语言。

dart 复制代码
// 变量声明
String hi = 'hello';

// 常量声明
const String hello = 'hello';

// 类定义
class Person {
  String name = '';
  int age = 0;

  Person(String n, int a) {
    name = n;
    age = a;
  }

  String getName() {
    return name;
  }
}

Person p1 = Person('Alice', 25);

注组

在 Flutter 中,通常使用注解来标识组件和入口点:

dart 复制代码
// 主程序入口
void main() => runApp(MyApp());

// 组件装饰器
class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      home: Scaffold(
        appBar: AppBar(title: Text('Hello')),
        body: Center(child: Text('Hello World')),
      ),
    );
  }
}

Flutter 与 ArkUI 对比

对比维度 Flutter ArkUI
开发语言 Dart ArkTS
架构层次 Dart Framework → C++ Engine → Platform Embedder ArkUI Framework(ArkTS) → ArkUI Engine → HarmonyOS 系统服务
渲染引擎 Skia 渲染 自研 ArkUI 渲染引擎
平台支持 Android / iOS / Windows / macOS / Linux / Web HarmonyOS / OpenHarmony
开发体验 热重载、Widget 声明式 UI ArkTS 声明式 UI、实时预览(Previewer)
插件机制 Platform Channels + FFI 调用,插件生态丰富 模块化开发 + 系统 API 调用,生态成长中
生态现状 全球活跃开发者 280 万+,pub.dev 插件库庞大 -
优势 跨平台统一 UI、生态成熟 原生性能高、系统集成度深、分布式支持
适用场景 跨平台应用、多端兼容 鸿蒙原生应用、分布式设备协同

语法对比

Flutter ArkUI

参考资料

相关推荐
博客-小覃19 小时前
Zabbix之华为交换机的日志记录信息操作详细教程
服务器·网络·华为·zabbix
不羁的木木1 天前
Form Kit(卡片开发服务)学习笔记01-核心概念与架构设计
笔记·学习·harmonyos
不羁的木木1 天前
ArkWeb实战学习笔记01-核心概念与架构设计
笔记·学习·harmonyos
Goway_Hui1 天前
【鸿蒙原生应用开发--ArkUI--010】Recipe-app 菜谱应用开发教程
华为·harmonyos
●VON1 天前
鸿蒙 BodyAR 实战:基于人体骨骼追踪的体感运动计数器开发全解
华为·ar·harmonyos·鸿蒙·新特性
Davina_yu1 天前
页面路由导航:Router与Navigation组件的跳转传参(7)
harmonyos·鸿蒙·鸿蒙系统
Ww.xh1 天前
鸿蒙WebView IPC防伪造请求方案
华为·harmonyos
大雷神1 天前
第25篇|Surface 预览控制:ArkUI 页面如何接住相机画面
harmonyos
大雷神1 天前
第24篇|相机权限和设备枚举:先判断能力再打开预览
harmonyos
川石课堂软件测试1 天前
使用mock进行接口测试教程
数据库·python·功能测试·测试工具·华为·单元测试·appium