自己开发app需要学习flutter

Flutter是一款由谷歌推出的开源移动应用程序开发框架。它允许开发人员使用一套代码同时开发iOS和Android平台的应用程序。Flutter使用Dart编程语言,这是一种基于类的面向对象语言,它非常易于学习和编写,因为Dart语言本质上是一种结构简单、可读性强的语言。

Flutter的特点

Flutter最大的特点就是快速开发,它内置了许多UI组件并且可以任意自定义,给开发者非常便捷和自由。Flutter还需要的功能进行扩展时,它的可扩展性非常好,也支持插件来扩展功能,而这些插件都是由社区开发人员提供的,因此,这些插件不仅拥有丰富的功能,还能够让开发者更好的掌握代码。此外,Flutter还使用了现代的开发方法,例如Reactive Programming,它使用感知数据和快速反应的方式来实现UI的构建。

Flutter的实现原理

Flutter通过它的自有渲染引擎Skia,直接通过OpenGL ES或VK GPU进行绘制,跨平台的同时使用GPU硬件加速,因此获得了非常出色的性能表现。Flutter利用Skia进行图形渲染,流程如下:

1.将UI描述解析为一棵解析树。

2.收集这个解析树的绘制命令,并将它们发送到GPU进行渲染。

3.随着用户界面更新,只更新那些需要的部分,从而保持了界面的响应性。

Flutter的架构

Flutter具有基于组件的体系结构,组件:

1、自带拥有完整的UI响应能力

2、需要处理和绘制UI的生命周期

3、自身处理输入和触控事件

所有的组件都继承自最基础的Widget类,所以我们一般称Flutter应用程序由widget构建。

Flutter开发环境配置

1、在官网或者Github上下载Flutter SDK,解压,配置环境变量等全局设置。

2、安装Flutter插件

3、使用Flutter Doctor检测安装是否完全

开发一个简单的Flutter应用程序

需要了解以下几个重要的Widget:

1、MaterialApp

入口Widget,用于运行MaterialDesign的应用

2、Material

代表了一个Material风格的组件,例如,Material支持Material的圆角、阴影、SelectableText等,如果继承了Material组件,这个Widget就享受了material design的美好体验。

3、Scaffold

代表一个典型的页面布局,例如AppBar、Drawer、SnackBar、FloatingActionButton这些都是Scaffold中的字段。

4、Text

这是Flutter中常用的一个组件,用于在页面中显示纯文本。

实现步骤:

// 导入Flutter SDK的核心库

import 'package:flutter/material.dart';

// 自定义组件 MyApp,继承 StatelessWidget 类

class MyApp extends StatelessWidget {

// 重写 build 方法

@override

Widget build(BuildContext context) {

// 返回一个 MaterialApp 组件,作为页面根组件

return MaterialApp(

debugShowCheckedModeBanner: false, // 去除 Debug 的图标

title: '美好人生', // 页面标题

home: Scaffold(

// AppBar 组件,用于顶部导航栏

appBar: AppBar(

title: Text('Flutter AppBar'), // Text 组件顶部标题

),

// 剩余部分的组件,本文只演示文本组件

body: Center( // Center组件用于剩余部分居中

child: Text( // Text组件

'❤ 一个拥抱,一个未来。❥(^_-)', // Text组件中的文本内容

style: TextStyle(fontSize: 25.0), // TextStyle组件样式,更多属性可以查看官方文档

),

),

),

);

}

}

// main 方法作为程序的入口

void main() {

runApp(MyApp()); // 启动 MyApp 组件

}

这是一个简单的Flutter应用程序,其中由MaterialApp作为页面根组件,包含一个AppBar组件和一个文本组件。在这个示例中,我们演示了文本组件的使用,Flutter中提供了丰富的UI组件,只需按照需要选择相应的组件,在通过它们的属性进行设置即可实现所需的UI效果。

结论

Flutter是一种非常强大的移动应用程序开发框架,它具有可重用性和可扩展性,特别适用于中小企业或者个人开发者,通过Flutter框架可以快速构建iOS和Android平台的应用程序,并且Flutter还可以节约开发的时间和开发成本。最重要的是,掌握Flutter之后可以让你更好地了解各种移动应用程序的开发。