Android Weekly Issue #218, 筆記.
Android Weekly Issue #218
August 14th, 2016
http://androidweekly.net/issues/issue-218
ARTICLES & TUTORIALS
PathMorphing with AnimatedVectorDrawables
Android 5.0 推出了VectorDrawable, 矢量圖為處理多種螢幕尺寸的帶來了很多好處. 這篇文章先介紹了VectorDrawable的使用, 然後主要講如何實時操縱圖像的改變, 用AnimatedVectorDrawable實作一個圖像變形的效果.
文中的例子是Android和Apple的log在互相變化.
source code available
Android UI Instrumentation test with Espresso
用Espresso寫UI功能測試, 通常是: 定位UI元素, 然後與其互動, 檢查UI元素的狀态.
三種主要的元件是: ViewMatchers, ViewActions 和ViewAssertions.
一個簡短的例子:
onView(withId(R.id.my_view)) // withId(R.id.my_view) - ViewMatcher
.perform(click()) // click() - ViewAction
.check(matches(isDisplayed())); //matches(isDisplayed()) - ViewAssertion
為了測試不受animation的影響, 有時候可能需要把裝置上的Developer Options裡的下面幾個animation全關掉:
Window animation scale
Transition animation scale
Animator duration scale
然後這個文章裡有具體的例子介紹如何寫并且運作測試, 還附有相關源碼.
How to Build an Android App for Fire TV - Part 1
建立在亞馬遜的Fire TV上跑的Android應用.
文後可以點進part 2.
Android Wear Development for beginners
Complication是指手表上顯示的除了小時和分鐘之外的東西, 比如, 一個電池訓示标志.
使用了Complication API之後, 使用者就可以自己選一個地方, 然後從應用的清單中選一個東東來顯示.
Wear應用是嵌入到一個主應用裡面的, 當google play上主應用的apk被安裝到手機上的時候, Wearable應用會自動安裝在配對的裝置上.
這篇文章詳細介紹了如何建立一個Wear應用, 代碼在github
官方文檔: Watch Face Complications
官方sample: android-WatchFace
Router — Everything in its Right Place
之前有一篇文章介紹了用裝飾者模式來建構高度子產品化的Android應用: Creating Highly Modular Android Apps
那篇文章裡也有一個例子Decorator.
這篇文章講同樣采用裝飾者思想的一個庫: Router.
Router首先基于一個将URL映射到程式界面的庫: routable-android
Router在此基礎上做出了一些擴充和改進, 可以用一個map檔案(YAML/JSON/XML)來定義基本的構架.
輸入是URL(可以帶參數), 根據map進行解析, 然後傳到plugins, 然後每個plugin創造一部分的輸出, 當左右plugins的工作結束後, 輸出就可用了(輸出是由多個plugins組裝而成的).
文末附有sample.
Boosting app performance with reflectionless (de)serialization
這篇文章研究了在解析JSON響應的時候如何提高效率.
作者他們的應用Vimeo Android用了Retrofit來做網絡請求, 用Gson來反序列化, 不好的一點就是有點慢, 因為Gson用反射來解析JSON. 為了改進,他們想要去除反射.
他們建立了自己的Gson TypeAdapters, 并且利用程式中各個不同大小的model來測量對比了了反序列化的時間.
他們的實驗測試了不同的機器對于不同大小model的處理, 在多數情況下, 不用反射會提高性能, 但是也有例外, 在解析很大的model時, 在高性能的機器上, 反而是使用反射的情況比較快.
他們的庫: stag-java
STAG: Speedy Type Adapter Generation.
Introduction to Automated Android Testing - Part 4
講如何寫測試的系列文章, 有一個案例sample: GithubUsersSearchApp.
舉例了一個MVP的真執行個體子, 然後給P寫單元測試.
Presenter裡有一個CompositeSubscription, 用來管理RxJava的subscriptions, detach的時候會登出所有的訂閱, 防止了記憶體洩露和可能存在危險的view操作.
還建立了一個Contract接口, 把View和Presenter的接口定義寫在裡面.
這裡面還有很機智的一點是把RxJava要用到的Scheduler也從presenter的構造函數傳入, 這樣在測試的時候就可以使用
Schedulers.immediate()
, 而在View裡面我們就按實際情況使用其他.
Introduction to Android Testing - Part 3
這應該是跟上面那條一個系列文章的第三篇.
介紹了如何用Retrofit和RxJava請求Github API然後解析到models.
後面是寫單元測試, 步驟很清楚, given, when, then.
可以從中學習一下怎麼給這種Retrofit + RxJava的程式寫單元測試.
Git as a secure private Maven repository
Bitbucket is a web-based hosting service for projects using Git.
講了如何使用BitBucket或者Github作為一個private的Maven repository.
例子: WagonGitExample
Gradle 腳本: GitAsMaven
Crash reporting in Firebase
比較簡單的一個文章, 如何set up Firebase的crash reporting.
其實Firebase Crash Reporting一旦建構好之後, 不需要加java代碼, 所有uncaught的異常都是自動報告的.
Firebase Report Crashes.
Isometric AnimatedVectorDrawable – Part 1
神奇的AnimatedVectorDrawable, 這篇文章講了用它來實作栅格地形圖, 遊戲裡可以升降的草地的類似的東東. (看文章裡的圖吧, 我也形容不好.)
遺憾的是pathData animation目前在VectorDrawableCompat library暫不支援, 是以文中所講的技術隻能在api 21及其之上使用.
文中的例子有9個方塊, 4個三角形, 把SVG作為矢量圖VectorDrawable導入Android Studio, 然後給每一個path起名字.
本文隻是part 1, 預告了下一篇文章将講如何動畫.
Source code available here: IsometricAnimatedVector
Design
Don't just port an iOS navigation model to Android
關于bottom nav bars的讨論.
Hamburger menu有時候感覺不是很理想, 是因為抽屜裡的items總是隐藏狀态, 使用者不易發現和使用.
Bottom bar則把每一個item都時刻展現給使用者, 在iOS上使用得很成功.
Google在2016年3月提供了Guides: Bottom navigation.
-
什麼時候該用bottom navigation呢?
應用有3到5個top級别的目的地, 且它們需要直接被通路, 從各個目的地之間轉換, 并且它們應該是具有同等重要性的.
-
什麼時候bottom navigation不适用呢?
不能因為怕使用者看不見一個東東, 就把它放在bottom nav bar, 作為推廣手段.
bottom nav bar也不是用來放menu的, 比如放不下了加個more tab, 展開以後是更多的二級頁面入口; 也不要用來放一些彈出視窗, 它們同樣也不是top level的目的地.
bottom nav bar不能放低級别的目的地.
最後文章強調了每個平台應該遵從自己的特性, 對Android來說, 如果完全拷貝iOS的設計可能不是一個好主意.
LIBRARIES & CODE
stag-java
Stag通過減少反射改善了Gson的性能, 為你的model對象自動生成TypeAdapters.
Router
一個基于routable-android的新的Android URL router, 摒棄了Activity/Intent依賴, 并加入了新的特性.
作者: 聖騎士Wind
出處: 部落格園: 聖騎士Wind
Github: https://github.com/mengdd
微信公衆号: 聖騎士Wind
