Google「バックアップと同期」が謎だったので整理する

久しぶりに「Googleドライブ」と「バックアップと同期」を使ったら意味不明になっていた。

やりたいことは以下3つだけ。

複数パソコン間でのファイル共有。

スマホで撮影した写真・動画ファイルのクラウド保存と共有。
(端末内には保存しない。)

写真はパソコンからも参照。(ダウンロード)

ざっくり曖昧なまま図にしてみた。

そして、「バックアップと同期ツール」の設定を見る。

さらに、ブラウザでGoogleドライブを開く。

あれ、意味がわからない...。

「マイドライブ」
「マイiMac」

って何のことなのか...。

ややこしいので整理してみました。

基本的に持つと良い考え方

Googleのクラウドサービスとして「ドライブ」と「フォト」の2つがある。それぞれ個別に運用できる。

👉 マイドライブ - Google ドライブ 
👉 Google ドライブ - Google Play のアプリ 

👉 フォト - Google フォト 
👉 Google フォト - Google Play のアプリ 

「バックアップと同期」は、パソコン向けの「ドライブ」ツール。追加機能として、パソコン内の「画像と動画を抽出」してドライブ内指定ディレクトリと同期したり、Googleフォトにアップロードできる。

👉 バックアップと同期のダウンロード - 無料のクラウド ストレージ 

私の設定

複数パソコン内のディレクトリを指定して Googleドライブ で常に同期。
→ 「バックアップと同期」ツールで対応。

スマホで撮影した画像と動画はできるだけ Googleフォト にアップしてスマホからは消す。
→ スマホアプリ「Googleフォト」で対応。

写真や動画の実体はすべてクラウド上だけに置く。パソコン上ではブラウザ版、スマホ上ではアプリ版のGoogleフォトで参照・操作する。

「Googleドライブ」と「Googleフォト」は個別に運用する。

今は、できるだけ分かりやすくシンプルにしておく。

画像の画質やクラウドストレージ内容量やその料金などで細かく設定していこうと思っています。

まとめ

「マイ ドライブ」とは:

Googleドライブで同期されたディレクトリのクラウド側の呼び名、またはその機能。

「マイ iMac」とは:

パソコン上のディレクトリから画像と動画を自動抽出してGoogleドライブ内に同期する機能のこと。オプションとして、同時にGoogleフォトにもアップロードすることもできる。
(マイノートパソコン/マイパソコン/マイ MacBookPro なども同義。)

これに馴染めず私は混乱していたようです。

Googleクラウド上に保存するファイルサイズを増えさせての有料移行を推しているのだろう。

その他

Google ドライブの言語設定を変更したら「Googleドライブ」と「Google Drive」と同期ディレクトリが2つ作成されていてさらに混乱した。

どちらにしても「日本語カタカナ」と「スペース含み英字」のディレクトリ名になってるのキモス。

👉 【Googleフォト】一括で「高画質」へ変換して使用量を無制限にする方法 


Navigation Component がタブごとのバックスタックを実装すると思える理由

公開されているGoogleサンプルにて

下部タブごとのバックスタック実装。



自然だと思う。

コード内コメントを見ていると

👉 architecture-components-samples/NavigationExtensions.kt at master · android/architecture-components-samples 

This sample is a workaround until the Navigation Component supports multiple back stacks.

このサンプルは、ナビゲーションコンポーネントが複数のバックスタックをサポートするまでの回避策です。

この拡張関数周りのコードはコンポーネント内に内包されることになるのだろう。

が、しかし、Fragment のライフサイクルに依存しながら動くMVVMのスタイルでは、そのコンテンツデータの読み込みは再度行われることになるはず。

はっきり衝突してないか、

AAC と MVVM。

このサンプルでは、Fragment のみの実装なので複数のバックスタックがまともに動いているが、実際の現場ではそうはいかないはず。


Retorofit + JSON には「Kotlin Serialization Converter」がよい。

Retrofit は非常に有名なSquare製のJavaで書かれたAndroid 向け HTTP クライアントです。

👉 square/retrofit: Type-safe HTTP client for Android and Java by Square, Inc. 

その内部には Kotlin Serialization はサポートされていませんが、オブジェクトのシリアル化のためのコンバータファクトリを追加することができます。独自のコンバータファクトリを作成することもできますし、Jake Wharton が書いたものを使うこともできます。

👉 JakeWharton/retrofit2-kotlinx-serialization-converter: A Retrofit 2 Converter.Factory for Kotlin serialization. 

Retrofit2 Converter.Factory を利用するには、ライブラリ dependencies に追加したあと、Retorofit インスタンス生成時に、Extension Function である asConvertFactory を使ってそれを追加します。


val contentType = "application/json".toMediaType()

val retrofit = Retrofit.Builder()
 .baseUrl("https://www.example.com")
 .addConverterFactory(Json.asConverterFactory(contentType))
 .build()

簡単ですね!

ちなみに、.toMediaType() とは、


okhttp3.MediaType.Companion.toMediaType

です。

👉 「Kotlinx Json」の登場でサードパーティJSONライブラリは不要となる。