iT邦幫忙

第 11 屆 iT 邦幫忙鐵人賽

DAY 30
6
Mobile Development

iOS Developer Learning Android系列 第 30

iOS Developer Learning Android. Lesson 30 - 精彩大結局 (重點整理: 看這一天等於看30天)


耶~終於完賽了~
終於可以結束每天都兩點以後睡的日子了~
也可以開始訂閱Apple Arcade了~XD
其實大家都說,寫技術文章是為了自己,我也這麼認為
但這個系列賽我捫心自問,的確是很用心寫
也盡量考慮到讀者的心情
不過不管是點閱數或是互動上都很冷清
著實有點灰心呢....
不知道是不是技術深度不足;還是文筆太差
不論如何,算是對自己有個交代,也有學到東西
真是可喜可賀

之後,我還會繼續地在手機跨平台開發的路上繼續前進
下一個目標是RN、再來是Fultter....
為此,我也組了一個LINE群,希望對"跨平台"開發有興趣的小夥伴們可以一起討論(iOS跟安卓已有專群了)
或是只要您是iOS Developer對安卓有問題的,都歡迎在下面留言,我盡量回覆您(如果是專業Android開發者的問題我可能扛不住XD)
最後,
畢竟文章是寫給人看的
如果我的文章有那麼一點點幫助到您
麻煩您點個喜歡/收藏
【這邊】
或隨意留個言
對我來說都是莫大的鼓舞
謝謝

本系列文章受到陳董 - Kotlin連續三十天動手做很大的啟發,在此特別感謝


Android手機想要下載請去這邊

若要看圖文對照請至基哈普


先來個動動牆

直的牆沒fu,要看真正的牆去這裡(出頭真的很多)

下面是針對各主題的摘要

Lesson 01 - Android Studio

  • 大致介紹了AS的板面配置: 像這樣
  • 最大的差別在於Android有規定各種檔案存放的路徑
  • 再來以前Xcode只有一個Consolo,AS分成Log、Build、Run
  • 要執行除錯模式斷點才會停

Lesson 02 - Hello World

  • Log有分類型v,d,i,w,e,分別對應Verbose,Debug,Info,Warn,Error
  • 模擬器要自己下載
  • 實機要啟用開發者模式

Lesson 03 - 專案相關設定

  • AndroidManifest 跟 Gradle是Android兩個很重要的設定檔,類似xcodeproj
  • Gradle有類似podfile可以裝套件
  • 另外這集有講怎麼設定icon跟Target

Lesson 04 - Activity生命週期

  • Activity就是類似ViewController的東西
  • 因為他們沒有NavigationController,所以要切換Activity要透過Intent去call startActivity(類似present)
  • life cycle對照表
iOS Android
VDL onCreate
WillEnterForeground onRestart
VWA, DidBecomeActive onStart
VDA onResume
VWD, WillResignActive onPause
VDD, DidEnterBackground onStop
dealloc onDestroy

Lesson 05 - Activity啟動模式

  • 就是決定要不要new一個新的Activity
  • Standard: 不管怎樣都一定產生一個新的Activity出來。
  • Single Top: 如果要去的Activity已經在Task的Top的話,就直接拿來用,不然的話才new。
  • Single Task: 該Task只有一個Activity,如果Task已存在就pop回去,中間的Activity就都出棧。
  • Single Instance: 比照Single Task,有就pop,沒有才new,但會new在另一條Task

Lesson 06 - 如何製作畫面

  • 可以用拉的,AS會自動產生XML
  • XML是人類看得懂的,也可以自己寫XML,寫的時候可以即時預覽
  • 也可以用Java寫畫面

Lesson 07 - Layout

  • 類似self.view地位,但會安排subView的位置,主要這三種:
  • Linear Layout: 畫面很簡單的時候用
  • Relative Layout: 以前比較常用,現在應該都用ConstraintLayout
  • Frame Layout: Fragment會用到

Lesson 08 - ConstraintLayout基礎

  • 就是類似AutoLayout的東西,介紹基本用法

Lesson 09 - ConstraintLayout特色

  • Guideline: 輔助線,可以拿來算比例
  • Chain: 把多個物件串起來,自動分配位置(像stackView),但好用很多
  • gone: 物件不顯示了,而且位置還會被其他元件替補
  • CircleAngle: 可以用角度去算

Lesson 10 - TextView + EditText

  • 基本介紹
Android iOS
TextView UILabel
EditText UITextField
  • 不用寫code就可做到跑馬燈跟UITextView自動長高

Lesson 11 - Button + Dialog

  • 基本介紹
Android iOS
Button UIButton
Dialog UIAlertController
  • 基本上Android的元件事件都是用監聽(setOnXXXXXListener)給他一個Closure
  • Alert可以用鏈式寫法一路點下去很爽
  • 有個小提示叫做Toast,可以顯示訊息給user
    像這樣

Lesson 12 - ImageView + ImagePicker

  • 基本介紹
Android iOS
ImageView UIImageView
Bitmap UIImage
  • 圖片檔名連一個大寫都不能出現= =,不然就會build不起來
  • scaleType就是以前的UIContentMode
    1. UIViewContentModeScaleToFill = fitXY
    2. UIViewContentModeScaleAspectFit = fitCenter
    3. UIViewContentModeScaleAspectFill = centerCrop
  • 圖片可能會被轉90度,還不知道怎麼解!!!
  • 模擬器可以測相機

Lesson 13 - Spinner + DatePickerDialog

  • 基本介紹
Android iOS
Spinner UIPickerView
DatePickerDialog UIDatePicker

Lesson 14 - SeekBar + ProgressBar

  • 基本介紹
Android iOS
ProgressBar UIActivityIndicatorView
SeekBar UISilder
  • Loading轉圈動畫是用ProgressBar

Lesson 15 - Buttons = [Radio,Chip,Switch,Toggle,Material]

  • 基本介紹
Android iOS
RadioButton UISegment
Switch UISWitch
ToggleButton
Chip
MaterialButton UIButton
  • Chip可以做到常見的tag或是Mail收件人功能

Lesson 16 - RecyclerView

  • 以前都用ListView,但不像TableView有回收的機制,後來就出了個RecyclerView
  • iOS的Delegate跟DataSource,在安卓世界裡要用個RecyclerView.Adapter來處理三個必做的方法
    1. onCreateViewHolder(給它畫面)
    2. onBindViewHolder(給它資料或監聽點擊)
    3. getItemCount(資料筆數)
  • Adapter裡面要有個RecyclerView.ViewHolder負責持有畫面跟更新資料

Lesson 17 - BottomNavigationView + Fragment

  • BottomNavigationView做出來會像TabBarController,但是很像View上面放幾個按鈕然後把subView換掉的感覺
  • 我的理解:因為Android不像iOS可以ViewController addChildViewController,所以他們發明了可以加在Activity上的東西:Fragment
    因此iOS上常見的ContainerViewController模式到的Android上就要請Fragment出馬了

Lesson 18 - call API

  • OkHttp套件
  • manifest要加<uses-permission android:name="android.permission.INTERNET" />,不然會閃退
  • 由三大部分OkHttpClient, Request, Call組成一次網路請求
  • callback裡動UI要用runOnUiThread包起來

Lesson 19 - JSON轉物件

  • Gson套件
  • 一行搞定:XXXClass xxxInstance = new Gson().fromJson(jsonString,XXXClass.class);
  • @SerializedName可以跟後端的欄位命名匹配

Lesson 20 - Activity Gallery

  • 內建一些範本可以參考或修改
  • Drawer: 漢堡側邊欄
  • Tabbed: 左右滑動切換頁面
  • Master/Detail: SplitViewController
  • FullScreen: 就是不會看到安卓系統下面的那條

Lesson 21 - 指紋辨識

  • 在manifest加上權限申請 <uses-permission android:name="android.permission.USE_FINGERPRINT" />
  • FingerprintManager: 檢查跟辨識使用
  • CancellationSignal: 取消辨識使用
  • 另外說明了怎麼設定才能在模擬器上測指紋

Lesson 22 - Google Map

  • 要去Google API網站申請API Key才能用
  • getSystemService(Context.LOCATION_SERVICE)取得locationManager
  • 用locationManager.requestLocationUpdates去定位
  • 用locationManager.removeUpdates(this)停止定位
  • 用mMap.animateCamera(cameraUpdate)去移動位置

Lesson 23 - 本地儲存

  • SharedPreferences(類似UserDefault)
  • 有file的概念,可以開很多個xml檔,不像我們只有一個.plist

Lesson 24 - Room

  • 是個Google官方提供的套件
  • 用來存取SQLite達到本地資料庫的CRUD
  • 分成三個Class:Entity(就是Model)、DAO(負責新刪改查)、Database(存資料的地方)
  • AS的Device File Explorer可以導出資料庫

Lesson 25 - ActionBar

  • 就是上面那條NavigationBar的位置
  • 改成客製:style.xml的DarkActionBar改成NoActionBar > findviewbyID取得layout上的ActionBar > setSupportActionBar
  • 沒有改成NoActionBar就setSupportActionBar = 閃退
  • 客製ActionBar就是Activity上的一個view

Lesson 26 - FCM Notification

  • FCM = Firebase Cloud Messaging
  • 已整合進AS(在Tools裡可以找到)
  • 不用取得user權限也可收推播
  • 實作繼承FirebaseMessagingService的Service去override onMessageReceived
  • 不像iOS一定要走APNs,他們也可以不透過FCM,像在中國Google不通,就要用其他的推播服務

Lesson 27 - APP Widget

  • Android的widget繼承於BroadcastReceiver
  • 生命週期:onEnabled(加入第一個widget時呼叫)、onUpdate(只要加入widget時就會呼叫)、onDeleted(只要刪除widget時就會呼叫)、onDisabled(刪除最後一個widget時呼叫)
  • onReceive:因為是繼承BroadcastReceiver,所以也可以發廣播給它
  • 佈局只支援FrameLayout、LinearLayout、RelativeLayout、GridLayout
  • 元件只支援AnalogClock、Button、Chronometer、ImageButton、ImageView、ProgressBar、TextView、ViewFlipper、ListView、GridView、StackView、AdapterViewFlipper(連子類也不行)
  • widget跟畫面的溝通必須要透過一個RemoteViews類來處理

Lesson 28 - 伸縮Banner + 瀑布流 + CardView

  • CardView: 就是FrameLayout的一種,但是加了一些現在常用的設計,例如圓角/陰影等等
  • 瀑布流: 給RecycleView一個StaggeredGridLayoutManager就OK了,超簡單
  • 伸縮Banner: 透過CoordinatorLayout跟CollapsingToolbarLayout即可達成~不用寫code
  • 在AndroidMenifest把Activity的label改掉,會蓋掉app_name

Lesson 29 - 上架

  • Android的key(憑證)是存在本地的,沒保管好就不能更新架上的APP了(現在Google好像有代管服務了,但沒研究)
  • 打包跟送審流程每個步驟都截圖下來了,直接去看吧~

結論

這個系列實作下來有幾點心得

  1. 畫面實作差滿多的,用拉的可以產生XML很棒
  2. 在畫布上ConstraintLayout感覺不會像AutoLayout都擠在一起
  3. AS滿多貼心小舉動的,例如變數建議、自動import、行數顯示顏色、自動生code、更強的⌘跳轉
  4. 取用資源都用R.xxxx,不用寫字串很棒
  5. 所有檔案都有固定的位置,容易理解
  6. 原生框架很亂,有什麼support library跟androidx啦、超多Fragmemnt啦
  7. 模擬器幾乎什麼都能測(相機、推播)
  8. 非常不能接受原生API變數命名都不寫清楚!!!(好像AS3.5改了?)
@Override
public void onProgressChanged(SeekBar seekBar, int i, boolean b) { //i是什麼鬼?b是什麼鬼?
  1. 很多現成元件(RadioButton、瀑布流、抽屜選單)不用自己刻
  2. 很多東西都會寫在XML
  3. 很常用Adapter模式
  4. new 一個變數,不知道建構子(就是init)要傳什麼進去,就在括號裡面打逗號就會跳出overloading讓你選
  5. AS是沒有debug view hierarchy的,畫面除錯就比較麻煩一點

總體下來感覺主要精神跟iOS沒有差很多,寫起來體驗也不錯(可能因為我只是學到皮毛吧)

我終於完賽了!


上一篇
iOS Developer Learning Android. Lesson 29 -上架 (寫APP就是要上架啊~不然要幹嘛)
系列文
iOS Developer Learning Android30

2 則留言

3
z8631989816
iT邦新手 5 級 ‧ 2019-10-16 09:58:29

恭喜大大完賽,我本身是 Android 起手的,現在自學 iOS,看完大大的文章,覺得你寫的真的很不錯,希望可以出個 iOS 版,雖然板上很多了,但文筆好、容易懂,實在不多見

哇哇!謝謝您的回應
終於不是自嗨了XD
很感謝您的肯定
iOS版的話,暫時沒有計劃
如果您有什麼問題的話
也歡迎提出來,我們可以討論討論~

/images/emoticon/emoticon08.gif

1
MarkFly~
iT邦新手 5 級 ‧ 2019-10-16 12:59:02

手機跨平台開發討論群(iOS&Android雙刀、ReactNative、Flutter)
https://line.me/R/ti/g/Cdyg5jOsQ4

我要留言

立即登入留言