Flutter

本页使用了标题或全文手工转换,现处于中国大陆简体模式
求闻百科,共笔求闻
Flutter
原作者Google
开发者Google与社区
首次发布Alpha (v0.0.6) / 2017年5月,​7年前​(2017-05[1]
稳定版本
3.10.5
(2023年6月13日,​11个月前​(2023-06-13[2][3]
编程语言CC++Dart[4]
系统平台AndroidiOSGoogle Fuchsia、Web平台、WindowsmacOSLinux
类型应用框架
网站flutter.dev

Flutter是一个由谷歌开发的开源移动应用软件开发工具包,用于为AndroidiOS、Windows、Mac、Linux、Google Fuchsia开发应用[5]

Flutter第一个版本支持Android操作系统,开发代号称作“Sky”。 它于2015年4月的Flutter开发者会议上被公布,宣称其目标为实现120FPS渲染性能[6]。在上海Google Developer Days的主题演讲中,Google宣布了Flutter Release Preview 2,这是Flutter 1.0之前的最后一个重要版本。2018年12月4日,Flutter 1.0在Flutter Live活动中发布,是该框架的第一个“稳定”版本。[7]2019年12月11日,在Flutter Interactive活动上发布了Flutter 1.12,宣布Flutter是第一个为环境计算设计的UI平台[8]

框架组织

Flutter的主要组成部分包括:

  • Dart平台
  • Flutter引擎
  • 基础库
  • 定制化设计语言的组件
  • Flutter DevTools

Dart平台

Flutter是使用Dart语言编写,并利用该语言的许多高级功能。[9]

WindowsmacOSLinux上,Flutter在Dart虚拟机中运行,该虚拟机具有即时编译执行引擎。在编写和调试应用时,Flutter使用即时编译功能进行“热重载”,可以将对源文件的修改注入正在运行的应用中。Flutter通过支持有状态的热重载来扩展此功能,在大多数情况下,对源代码的更改可以立即在运行的应用中反映出来,而无需重新启动或丢失任何状态。[10]Flutter实现的此功能已广受赞誉。

Flutter应用的发布版本在Android和iOS上都进行了提前(AOT, Ahead Of Time)编译[11],使Flutter在移动设备上可以高性能地运行。

Flutter引擎

Flutter的引擎主要使用C++开发,通过Google的Skia图形库提供底层渲染支持,亦提供平台相关的SDK,例如AndroidiOS[9]。Flutter引擎是用于托管Flutter应用的可移植的运行环境。它实现了Flutter的核心库,包括动画和图形、文件和网络I/O、可访问性支持、插件架构以及Dart运行环境和编译工具链。大多数开发人员将通过Flutter框架与Flutter进行交互,该框架提供了一个现代、响应式的框架,以及一组丰富的平台、布局和基础组件。

基础库

基础库由Dart编写,提供了用Flutter构建应用所需的基本的类和函数,例如与引擎通讯的API[12]

组件

Flutter是通过组织、创建不同的组件完成用户界面设计的。在Flutter中,一个组件代表用户界面中不可变的一部分;包括文本、多边形以及动画在内的所有图形都是用组件创建的。复杂的组件由简单的组件结合而成。

定制化设计风格的组件

Flutter框架包含了两套符合特定设计语言组件。 称作Material Design的组件实现的是同名的谷歌设计语言,称作Cupertino的组件实现苹果公司iOS的人机接口指南(Human interface guidelines)[9][13][14][15]

Hello World示例

一个Flutter中的Hello World程序如下所示:

import 'package:flutter/material.dart';

void main() => runApp(HelloWorldApp());

class HelloWorldApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Hello World App',
      home: Scaffold(
        appBar: AppBar(
          title: Text('Hello World App'),
        ),
        body: Center(
          child: Text('Hello World'),
        ),
      ),
    );
  }
}

参考文献

  1. Chris Bracken. Release v0.0.6: Rev alpha branch version to 0.0.6, flutter 0.0.26 (#10010) · flutter/flutter. GitHub. [2018-08-08]. 
  2. Flutter SDK releases. flutter.dev. [2021-10-16]. 
  3. Releases – Flutter. GitHub. [2021-10-16]. 
  4. FAQ - Flutter. [2018-08-08]. 
  5. Google’s "Fuchsia" smartphone OS dumps Linux, has a wild new UI. Ars Technica. [2018-04-03]. 
  6. Amadeo, Ron. Google’s Dart language on Android aims for Java-free, 120 FPS apps. Ars Technica. 2015-05-01 [2018-04-03]. 
  7. Speed Up Native Development As Google Flutter Comes Out Of Beta. Appetiser Apps. [2018-12-21] (英语). 
  8. Flutter: the first UI platform designed for ambient computing. Flutter blog (英语). 
  9. 9.0 9.1 9.2 Technical Overview - Flutter. flutter.io. [2017-12-13] (英语). 
  10. Lelel, Wm. Why Flutter Uses Dart. HackerNoon. 2018-02-26 [2018-12-05]. 
  11. stephenwzl. Flutter’s Compilation Patterns. ProAndroidDev. 2018-08-01 [2018-12-06]. 
  12. foundation library - Dart API. [2017-12-13] (英语). 
  13. Material Design Widgets - Flutter. flutter.dev. [2017-12-13] (英语). 
  14. Cupertino (iOS-style) Widgets - Flutter. flutter.dev. [2017-12-13] (英语). 
  15. Human Interface Guidelines. developer.apple.com. [2019-10-08] (英语). 

外部链接