はじめに
GameWith Advent Calendar 2018 8日目担当のkyamです。
最近iOS開発をしていて思ったのが、長くiOS開発をしていると使うライブラリが大体固定化されてきて新しいものを使うことが昔に比べて減ったなと最近感じました。
通信なら○○、画像キャッシュなら○○、AutoLayoutなら○○、と言った様に個人的なお気に入りはあるのでチーム開発を除いて、個人開発をする場合には使うライブラリが限られてきます。
GitHubのTrending Repositoriesを眺めるのが好きなんですが実際のプロダクトで使えるものを探すというよりは、今何が流行っていてそのライブラリがどんな書き方をしているのか、といった興味関心から見ることが多いです。
自分は今回はTrending Repositoriesの中から今注目されているライブラリを何個か紹介するのに加えて、年末も近いということで1年を振り返って実際にプロダクトで使って良かったものを合わせて簡単に紹介します。
この記事を読んでくれた皆さんには、この一年振り返ってこのライブラリをプロダクトに導入したけど良かったなど実用的なものをコメント欄で紹介してくれたら嬉しいです
Trending Repositories
面白そうなライブラリ
Marionette
12/5が最初のコミットなのでまだ出たばかりの新しいライブラリですね。
WKWebView
を操作することが目的のライブラリで、ゴールはpuppeteerのようなものにすることだそうです。社内でWKWebView
を用いているアプリもあるので今後触る機会もあるかもしれません。
let page = Marionette()
firstly {
page.goto(URL(string: "https://www.google.com/")!)
}.then {
page.type("input[name='q']", "LinusU Marionette")
}.then {
when(fulfilled: page.waitForNavigation(), page.click("input[type='submit']"))
}.then {
page.screenshot()
}.done {
print("Screenshot of Google results: \($0)")
}
flashy-tabbar
11/29が最初のコミットなのでこちらも比較的新しいライブラリです。
UITabBarController
のアニメーションライブラリは比較的貴重なのでソースコードを読みたいなと思いピックアップしました。
storyboard
or nib
を用いて実装を行う様です。
個人的にはアニメーションでタブの画像が上にずれる際見切れる感じのアニメーションになっているのが少し気になります。
アニメーション系のライブラリはアニメーションを見て自分だったらこういう感じに実装するなというイメージを持ってからソースコードを見ると結構学びがあって面白いです。
使いたいライブラリ
SkeletonView
新規プロダクトに入る際に毎回採用しようか悩むライブラリです。
FacebookやYouTubeアプリなどで用いられているSkeletonView。
通信状態が悪い場合にUIを表示させるまでに用います。
普通に画面の中心にローディングを回すよりも、コンテンツの形が予め分かる(何を読み込んでいるのかが分かりやすい)ためUIActivityIndicator
などをシンプルに使うよりもユーザー体験が少し良くなります。
アプリに合ったSkeletonViewを自作した方が便利かなと思いライブラリの導入は見送るのですが、この一年くらいずっと人気があるのでカスタマイズが容易であれば導入を検討したいです。
PINRemoteImage
Pinterest社製の画像キャッシュライブラリです。
SDWebImageやKingFisherを使う人が多く、最近だとダウンロード速度が早いことで有名なNukeも採用されることが多い印象です。
一方でPINRemoteImage
は比較されることはあれどあまりメインで使ってるプロジェクトを自分は知りません。速度というよりはメモリ消費量が非常に少ないことで推されています。
PINRemoteImage
のソースコードはまだ一度も読んだことがないので、読んでみて何故他のライブラリよりメモリ消費量が優れているのかを調べてみようと思います。ダウンロード速度の差は正直ライブラリ間で体感でわかるレベルではないのでメモリ消費量が優れているのであれば導入の価値はあるかもしれません。
Charts
簡単にあらゆるチャートが作れるライブラリです。
チャート周りは自前で作ると結構大変なのでこの辺使って見たいですね。
今年のクソアプリアドベントカレンダーのVue.js + Onsen UIで作る晩ご飯ランダムスロットが個人的に好きで、自分用にアプリ版作ろうかなと思ったんですがその時に上記ライブラリのPie Chartが使えそうだなと思いました。
SwifterSwift
昔からありますが、Swiftの便利なExtensionを集めたライブラリです。
Extensionは結構自分で作るので、改めて見ると勉強になるかもなと思いました。
社内のiOSエンジニアでお気に入りのExtension紹介し合う勉強会とかも面白そうです!
2018年使って良かったライブラリ(おまけ)
TransitionalTab
タブ切り替え時に画面にアニメーションをかけるためのライブラリです。
spotifyなどが個人的にタブ切り替え時のアニメーションをかけているイメージが強いです。
TransitionalTab
では、Move
, Scale
, Fade
, Custom
とアニメーションの種類を選べるのですがアニメーションの質も良くコードもシンプルでかなり使いやすかったです。
Firebase SDK
2018年Firebase SDKの各サービスを大体使ったのですがいずれも使いやすくてオススメです。
詳しくはこちらにまとめています。
Firebaseをプロダクトに採用して得た知見
まとめ
ライブラリの導入に関しては導入フェーズに応じて一長一短であり、また個人開発かチーム開発かによって意味合いも変わってくるかと思います。
チーム開発を考えると最近は会社の中で社内OSSのような形でライブラリを作りそれを運用するという例が増えてきており、そのような形はメンバーのライブラリへの共通理解があるという点で望ましいなと思います(もちろん内容にはよると思います)
ただそうではなく外部のライブラリを導入する場合は、
・ただ単純に便利だから
・工数削減できるから(影響範囲理解していない)
・皆使ってるから
といって安直に採用するのではなくて、特にチーム開発の場合はメンバーへの信頼性にも繋がると思うので、なぜ採用したのか、なぜ同じような内容の別の○○ではないのか、まで説明できると良いなと思います。
最後に
GameWithには OSS コントリビュータ / コミッタ手当
といった素敵な制度もあるので自分でライブラリを作るだけでなく上記の様に気になったライブラリにはどんどんコミットしていこうと思います!
明日の9日目は iOSエンジニアの @chuymaster がLINE Botを活用した面白い事例について執筆します。
そちらもお楽しみに!