為您解碼網(wǎng)站建設(shè)的點點滴滴
發(fā)表日期:2018-12 文章編輯:小燈 瀏覽次數(shù):7343
[TOC]
寫在最前面,想玩flutter最好有科學(xué)上網(wǎng)的梯子,否則被墻的整個人都暴躁了
在目標(biāo)目錄使用git拉取flutter的sdk
# 移動到目標(biāo)目錄 cd ${HOME}/env # 拉取sdk git clone https://github.com/flutter/flutter.git
需要提前配置好安卓開發(fā)環(huán)境,可以提前配置好jdk,android sdk等環(huán)境變量
需要配置flutter sdk的環(huán)境變量
需要配置flutter的鏡像地址
PUB_HOSTED_URL=https://pub.flutter-io.cn FLUTTER_STORAGE_BASE_URL=https://storage.flutter-io.cn
# jdk begin JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk1.8.0_144.jdk/Contents/Home # jdk end # android sdk begin ANDROID_HOME=/Users/rexih/Library/Android/sdk ADB_HOME=/Users/rexih/Library/Android/sdk/platform-tools # android sdk end #android ndk begin NDK_HOME=/Users/rexih/Library/Android/sdk/ndk-bundle CMAKE_HOME=/Users/rexih/Library/Android/sdk/cmake/3.6.4111459 #android ndk end # flutter begin FLUTTER_HOME=/Users/rexih/env/flutter PUB_HOSTED_URL=https://pub.flutter-io.cn FLUTTER_STORAGE_BASE_URL=https://storage.flutter-io.cn # flutter end PATH=$FLUTTER_HOME/bin:$FLUTTER_HOME:$CMAKE_HOME/bin:$ANDROID_HOME/:$ANDROID_HOME/tools:$ADB_HOME:$NDK_HOME:$JAVA_HOME/bin:$PATH:. CLASSPATH=JAVA_HOME/lib/tools.jar:$JAVA_HOME/lib/dt.jar:. export JAVA_HOME export ANDROID_HOME export ADB_HOME export NDK_HOME export CMAKE_HOME export PATH export CLASSPATH export FLUTTER_HOME export PUB_HOSTED_URL export FLUTTER_STORAGE_BASE_URL
打開as(本文使用的是3.2.1 stable)的plugin,下載插件Flutter
,會自動下載插件Dart
,確保兩個插件勾選,重啟as
flutter提供doctor
指令幫助用戶診斷開發(fā)環(huán)境是否可用,根據(jù)命令行里的診斷結(jié)果逐步修復(fù)即可
第一次運行會自動下載Dart SDK
Downloading Dart SDK from Flutter engine# ... Building flutter tool... # ... Flutter assets will be downloaded from https://storage.flutter-io.cn. Make sure you trust this source! # ... Doctor summary (to see all details, run flutter doctor -v): # ...
診斷結(jié)果會告知去設(shè)置Android SDK的環(huán)境變量
診斷結(jié)果會告知運行flutter doctor --android-licenses
通過licenses以使用
[!] Android toolchain - develop for Android devices (Android SDK version 28.0.3) ! Some Android licenses not accepted.To resolve this, run: flutter doctor --android-licenses
診斷結(jié)果會告知安裝AS插
[!] Android Studio (version 3.2) ? Flutter plugin not installed; this adds Flutter specific functionality. ? Dart plugin not installed; this adds Dart specific functionality.
診斷結(jié)果會告知運行設(shè)備情況
[!] Connected device ! No devices available
診斷結(jié)果會告知idea和iOS的開發(fā)環(huán)境的可用性
國內(nèi)被墻的很嚴(yán)重。gradle下載太慢了。建議先下載好gradle的對應(yīng)版本,放置到本地gradle倉庫里,以加快構(gòu)建速度。(移動寬帶直接下載也挺慢的)
手動下載gradle對應(yīng)版本。例如下載gradle 4.10.2 地址:https://downloads.gradle.org/distributions/gradle-4.10.2-all.zip,下載完成后放到${HOME}/.gradle/wrapper/dists/gradle-4.10.2-all/9fahxiiecdb76a5g3aw9oi8rv
,解壓,修改文件鎖gradle-4.10.2-all.zip.ok
使用鏡像替代flutter的腳本倉庫。找到flutter sdk的根目錄,打開packages/flutter_tools/gradle/flutter.gradle
,修改倉庫地址
buildscript { repositories { maven { url "https://maven.aliyun.com/repository/google" } maven { url "https://maven.aliyun.com/repository/jcenter" } maven { url "http://maven.aliyun.com/nexus/content/groups/public" } // google() // jcenter() } dependencies { classpath 'com.android.tools.build:gradle:3.2.1' } }
?
配置好開發(fā)環(huán)境后,AS新建項目時會增加新的創(chuàng)建選項Start a new Flutter project
設(shè)置項目名稱時,必須遵守其命名規(guī)范,小寫加_
下劃線,否則會提示
Invalid project name: 'T' - must be a valid Dart package name (lower_case_with_underscores)
點擊播放鍵編譯運行項目
修改后,不點擊播放鍵,直接ctrl+s
保存一下源文件,發(fā)現(xiàn)設(shè)備上直接同步了修改
- 要查看您的更改, 只需調(diào)用 Save All (
cmd-s
/ctrl-s
), 或點擊 熱重載按鈕 (帶有閃電??圖標(biāo)的按鈕).
flutter devices1 connected device:Android SDK built for x86 ? emulator-5554 ? android-x86 ? Android 9 (API 28) (emulator)
# 查看可用版本 flutter channel # 切換到stable版本 flutter channel stable # 切換版本后再次調(diào)用flutter指令會重新配置開發(fā)環(huán)境 flutter
9212-flutter
6351-dart
查看項目目錄下是否已經(jīng)生成項目文件,如果有,強制關(guān)閉as進程,重啟后打開此項目
Waiting for another flutter command to release the startup lock…
參見issues 7768
改android里build.gradle腳本的倉庫源
buildscript { repositories { maven { url 'https://maven.aliyun.com/repository/google' } maven { url 'https://maven.aliyun.com/repository/jcenter' } maven { url 'http://maven.aliyun.com/nexus/content/groups/public' } //google() //jcenter() }dependencies { classpath 'com.android.tools.build:gradle:3.2.1' } }allprojects { repositories { maven { url 'https://maven.aliyun.com/repository/google' } maven { url 'https://maven.aliyun.com/repository/jcenter' } maven { url 'http://maven.aliyun.com/nexus/content/groups/public' } //google() //jcenter() } }
日期:2018-10 瀏覽次數(shù):7274
日期:2018-12 瀏覽次數(shù):4345
日期:2018-07 瀏覽次數(shù):4891
日期:2018-12 瀏覽次數(shù):4187
日期:2018-09 瀏覽次數(shù):5516
日期:2018-12 瀏覽次數(shù):9938
日期:2018-11 瀏覽次數(shù):4823
日期:2018-07 瀏覽次數(shù):4595
日期:2018-05 瀏覽次數(shù):4870
日期:2018-12 瀏覽次數(shù):4337
日期:2018-10 瀏覽次數(shù):5153
日期:2018-12 瀏覽次數(shù):6229
日期:2018-11 瀏覽次數(shù):4482
日期:2018-08 瀏覽次數(shù):4602
日期:2018-11 瀏覽次數(shù):12654
日期:2018-09 瀏覽次數(shù):5595
日期:2018-12 瀏覽次數(shù):4848
日期:2018-10 瀏覽次數(shù):4202
日期:2018-11 瀏覽次數(shù):4541
日期:2018-12 瀏覽次數(shù):6077
日期:2018-06 瀏覽次數(shù):4018
日期:2018-08 瀏覽次數(shù):5452
日期:2018-10 瀏覽次數(shù):4466
日期:2018-12 瀏覽次數(shù):4547
日期:2018-07 瀏覽次數(shù):4372
日期:2018-12 瀏覽次數(shù):4513
日期:2018-06 瀏覽次數(shù):4401
日期:2018-11 瀏覽次數(shù):4387
日期:2018-12 瀏覽次數(shù):4262
日期:2018-12 瀏覽次數(shù):5297
Copyright ? 2013-2018 Tadeng NetWork Technology Co., LTD. All Rights Reserved.