Flutter-Mac开发环境搭建

1.获取Flutter SDK

1)去flutter官网下载其最新可用的安装包
下载地址:https://flutter.dev/docs/development/tools/sdk/releases#macos

image.png

下载最新的稳定版本
2)将下载的安装包解压到指定安装目录

可以在根目录下单独新建一个安装文件夹
cmd+shift+g 输入根路径 ~/
新建文件夹- Flutter,把下载的安装包解压后的flutter文件拖进去

或者使用终端操作 :

$ cd ~/   
$ mkdir Flutter  
$ cd ~/Flutter  
$ unzip ~/Downloads/flutter_macos_v1.20.4.zip
flutter-1.png
2.设置flutter相关工具到path中,使用flutter指令
// 使用vim打开bash_profile文件  
$ vim ~/.bash_profile  

输入i,进入插入模式,设置下面环境变量  
export PATH=~/Flutter/flutter/bin:$PATH  
export PUB_HOSTED_URL=https://pub.flutter-io.cn  
export FLUTTER_STORAGE_BASE_URL=https://storage.flutter-io.cn  
点击esc,退出当前模式,输入:wq!或者:x保存内容并退出。

// 更新bash_profile文件  
$source ~/.bash_profile
flutter-2.png

注:
若终端使用的是zsh,下次打开命令行运行提示 zsh: command not found: flutter
flutter命令是一次性的,需要重新执行$source ~/.bash_profile

解决方案:
open ~/.zshrc
在后面添加source ~/.bash_profile

3.测试flutter指令及检查flutter环境
// 查看 flutter 帮助文件   
$flutter -h  
若提示flutter命令不存在,检查第二步是否出错

// 检查flutter依赖项   
$flutter doctor

flutter-3.png

根据提示安装Android Studio
下载地址1:http://www.androiddevtools.cn/

下载地址2:https://developer.android.google.cn/studio/

安装完成后,打开Andriod Studio ,安装flutter插件
Android Studio–>Preferences–>点击Plugins在输入框中输入flutter–>点击安装即可

安装完成后,重启Android Studio

// 安装完成后再次检查flutter安装环境  
$flutter doctor
flutter-4.png
// 若出现Android licenses not accepted 错误,按照要求运行命令
$ flutter doctor --android-licenses  
然后根据提示一直y,y到结束为止。

// 完成后继续检查flutter 安装环境  
$flutter doctor
flutter-5.png

出现 • No issues found! 环境配置就完成了!

若安装Android Studio (version 4.1),由于插件安装目录与之前的安装目录发生变化,doctor检测时会检测不到安装的flutter和dart插件

旧目录: ~/Library/Application\ Support/AndroidStudio4.1
新目录: ~/Library/Application\ Support/Google/AndroidStudio4.1/plugins

解决办法指令软链接一下目录:

ln -s ~/Library/Application\ Support/Google/AndroidStudio4.1/plugins ~/Library/Application\ Support/AndroidStudio4.1
4.创建flutter项目

创建flutter项目时可以看到
Create New Flutter Project 选择 Flutter Application 创建项目

flutter-6.png
flutter-7.png
5.flutter项目结构分析

android:Andorid相关代码目录,里面代码配置和单独创建Andorid项目有些不一样。

ios:iOS相关代码目录,存放Flutter与ios原生交互的一些代码。

lib:应用源文件,dart文件,核心文件,可以创建不同的文件夹,存放不同文件。flutter开发文件主要在此目录下完成。

test:测试文件。

.gitignore:忽略文件,记录一些不需要关注变更记录的文件,就是不添加到版本记录里面。

.metadata:记录一些Flutter。 project一些基本信息,如版本,项目类型。

.packages:记录一些lib文件的路径。

.iml:是由IntelliJ IDEA创建的模块文件,用于开发Java应用程序的IDE。它存储有关开发模块的信息,该模块可能是Java,Plugin,Android或Maven组件; 保存模块路径,依赖关系和其他设置。

pubspec.lock:这是根据当前项目依赖所生成的文件,记录当前使用的依赖版本。

pubspec.yaml:包含Flutter应用程序的包数据,这个是配置依赖项的文件,比如配置远程public仓库的依赖项,或者本地资源(图片,音视频)。

README.md:项目信息介绍。

6.运行项目

编辑main.dart 文件,可以尝试显示个“Hello world”,把main.dart中所有代码去掉,替换为下面代码:

import 'package:flutter/material.dart';

//这个是Dart中单行函数或者方法的简写
void main() => runApp(MyApp());

//程序继承StatelessWidget,该应用程序成为一个widget,在Flutter中,大多数东西都是widget
class MyApp extends StatelessWidget {
  // 这个是应用的根widget
  @override
  Widget build(BuildContext context) {
    //注意:一个app只能有一个MaterialApp
    return MaterialApp(
      //标题栏的名字
      title: 'Hello Flutter',
      //这个是Material library提供的一个widget,它提供了默认的导航栏、标题栏
      //包含主屏幕的widget树的body属性
      home:new Scaffold(
        appBar:new AppBar(
          title:const Text("Weclome to Flutter"),
        ),
        body:const Center(
          child:const Text("Hello World"),
        ),
    ),
    );
  }
}

选择模拟器,运行!


flutter-8.png

若无法连接模拟器,可以重启Android Studio,重起仍然无法连接,执行命令行:
sudo xcode-select --switch /Applications/Xcode.app/Contents/Developer

然后重启Android Studio 就能正常连接了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,362评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,330评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,247评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,560评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,580评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,569评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,929评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,587评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,840评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,596评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,678评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,366评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,945评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,929评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,165评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,271评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,403评论 2 342

推荐阅读更多精彩内容