- この職務経歴書はこちらに最新版があります: https://github.com/Corvus400/resume
名称 | 経験歴 |
---|---|
Android Mobile | 7年(85ヶ月) |
Android TV | 6ヶ月 |
iOS | 7ヶ月 |
Flutter | 2ヶ月 |
Cocos2d-x | 1.5年(18ヶ月) |
名称 | 経験歴 |
---|---|
Kotlin | 6年(73ヶ月) |
Swift | 7ヶ月 |
Dart | 2ヶ月 |
C++ | 1.5年(18ヶ月) |
Java | 3年(35ヶ月) |
JavaScript | (業務でのモック修正や個人的な趣味で)6ヶ月相当 |
Objective-C | (Cocos2d-xのネイティブ連携記述時で)1ヶ月相当 |
Python | (大学在学中)3ヶ月相当 |
PHP | (大学在学中)3ヶ月相当 |
C | (C++学習前のキャッチアップとして)1ヶ月相当 |
RPG3 | (新卒企業で)5ヶ月 |
DroidKaigi2024コントリビュート 👍
- 8/11のリポジトリ公開から9/10までの31日間コントリビュートしました
- 結果と貢献を通じて何を学んだかはZennに纏めておりますのでそちらをご覧ください
- 3年連続Welcome Talkにてオーガナイザーの方々と並ぶ形でご紹介頂きました
- 今年も去年同様Takahiromさんに並ぶ二位の位置を占めることが出来ました
DroidKaigi2023コントリビュート 👍
- 8/14のリポジトリ公開から9/13までの30日間コントリビュートしました
- 結果と貢献を通じて何を学んだかはZennに纏めておりますのでそちらをご覧ください
- 今年も前年同様Welcome Talkにてオーガナイザーの方々と並ぶ形でご紹介頂きました
- 今年は去年より貢献順位が一つ上がりTakahiromさんに並ぶ二位の位置を占めることが出来ました
DroidKaigi2022コントリビュート 👍
- 9/6のリポジトリ公開から10/2までの26日間で大小様々なPRを38個作成
- Issueも16個消化し内5個がhigh priorityのものでした
- DroidKaigi2022 Day1 の Welcome Talk にてオーガナイザーの方々と並ぶ形でご紹介頂きました
Flutter学習
- Flutter for Android developers, Flutter Layout Cheat Sheet, Flutter Gallery の内容を踏まえて学習
- https://github.com/Corvus400/my-flutter-cook-book-animation-app
- https://github.com/Corvus400/my-flutter-for-android-developers-app
- https://github.com/Corvus400/my_flutter_layout_cheat_seat_app
- https://github.com/Corvus400/my_flutter_animation_tutorial_app
- https://github.com/Corvus400/my-flutter-cook-book-effects-app
Android Developers の翻訳動画を作成
- 参画先のキャッチアップ時間で話題として提供 https://zenn.dev/todayama_r
Tip
各プロジェクトをクリックすると詳細が展開されます
2024年10月 - 現在 / BtoC / 株式会社ドワンゴ(KADOKAWAグループ) / Zen Studyアプリ開発・保守 👍
- Kotlin, Jetpack Compose, Android, RESTAPI, Kotlin Coroutine, RxJava, Robolectric, firebase, OAuth2.0, OIDC
- ストアは此方
- マルチモジュールだがDIは入っていない
- PresenterとInjectorと呼ばれるクラスによってDIが行われている
- DIは入っていないがRoborazziは入っている
- WebViewとNativeの混合構成
- R高が開学するためそちらに対応するためのアプリの改修と技術調査を主に担当
- 他にもCrashlyticsで挙がってくるバグの調査・対応も担当
- ログイン導線が変更になるためそれに対応するためにOAuth 2.0 / OIDCに準拠したログインフローを実装する必要がある
- ただし標準的なOIDCのフローやPKCE対応とは異なる実装を求められるため公式ドキュメントで使用が推奨されているAppAuthを使用しない独自実装が必要
- AndroidチームにOAuth2.0 / OIDCに知見の有るメンバーが1人も居ないため自分で調べて実装・懸念点の洗い出しを行う必要がある
- レビュー前までに他のメンバーにも知識を付けてもらうための勉強会等をレビューまでに定期的に行う必要がある
- レビュー時に他のメンバーにもOAuth2.0 / OIDCの知見が無いとレビューが出来ずタスクが進行できないので理解してもらう事は必須
- 実装フェーズが複数有るのでそれらに取り組みつつOAuth2.0 / OIDCやPKCEについての知識を深める
- 他のメンバーが策定しているフローにセキュリティリスクが存在しないかの検証
- 付け焼き刃的に暗記しても意味が無いので毎日OAuth2.0 / OIDCやPKCEについて調べて実装に備えるようにした
- DroidKaigiで得た知見の共有
- codeInsightSettings.xmlが設定されておらずCompose以外の不要なクラスがサジェストされていたのでサジェストされないようにした
- DroidKaigi/conference-app-2023#589
2024年5月 - 2024年8月 / BtoC / 株式会社ギフトモール(LUCHE GROUP) / Giftmallアプリ開発・保守 👍
- Kotlin, Jetpack Compose, Android, RESTAPI, Kotlin Coroutine, RxJava, MVVM, Dagger Hilt, MockK, Kotest, firebase
- ストアは此方
- マルチモジュール構成を取っておりapp/feature/cross_domain/repository等から成る
- WebViewとNativeの混合構成
- GiftmallAndroidアプリのABテスト対応・保守を主に実施
- チーム人数は3人
- プロパーのAndroidエンジニアが1人で手が足りておらずABテスト対応などが人数が多いiOS側と比べ対応が間に合っていない
- ABテスト対応後のコードの消し忘れなどで使われなくなったコードが多数残ったままになっている
- Jetpack Composeで構成された画面のABテスト対応を主に実施
- ABテスト対応で触った箇所でどこからも参照されていないコードをボーイスカウト・ルールに則り削除
- 削除が必要な行数が多い場合はタスクを作成し別PRで対応することでレビューし辛い状態にならないように対応
- ABテスト対応時にキャッシュ(Singleton化されたFlowを持つ簡易キャッシュ)の既存バグを発見しそちらの修正も対応
- Flowが<Set>を保持していたのでkey-valueで扱えるMapに変更することで対応
- DroidKaigi2023での貢献を通して得た知見を活用
- ex)ABテスト対応でハプティックフィードバックを導入する対応が有ったがDroidKaigiで同様の対応をしているPRを知っていたのでそちらを参照することで機能実装は数分で対応が完了
- 参考にしたPR
2023年9月 - 2024年5月 / BtoB / 株式会社TOKIUM / TOKIUM経費精算システムアプリ開発・保守 👍
- Kotlin, Jetpack Compose, View base(Jetpack ComposeではないXML), Android, RESTAPI, Kotlin Coroutine, MVVM, LiveData, flow, Dagger2, androidx.paging, Robolectric, JUnit,
- ストアは此方
- マルチモジュール構成(app/core/feature形式ではない)
- HiltではなくDagger2を使用してDIが行われている
- Full-ComposeではなくComposableとViewベースのUIとが混在
- Androidチームのテックリードとしてのロールが主な責務
- TOKIUM経費精算システムアプリの新機能開発・保守を主に実施
- チーム人数は3人
- 既存コードに影響されViewModel等の構造がベストプラクティクスから外れている
- 横連携・情報伝達・開発フロー等アプリのコード以外の部分にも多数問題が存在しそれらにより開発速度が上がらない状態が何年も続いている
- 施策の進行時クリティカルパスの把握など通常のプロジェクト進行で必須となる事前準備がほぼ不足している
- 施策の進行中に稼働を増やすことでしかカバー出来ない状態になることが多々発生
- iOS側でサイレントで対応・修正している内容がAndroid側に連携されず本来発生しえなかった対応コストが余分に発生
- Figmaの有用性が低い
- Figmaすらない画面の方が多数
- 殆どの画面がスクリーンショットを貼り付けるだけのほぼ意味の無い状態になっている
- テキスト色等具体的な数値等は過去に実装されたコードを見る事になっていた
- Figmaを含めたドキュメントの有用性が低い
- ドキュメントが無いor重複して存在・記述間違いのため正しい仕様の把握が困難な状態となっておりコードが仕様の状態が何年も継続している
- Composableに対するテストが書かれたことが無かった
- リファクタ・リアーキテクチャ計画の立案・ディスカッション・推進を主導
- 施策の進行に伴ってリファクタ・リアーキテクチャでの対応が困難だと判断しリプレースをするメリットを説明しそちらを行うように推進
- 未整理だったSlackチャンネル・ドキュメント・Figmaの整理整頓を主導
- PullRequestテンプレートから不要な記述を削除し必要な記述を追加しPRのレビュー効率を高める
- JetpackComposeに関連しない同名のクラスがサジェストされないようにする事で生産性を向上させる
- 既に誰も見ていないbotの通知などが誰も止めずに何年も放置されていたので止め必要な情報が流れるのを防ぐ
- チャンネル名に法則を持たせて統一しチャンネルを探す余計な手間を排除
- GitHubの通知を行うチャンネルが存在せず手動でレビュー依頼メンションを既存メンバーが都度投稿していた
- 専用チャンネルにGitHubアプリによるインテグレーションを追加することで余計な作業を排除
- DroidkaigiのFigmaのようにComponent化した部品を使って画面を作成するよう主導
- 先行して実装完了済のiOS側が作成したFigmaの内容構成に合わせComponent化した部品を用いて既存メンバーと協力してFigmaを作成
- 本来はデザイナーが担う役割だがデザイナーが居ないため開発メンバーでFigmaを作成
- 仕様の記述されているNotionの整理を主導
- テンプレートを作成しビジネスサイド・開発メンバー双方がどこを見れば何の情報が有るかを分かりやすくする
- 会議体や会議の進行方法の変更を提案し横連携を行えるようにした
- 朝会を夕会に改組
- 重要なメンバーが参加出来ない日が多く機能していないため
- 横展開を先に行いその後主催者が各自の進捗を聞く流れとなるように変更
- 先に重要な連絡・ディスカッションを済ませてから主催者が進捗を聞くようにする
- 朝会を夕会に改組
- 仕様の確認と段取り方法(何をまず確認しなければならないか等)の伝授を既存メンバーに対して主導
- 段取り不足による工程の遅延・やり直しの発生が初期は非常に目立ったため
- PERT図の導入なども提案
- メンバーのレベルを高めるためDroidkaigiのPRから一つ選んでそれについて10分話す場を週に3回設けるよう主導
- 10分としたのはANDPADの取り組みの記事を見てのこと
- JIRAのタスク番号が偶数・奇数かで既存メンバーのどちらが自分のPRを見るかを決めていたためそのルールをGitHubActionを使用して自動化
- Robolectricを使ったユニットテストを導入(自分が追加したのは199件中154件)
- テストを導入する前にテストの記述方針を既存メンバーと調査・ディスカッションした上で導入
- テスト内容としてはnull/non-null/境界値をチェックすることでUIが仕様通りに表示されているかをチェックする
- DisplayNameアノテーションを使って日本語でテストの説明を入れて分かりやすくしている(メソッド名称は英語)
- painter等に何がセットされているかは直接確認する方法は無いのでそのような場合はcontentDescriptionにセットされた値をチェックすることで代替としている
- ViewModelの構造を一般的なAndroidアプリに近づけるよう主導
- 不要なViewModelの依存・継承を排除
- Repository/UseCaseからデータのCRUDを行う修正を主導
- Screen・Screenで利用するComposable・ボトムシートを担当し作成
- 3画面・9部品・5つのボトムシートコンテンツ
- それぞれ表示パターンを目視で素早く確認出来るようにPreviewアノテーションで境界値によるUI変化をパターン網羅するように表示させている
- DroidKaigiやNow in Androidの採用した方が良いパターンを導入し他の方にもそれに合わせてもらうよう主導
- ViewModelでbuildUiStateを使用するよう主導
- ダミーデータをfake(),fakes()メソッドを作成して提供
- DroidKaigi2023での貢献を通して得た知見を活用した
2022年12月 - 2023年8月 / BtoC / REALITY株式会社(グリーグループ) / REALITYのAndroidアプリ開発・保守 👍
- Kotlin, Jetpack Compose, Android, Protocol Buffers, RESTAPI, Kotlin Coroutine, MVVM, LiveData, flow, koin, Lokalise
- ストアURLは此方( https://play.google.com/store/apps/details?id=net.wrightflyer.le.reality&hl=ja&gl=US&pli=1 )
- マルチモジュール構成を取っておりfeature/libraries/data/coreから成る
- UaaL( Unity as a Library )を採用しておりUnityを使用してアバターの表示を行いUnityの上にネイティブのUIを表示する構造となっている
- 12言語対応のためLokaliseというサービスを使用しstrings.xmlは手動ではなくサービスから出力されたものを使用する形となっている
- 通信クライアント部分が別リポジトリで管理されており部分的にProtocol Buffersを使用
- 新機能開発の合間に整理されていない状態となっていたドキュメントの整理などチーム全体の効率を上げるタスクも自ら実行
- REALITY Androidアプリの新機能開発・保守を主に実施
- チーム人数は10人
- 他社ではチャットへの流入を増やすためのシェア導線が準備されているがREALITYではアプリ外シェアがメインとなっており流入が少ない状態となっていた
- デフォルトで通知がONになっておりフォロー通知が頻繁に飛ぶため通知をOFFにされるケースが多い状態となっていた 加えて通知をOFFにするとONに戻すきっかけが存在していない
- Plural機能が使用されていないため単位の単数複数形が存在する言語の翻訳品質が低下していた
- GitHubのWikiに情報が集積されているものの整理されておらず必要な情報に辿り着くことが難しい状態となっていた
- JetpackComposeによる画面の作成・REST APIの追加を実施
- JetpackComposeではpluralStringResourceを使用しXMLではgetQuantityStringを使用する事でLokaliseから出力されるリソースを表示出来るようにした
- チーム内にて協議しプロジェクト内にDocsフォルダを作成しWikiとDocsの役割分担を行い整理を実施
- DroidKaigi2022での貢献を通して得た知見を活用した
2022年01月 - 2022年06月 / BtoC / 合同会社DMM.com / 動画配信サービスアプリ開発 👍
- Android TV, Kotlin, GraphQL, Apollo Client, Kotlin CoroutineKotlin Multiplatform Mobile, ExoPlayer, LiveData, Kotlin Flow, Koin, MVVM, DDD, Mermaid, PlantUML, JavaScript, Node.js
- 動画配信サービスアプリを置き換えるためのAndroid TV開発
- Kotlin Multiplatform Mobile(KMM)を利用したマルチモジュール/マルチフレームワーク構成
- GraphQL(BFF)のQueryとMutation部分も設計・実装
- 各種スキーマの定義も実施
- 設計の際にはMermaidやPlantUMLを使用してクラス図を作成しレビュー
- 主体的に自チームだけでなく各チームと仕様や実装についてやり取りを行い自走しタスクを進めた
- Android知識のキャッチアップを行う時間が業務中に有りその時間の為に Android Developers の翻訳動画を作成するなどした
- 5/17時点で 対応画面数は10以上 UseCase類の設計も10以上 作成したPRは111個 コードは 20,290++ 9,208-- 1,191貢献
- 17人チームのAndroid TV側を担当
- 基本設計・詳細設計・実装・単体テストを実施
- Android TV側にはNavigationコンポーネントが導入されておらずMainActivityのFragmentを各開発者がreplaceして遷移させる処理を各所に書いていた
- 一ヵ月も絶たない内に遷移処理が複雑化しバグの温床になるのが目に見えていた
- Android TVはMobile開発では意識する必要のないフォーカス制御が肝であるが開発当初はチーム全員がフォーカス制御が上手く出来ず開発速度が停滞した
- GraphQLの知識が0のメンバーが殆どで有りダミーデータの直書きからQueryやMutationを実行するよう置き換える際にも開発速度が停滞した
- KMMのためiOS,Android Mobile, Android TV総勢30名以上がソースに触れる為CI(Bitrise)チェックをすり抜けてdevelopのビルドが通らない状態になる事が頻発した
- 既存サービスが有るとはいえ新規の大規模開発のためリードエンジニアだけでは対応が追い付かない部分が多々有り日々いくつもの問題が発生していた
- KoinのSharedViewModelと遷移先を判定するためのsealed interfaceを用意し各実装者がバラバラに記述していた遷移処理を統一させた
- Android TV特有のライブラリであるLeanbackのキャッチアップをチーム全体で行いフォーカス制御が上手く出来ないRecyclerViewの代わりにRowsSupportFragmentを使用するなどして開発速度の停滞を防いだ
- 自分が参画前にキャッチアップしていたGraphQLの知識を基に他メンバーの実装を助ける等して開発速度の停滞を防いだ
- PRマージ後にローカルでビルド出来るかをこまめにチェックする等して対応
- BitriseのプランをTeamsより上のVelocityプランへ引き上げるとTeamsへ戻す際に手続きに時間がかかるため
- 最新developを取り込み必須にする設定にも出来たが頻繁にdevelopへPRがマージされる状況ではいつ迄経ってもマージできない状況になり開発速度が低下する為上記の対応
- GraphQLのモックサーバがNodemonで自動再起動されるようになっていたがindex.jsと同じディレクトリのJSファイルのみ監視しており.graphqlファイルの変更が監視されていなかった
- そのため監視されるようにpackage.jsonを修正する対応を実施
- GraphQLにてカスタムスカラーが定義されていたもののモックされていなかった為参照されるとResolve出来ずクラッシュしていた
- カスタムスカラーをモックするように定義を修正する対応を実施
- 他にもドキュメント(Markdown)を適宜修正するPRを出し全体周知する対応を実施する等割り当てられたタスク以外の球拾いタスクも適宜実行し対応
- 自チームだけでなく他チームなど全体を見て重複作業の発生防止や困っている点を把握対応し個ではなくチームとしての開発速度を底上げできるよう努めた
- レビューを行う必要があるPRが毎日最低5件以上は出ており他のメンバーの作業をブロックしない為に時間を決めて全てレビューするよう務めた
- 参画前からGraphQLやJetpack ComposeをUdemyの動画を購入して翻訳して見ながら実装をしてみる等してキャッチアップしていた
2021年06月 - 2021年12月 / BtoC / メドピア株式会社 / 歩数計シリーズアプリ開発 👍
- Android Mobile, Kotlin, LiveData, Room, Dagger, Kotlin Coroutines, Kotlin Flow, DataBinding, Realm, Flipper, OneSignal
- 歩数計シリーズアプリ開発(Android)
- 3つの歩数計アプリをそれぞれ担当
- 新規機能追加が主
- マルチモジュール・AAC(LiveData、ViewModel、Room)・Dagger採用の歩数計テンプレートアプリをsubtreeで取り込み各プロダクトに応じたカスタマイズを行うタイプとシングルモジュール・MVPのアプリそれぞれを担当
- フルリモートにて対応
- 7人~14人チームのAndroid側を担当
- 実装・単体テスト・結合テスト・保守・運用を実施
- テンプレートアプリ側でDeprecated等の警告が多数出ておりGitHubでのレビュー時にbotが警告を大量に出力していたのでそれを無くす必要が有る
- 具体的には NetworkInfo(Deprecated)・FragmentPagerAdapter(Deprecated)・startActivityForResult(Deprecated)・onActivityResult(Deprecated)・requestPermissions(Deprecated)・kotlinx.coroutines.ExperimentalCoroutinesApi(experimental)・name shadowed・unnecessary safe call(Kotlinバージョンアップに伴う引数のnon-null変更)・type mismatch・whenのcase不足・never used・no cast needed・Interfaceと実装での引数名前違い
- 新規開発のテンプレートを使用したアプリではテンプレートアプリには無い歩数を示すマーク代わりの動物の画像をアニメーションさせる機能を追加する必要が有った
- 何れのアプリもPM側が余り仕様を把握していない状態の為言葉通りにタスクを進めるのは危うい状態
- 課金機能の実装と動作確認を行う要件への対応
- 地道に警告文が出ている部分を一つ一つデグレしていないか確認しながら解消
- 先に参画している開発者にアドバイスを貰いつつ他のテンプレートアプリを使用していないアプリ側の処理を参考に実装
- SlackやBacklogや昼会で口頭確認して仕様の不整合や不明点を潰しながらあやふやな部分の仕様を明確化
- テンプレートアプリが実装済みの課金機能を使用して要件を満たす
- レビューは余り細かく見るプロジェクトでは無かったがレビュー負担を減らすのと見逃しを減らす為に説明を加えた方が良いと思った箇所にGitHub上でシングルコメントを各所に追記した状態でPRを出していた
- 既存のテンプレートアプリの出来が良いので独自色を出すのは控え可能な限りテンプレートアプリの処理を参考にして機能追加や改修を行う事で作業時間を極限まで短縮した
2020年10月 - 2021年03月 / BtoBtoC / 株式会社くすりの窓口 / お薬手帳アプリ開発
- お薬手帳機能他血圧手帳等複合機能アプリ開発(BtoBtoC)
- Crashlyticsに記録された不具合の改修対応等が主。
- 6人チームのAndroid側を担当
- 実装・単体テスト・結合テストを実施
2020年04月 - 2020年06月 / CtoC / 株式会社インタースペース / 旅行口コミアプリ開発 👍
- Android Mobile, Kotlin, iOS, Swift, Redux, DDD, Navigator, Spek2, MockK, Mockito, Adjust, Repro, Crashlytics, DataBinding
- 旅行先の口コミ掲載アプリ開発
- Redux・DDDのコンビネーション構成に沿って機能追加を担当
- アーキテクチャーはRobert C. MartinのClean Architectureを参考としたものを採用
- 画面の追加はNavigationコンポーネントにより実装(1Activity多Fragment)
- テスト(Spek2)の追加も機能追加と同時に実施
- app,ui,domain,infrastructureからなるマルチモジュール構造
- フルリモートにて対応
- 5人チームのAndroid側を担当
- 実装・単体テスト・結合テストを実施
- iOSで先行してリリースされている自社サービスアプリをAndroidでも展開する事が目的
- PMが仕様を余り把握しておらずドキュメントもあてにならない状態の為先にリリースされているiOS側のコードを見て実装を進める流れになっていた
- 実現したい内容に比して複雑なアーキテクチャーを採用している為新規機能追加や改修のスピードが落ちていた
- Swiftコードを読み解きiOS側のアプリの動作を見ながら仕様の不明点を解消して実装を進めた
- キャッチアップが足りていない点を補いつつ実装を進めた
- 業務時間外でもキャッチアップを積極的に行った
2019年07月 - 2020年03月 / BtoCtoC / 株式会社リブセンス / 人材系アプリ開発 👍
- Android Mobile, Kotlin, Java, RxJava, DbFlow, Room, iOS, Swift, Adjust, Repro
- 成功報酬型人材紹介アプリ開発
- アーキテクチャーはRobert C. MartinのClean Architectureを参考としたものを採用
- 機能追加・改修・ABテスト対応を実施
- RxJava1系から2系への移行とKotlin化対応も施策対応と並行して実施
- DbFlowからRoomへのマイグレーション対応も一部実施
- 正社員の方とのディスカッションに参加し要件定義部分から関わる開発スタイル
- 正社員の方と同様10%ルールに参加しiOSアプリ側の簡単な改修も行う
- 当初は出社での業務で後半よりフルリモートにて対応
- 9ヶ月で作成したPRは凡そ90個 コードは 974コミット 52,377++ 31,415-- 1,434貢献
- 7人チームのAndroid側を担当
- 実装・単体テスト・結合テスト・保守・運用を実施
- Java部分が多くRxJava1やDbFlow等が使用されている部分が多くグロースに繋がり辛い部分の近代化改修が遅遅として進んでいない状態だった
- スピーディーにABテスト対応を行いグロースさせる事が非常に重視される現場だった為余日管理が他の案件より高度な物を要求された
- レビュー時にもパフォーマンスやコードの分かりやすさを非常に厳密に求められた
- 新規追加分のコードはKotlinで書き既存部分の改修やABテスト対応時についでにKotlin化や陳腐化したライブラリの入れ替えを実施
- 余日精度を上げるためにどのタスクにどの位の時間を費やしたかを日単位ではなく時間単位で毎日記録
- 可能な限り過去のレビュー指摘事項と同じ指摘事項が付かないようPRを出す前に過去のPRの指摘事項を確認してからレビューを依頼
- PM等が会議に多く時間を取られるため仕様策定や確認に時間を多く割ける環境では無かった
- ツーカーで済むコミュニケーションとなるように仕様の不明点を5W1Hを徹底して箇条書きにして短い文章となるようにして伝えるよう特に気を配った
- どの位の時間で終わるか不透明な部分から重点的に見積もりするようにした
- 時間が限られているので特に指摘回数が多い指摘事項については個人用SlackにメモしてPRを出す前に確認するようにした
2019年04月 - 2019年06月 / BtoB / 株式会社Mobility Technologies(旧JapanTaxi株式会社) / タクシー乗務員業務用アプリ開発 👍
- Android Mobile, Kotlin, DeviceOwner, ExoPlayer, AudioFocus, Service, Kotlin Coroutine, Timber, Kibana, Espresso
- MaaS大手(現在は合併社名変更)の乗務員用アプリ開発
- Android側を担当
- DeviceOwner使用端末のOreo,Pie対応、Espressoテスト項目追加、ラジオ機能追加等(ExoPlayerやAudioFocusやService使用)
- IPタブレット(旧システム)・広告タブレット(乗客側に設置 広告掲示と料金決済等に使用)・乗務員タブレット(ナビゲーションや乗車前の乗客との連絡用 タブレットによってPh1,Ph2がそれぞれ存在)と機器が複数存在
- 出社での業務
- 上記機器の内乗務員タブレットに使用するアプリ7人チームのAndroid開発を担当
- 実装・単体テスト・結合テストを実施
- 乗務員が非常時にのみ使用する事を想定したラジオ機能を追加する必要が有る
- ラジオ機能を使用している間もナビゲーションや乗客からの通話がかかってくる事が有るためAudioFocusによる制御は必須
- 新規決済手段を追加する必要が有る
- 広告タブレットチーム側と連携する必要が有る
- DeviceOwnerを使用するアプリの為端末の更新に伴いAndroid9.0に対応する必要が有る
- 単純にminSdkVersionを上げるだけではクラッシュして起動すらしないので起動するようにまず修正しそこから各機能が9.0更新前と同じ見た目で動くようにする必要が有る
- 具体的には Apache HTTP対応・ManifestでのReceiver登録からregisterReceiverする方法への変更・network-security-configの設定など
- 単純にminSdkVersionを上げるだけではクラッシュして起動すらしないので起動するようにまず修正しそこから各機能が9.0更新前と同じ見た目で動くようにする必要が有る
- 正社員の方より展開された正社員の方製のラジオアプリを参考にしてラジオ機能を追加した
- Android9.0更新時には地道に一つ一つ機能を手動で確認し表示崩れや機能が正常に動作するかの確認を目視とログ上で確認しながら改修
- 各機能の追加時に必要に応じてespressoテストを追加
- 正社員の方がミーティングや話し合いなどで拘束されている時間が長い為ツーカーで済むコミュニケーションとなるように仕様の不明点を5W1Hを徹底して箇条書きにして短い文章となるようにして伝えるよう特に気を配った
2018年12月 - 2019年03月 / BtoC / 仮想通貨クライアントアプリ開発
- BtoC向けの仮想通貨クライアントアプリ開発。
- 5人チームのAndroid側を担当
- 実装・単体テストを実施
2018年04月 - 2018年05月 / BtoB / ローカル仮想通貨アプリ開発
- BtoB向けの仮想通貨クライアントアプリ開発。
- 5人チームのAndroid側を担当
- 詳細設計・実装・単体テストを実施
2017年11月 - 2018年03月 / BtoC / 化学メーカーのHEMSアプリ開発 👍
- Home Energy Management Systemアプリ開発
- フルスクラッチの為要件定義から実装迄を担当
- Android側の開発アドバイス、開発手法・ツール提案等も実施
- アーキテクチャはMVC
- 出社での業務
- iOS, Swift, Carthage, Android Mobile, Kotlin, Bluetooth
- 1-4人チームのiOS側を担当
- 詳細設計・実装・単体テストを実施
- ECHONET Lite規格に沿って蓄電池や太陽光パネルと通信し通信によって得た値をグラフ等で表示する
- どのようなアーキテクチャにするか、ライブラリの選定、READMEへの使用ライブラリやアーキテクチャを記載
- 要件定義を行いつつ一人でプロジェクトに従事
- その後追加された人員も未経験者の為自身が後から来た人員に対して知見を共有
- Android側はフルKotlinだったがAndroid開発未経験者とJavaでのAndroid開発のみ経験が有る人員だった為Kotlinでの開発の知見や開発手法・ツール提案などを実施し作業効率の向上を図った
- iOS開発自体が知識経験がほぼゼロの状態なので業務時間外でもキャッチアップを行い不利を補った
- Bluetooth通信については iOS×BLE Core Bluetoothプログラミング を参考に実装
2017年06月 - 2017年11月 / BtoC / 空調機・化学製品メーカーの製品用リモコンアプリ開発 👍
- Android Mobile, Java, Glide
- 大手空調機・化学製品メーカーのエアコン・空気清浄機のリモコン(宅内・宅外)アプリ開発のAndroid側を担当
- 開発体制の改善提案等も実施
- 出社での業務
- 6人チームのAndroid側を担当
- 基本設計・詳細設計・実装・単体テストを実施
- 空調製品を操作するアプリの機能追加・改修を行う
- メーカー側のブランドキャラクターのAnimation GIFを読み込み動作させる
- Androidのアニメーション機能を用いてアニメーションさせていないので途中で動作を止める等の細かい制御が簡単に出来ず実装が難航
- 屋外からの空調機器操作を行う機能を追加する
- LANに接続された空調製品とアプリを仲立ちする機器が有りそちらと連携する事で温度・湿度の取得や運転モードの設定を空調製品に伝達する機能
- 当時の法律では屋外からの家電操作が厳しく制限されていたため法律に配慮した実装となり仕様が難解になり実装が難航
- 新しい運転モードへの対応
- 正社員同様業務委託メンバーも顧客と仕様調整を行うミーティングに参加するよう求められていたので積極的により実装が簡単になるよう働きかけた
- 他のメンバーの誰一人としてレビューをする意味を理解しておらず相互レビューではあったが仕様不備指摘や実装改善提案などをレビューでしていない状態だった
- リーダブルコードを基にしながらレビューで他メンバーにどのようにレビューをするかを示した
- ECサイトアプリ開発の時と同様テスト項目書を作成する事を求められたのでテスト観点表を作成してそれを基にしてテスト項目書を作成する流れになるよう働きかけた
- Gitのコミットメッセージやコメントもコードを日本語で説明するような役に立たない状態だったのでコードには How コミットログには Why コードコメントには Why not を書く形にするようレビューを中心として働きかけた
- メソッド名も同様
2017年02月 - 2017年05月 / BtoB / 配送事業者のアプリ開発
- 大手配送事業者の次世代業務端末機の開発。
- 10人チームのAndroid側を担当
- 詳細設計・実装・単体テスト・結合テストを実施
2016年06月 - 2017年01月 / BtoC / ECサイトアプリ開発 👍
- 大手コンビニ事業者が、複数アプリで提供していたサービスを統合する事を目的とするアプリの開発
- 出社での業務
- 6人チームのAndroid側を担当
- 基本設計・詳細設計・実装・単体テスト・結合テストを実施
- 多数ある自社ブランドを一つのアプリで提供する事を目的とするアプリの機能追加や改修を行う
- Nativeのログイン画面をWebViewに置き換える
- 通常は逆だがコンビニ事業者側よりログイン画面のデザイン都合でWebView化を行う事となった
- DOMをJavaScriptで細かく制御する必要が有るがこの時期のAndroid端末はOSバージョンや端末によってWebViewの動作が一様でない為最後までこの部分の実装で難航する事になる
- Excelで基本設計書・詳細設計書・テスト仕様書を作成する事を求められる為実装前にそれらのドキュメントレビューを行い実装を行う流れ
- ウォーターフォールだが設計書のレビューが通った後に実装を進めると実現出来ないケースや想定通りに動作しない事が判明するケースが多く設計書を修正しながら実装をする事が多かった
- テスト仕様書についてはテスト仕様書そのものをレビューすると項目自体が多すぎてレビュー漏れが多発した為後半からはテスト観点表をレビューしそれを基にテスト項目書を作成し手動テストを行う流れとなった
- 一つ一つの実装にログ出力とコメントを書く事が求められた為要望に沿って実装
- コメントが実装と乖離したり間違っている事も多いが保守されず放置されている
- 使用されていないクラスの削除も認められない為不要なコードが多数残ったまま放置されている
- プロジェクト体制や人員に多くの問題を抱える中で周りの先に参画しているエンジニアに仕様やコーディングについての助言を積極的に請う事で作業時間の短縮を図った
2016年03月 - 2016年06月 / BtoC / 株式会社ハコブネ / 適正診断アプリ開発
- 職業適性を診断するアプリの開発の端末側を一人で担当。
- 企画内容に基づいて開発。
- Cocos2d-x使用。
- 要件定義・基本設計・詳細設計・実装・単体テスト・結合テスト・総合テスト・保守・運用を実施
2016年02月 - 2016年03月 / BtoB / 株式会社ハコブネ / Androidビーコンアプリ開発
- バスの通行状態を検知するビーコンアプリの開発の端末側を一人で担当。
- 要件定義・基本設計・詳細設計・実装・単体テスト・結合テスト・総合テスト・保守・運用を実施
2016年01月 - 2016年02月 / BtoC / 株式会社ハコブネ / プログラミング教育講師・チューター
- 子供向けにプログラミング授業を中学校や学習塾などへ提供。講師の育成など。
- Scratchを使用。
2015年11月 - 2016年05月 / BtoC / 株式会社ハコブネ / 遺言動画保存アプリ開発
- 遺言動画を撮影・保存するアプリの開発の端末側を一人で担当。
- 企画内容に基づいて開発。
- 要件定義・基本設計・詳細設計・実装・単体テスト・結合テスト・総合テスト・保守・運用を実施
2015年01月 - 2016年02月 / BtoC / 株式会社ハコブネ / 育成シュミレーションアプリ開発 👍
- Cocos2d-x, Android Mobile, iOS, C++, Java, Objective-C, ニフクラ mobile backend
- 自社開発の昆虫育成シュミレーションアプリを企画・開発
- 台湾ベンダーとの共同事業。Cocos2d-x使用
- 10月のリリース後はアップデートや保守等を一人で実施
- 出社での業務
- 1-4人チームの実装を担当
- 要件定義・基本設計・詳細設計・実装・単体テスト・結合テスト・総合テスト・保守・運用を実施
- 受託開発メインの会社だったが自社プロダクトを持つために協業している台湾の会社と協力しゲームアプリを作成する
- Cocos2d-xを使用する事でAndroid・iOSそれぞれでゲームアプリを提供する
- Cocos2d-xのバージョンアップが頻繁に有り公式のバージョンアップコマンドを単純に実行すると失敗しビルドが出来なくなる事が多い等決して使い勝手の良いフレームワークでは無かった
- Cocos Studio を当初使用して開発していたため保守の段階で Cocos Creator になった際にデータに互換性が無く保守が難航
- C++コードからは呼び出せない各OS依存の処理(SNSへの投稿でIntentを使用する等)はJNI等を使用してネイティブ連携
- 自社のデザイナープランナーと台湾ベンダーのデザイナープランナープログラマーと協力し企画から実装・テストまで全部担当
- 台湾ベンダー側のプログラマーのコード品質が低すぎたため途中から外れて頂きその部分も自分で巻き取り
- アプリのimpressionの効果測定の為のライブラリ導入(C++ではなくJavaとObjective-Cでそれぞれ導入)
- PUSH通知を行うためにニフクラ mobile backendを導入
- 公式ドキュメント通りに導入しようとすると上手くいかなかった為導入が難航
- 業務時間外でのキャッチアップ
- 入れ替わりで辞めていった正社員の方が在籍している間に可能な限り知見の共有を行ってもらう事で知識・経験不足を補った