jpskill.com
📦 その他 コミュニティ

android-jetpack

Jetpack: Room, Navigation, WorkManager, DataStore, CameraX, Hilt injection, Paging 3

⚡ おすすめ: コマンド1行でインストール(60秒)

下記のコマンドをコピーしてターミナル(Mac/Linux)または PowerShell(Windows)に貼り付けてください。 ダウンロード → 解凍 → 配置まで全自動。

🍎 Mac / 🐧 Linux
mkdir -p ~/.claude/skills && cd ~/.claude/skills && curl -L -o android-jetpack.zip https://jpskill.com/download/22253.zip && unzip -o android-jetpack.zip && rm android-jetpack.zip
🪟 Windows (PowerShell)
$d = "$env:USERPROFILE\.claude\skills"; ni -Force -ItemType Directory $d | Out-Null; iwr https://jpskill.com/download/22253.zip -OutFile "$d\android-jetpack.zip"; Expand-Archive "$d\android-jetpack.zip" -DestinationPath $d -Force; ri "$d\android-jetpack.zip"

完了後、Claude Code を再起動 → 普通に「動画プロンプト作って」のように話しかけるだけで自動発動します。

💾 手動でダウンロードしたい(コマンドが難しい人向け)
  1. 1. 下の青いボタンを押して android-jetpack.zip をダウンロード
  2. 2. ZIPファイルをダブルクリックで解凍 → android-jetpack フォルダができる
  3. 3. そのフォルダを C:\Users\あなたの名前\.claude\skills\(Win)または ~/.claude/skills/(Mac)へ移動
  4. 4. Claude Code を再起動

⚠️ ダウンロード・利用は自己責任でお願いします。当サイトは内容・動作・安全性について責任を負いません。

🎯 このSkillでできること

下記の説明文を読むと、このSkillがあなたに何をしてくれるかが分かります。Claudeにこの分野の依頼をすると、自動で発動します。

📦 インストール方法 (3ステップ)

  1. 1. 上の「ダウンロード」ボタンを押して .skill ファイルを取得
  2. 2. ファイル名の拡張子を .skill から .zip に変えて展開(macは自動展開可)
  3. 3. 展開してできたフォルダを、ホームフォルダの .claude/skills/ に置く
    • · macOS / Linux: ~/.claude/skills/
    • · Windows: %USERPROFILE%\.claude\skills\

Claude Code を再起動すれば完了。「このSkillを使って…」と話しかけなくても、関連する依頼で自動的に呼び出されます。

詳しい使い方ガイドを見る →
最終更新
2026-05-18
取得日時
2026-05-18
同梱ファイル
1

📖 Skill本文(日本語訳)

※ 原文(英語/中国語)を Gemini で日本語化したものです。Claude 自身は原文を読みます。誤訳がある場合は原文をご確認ください。

[Skill 名] android-jetpack

android-jetpack

目的

このスキルは、効率的で保守性の高い Android アプリを構築するために、Android Jetpack コンポーネントを統合するためのツールを提供します。データベースには Room、UI フローには Navigation、バックグラウンドタスクには WorkManager、設定には DataStore、カメラ操作には CameraX、依存性注入には Hilt、データ読み込みには Paging 3 に焦点を当てています。

使用する場面

永続的なストレージ(例: SQLite 用の Room)、画面間のナビゲーション(例: Navigation Component)、スケジュールされたタスク(例: WorkManager)、安全な設定(例: DataStore)、カメラ機能(例: CameraX)、モジュール式の依存性注入(例: Hilt)、または効率的なページネーション(例: Paging 3)が必要な Android アプリを構築する際に、このスキルを使用します。複雑なデータフロー、バックグラウンド処理、またはハードウェアとの連携を伴うアプリに適用してください。

主な機能

  • Room: SQLite データベース用の ORM。エンティティ、DAO、マイグレーションをサポートしています。
  • Navigation: NavController を介してフラグメントトランザクションとディープリンクを管理します。
  • WorkManager: ネットワーク接続などの制約付きで、遅延可能なタスクをスケジュールします。
  • DataStore: SharedPreferences をプロトコルバッファに置き換え、型付きストレージを提供します。
  • CameraX: カメラハードウェアを抽象化し、プレビュー、キャプチャ、分析を可能にします。
  • Hilt: Android 固有のアノテーションを使用して、Dagger による依存性注入を簡素化します。
  • Paging 3: リストのデータをページ単位で読み込み、LiveData または Flow と統合します。

使用パターン

Room を使用するには、build.gradle に依存関係を追加します: implementation 'androidx.room:room-runtime:2.5.0'。エンティティを定義します: @Entity class User(val id: Int, val name: String)。DAO を作成します: interface UserDao { @Query("SELECT * FROM user") fun getAll(): List<User> }。データベースを設定します: Room.databaseBuilder(context, AppDatabase::class.java, "database-name").build()

Navigation の場合、build.gradle に追加します: implementation 'androidx.navigation:navigation-fragment-ktx:2.5.0'。XML で Nav Graph を作成します: <navigation xmlns:android="http://schemas.android.com/apk/res/android" ...> <fragment android:id="@+id/mainFragment" ...> <action android:id="@+id/action_to_detail" app:destination="@id/detailFragment" /> </fragment> </navigation>。コードでナビゲートします: findNavController().navigate(R.id.action_to_detail)

Hilt を統合するには、以下を追加します: implementation 'com.google.dagger:hilt-android:2.44'。アプリケーションにアノテーションを付けます: @HiltAndroidApp class MyApp : Application()。依存関係を注入します: @AndroidEntryPoint class MainActivity : AppCompatActivity() { @Inject lateinit var viewModel: MyViewModel }

WorkManager の場合、タスクをキューに入れます: WorkManager.getInstance(context).enqueue(OneTimeWorkRequestBuilder<MyWorker>().build())。ワーカーを定義します: class MyWorker(context: Context, params: WorkerParameters) : Worker(context, params) { override fun doWork(): Result { // Perform task return Result.success() } }

設定に DataStore を使用します: implementation 'androidx.datastore:datastore-preferences:1.0.0' を追加します。アクセスします: val dataStore = applicationContext.dataStore。読み書きします: dataStore.edit { settings -> settings[STRING_KEY] = "value" }

CameraX を使用してカメラをバインドします: ProcessCameraProvider.getInstance(context).use { provider -> val camera = provider.bindToLifecycle(this, cameraSelector, preview) }。プレビューを設定します: val preview = Preview.Builder().build().also { it.setSurfaceProvider(viewFinder.surfaceProvider) }

Paging 3 の場合、PagingSource を作成します: class UserPagingSource : PagingSource<Int, User>() { override suspend fun load(params: LoadParams<Int>): LoadResult<Int, User> { // Fetch data return LoadResult.Page(data, prevKey, nextKey) } }。ViewModel で使用します: val pager = Pager(config) { UserPagingSource() }.flow

一般的なコマンド/API

  • Room CLI: Room の統合を確認するには ./gradlew dependencies を使用します。マイグレーションの場合、ADB を介してデータベースクエリを実行します: adb shell sqlite3 /data/data/your.package/databases/yourdb "PRAGMA user_version;"
  • Navigation API: 遷移には NavController.navigate(actionId) を呼び出します。ディープリンクを使用します: Nav Graph で <deepLink app:uri="yourapp://details/{id}" />
  • WorkManager API: 制約付きでキューに入れます: OneTimeWorkRequestBuilder<MyWorker>().setConstraints(Constraints.Builder().setRequiredNetworkType(NetworkType.CONNECTED).build()).build()。ステータスをクエリします: WorkManager.getInstance().getWorkInfosForUniqueWork("workName").observe(...)
  • DataStore API: 設定を読み取ります: dataStore.data.map { preferences -> preferences[STRING_KEY] }。フローを処理します: collect { value -> /* process */ } を使用します。
  • CameraX API: 画像をキャプチャします: imageCapture.takePicture(outputFileOptions, executor, object : ImageCapture.OnImageSavedCallback { override fun onImageSaved(output: ImageCapture.OutputFileResults) { // Handle saved file } })
  • Hilt API: ./gradlew hiltGenerateSources でコードを生成します。モジュールを注入します: @Module @InstallIn(SingletonComponent::class) class AppModule { @Provides fun provideService(): Service = Service() }
  • Paging 3 API: ネットワークと DB の両方で RemoteMediator と組み合わせます: Pager( config = PagingConfig(pageSize = 20), remoteMediator = UserRemoteMediator(), pagingSourceFactory = { UserPagingSource() } )

統合に関する注意事項

Room を Hilt と統合するには、データベースにアノテーションを付けます: @Database(entities = [User::class], version = 1) @HiltDatabase abstract class AppDatabase : RoomDatabase() { abstract fun userDao(): UserDao }。WorkManager と Navigation の場合、フラグメントで作業ステータスを監視します: WorkManager.getInstance().getWorkInfoByIdLiveData(workId).observe(viewLifecycleOwner) { info -> if (info.state == WorkInfo.State.SUCCEEDED) navigateToResult() }。DataStore を Paging と組み合わせて使用します: ページネーションキーを DataStore に保存し、フローを介して取得します。CameraX の場合、権限を確認します: ContextCompat.checkSelfPermission(context, Manifest.permission.CAMERA) == PackageManager.PERMISSION_GRANTED で確認します。API キーが必要な場合(例: WorkManager の外部サービスの場合)、build.gradle または strings.xml で $GOOGLE_API_KEY のような環境変数を使用します。Paging を Room と組み合わせます。

📜 原文 SKILL.md(Claudeが読む英語/中国語)を展開

android-jetpack

Purpose

This skill provides tools for integrating Android Jetpack components to build efficient, maintainable Android apps, focusing on Room for databases, Navigation for UI flows, WorkManager for background tasks, DataStore for preferences, CameraX for camera operations, Hilt for dependency injection, and Paging 3 for data loading.

When to Use

Use this skill when building Android apps that need persistent storage (e.g., Room for SQLite), navigation between screens (e.g., Navigation Component), scheduled tasks (e.g., WorkManager), secure preferences (e.g., DataStore), camera features (e.g., CameraX), modular dependency injection (e.g., Hilt), or efficient pagination (e.g., Paging 3). Apply it in apps with complex data flows, background processing, or hardware interactions.

Key Capabilities

  • Room: ORM for SQLite databases; supports entities, DAOs, and migrations.
  • Navigation: Manages fragment transactions and deep links via NavController.
  • WorkManager: Schedules deferrable tasks with constraints like network availability.
  • DataStore: Replaces SharedPreferences with protocol buffers for typed storage.
  • CameraX: Abstracts camera hardware for preview, capture, and analysis.
  • Hilt: Simplifies Dagger for dependency injection with Android-specific annotations.
  • Paging 3: Loads data in pages for lists, integrating with LiveData or Flow.

Usage Patterns

To use Room, add the dependency in build.gradle: implementation 'androidx.room:room-runtime:2.5.0'. Define an Entity: @Entity class User(val id: Int, val name: String). Create a DAO: interface UserDao { @Query("SELECT * FROM user") fun getAll(): List<User> }. Set up the database: Room.databaseBuilder(context, AppDatabase::class.java, "database-name").build().

For Navigation, add in build.gradle: implementation 'androidx.navigation:navigation-fragment-ktx:2.5.0'. Create a Nav Graph in XML: <navigation xmlns:android="http://schemas.android.com/apk/res/android" ...> <fragment android:id="@+id/mainFragment" ...> <action android:id="@+id/action_to_detail" app:destination="@id/detailFragment" /> </fragment> </navigation>. Navigate in code: findNavController().navigate(R.id.action_to_detail).

Integrate Hilt by adding: implementation 'com.google.dagger:hilt-android:2.44'. Annotate your application: @HiltAndroidApp class MyApp : Application(). Inject dependencies: @AndroidEntryPoint class MainActivity : AppCompatActivity() { @Inject lateinit var viewModel: MyViewModel }.

For WorkManager, enqueue a task: WorkManager.getInstance(context).enqueue(OneTimeWorkRequestBuilder<MyWorker>().build()). Define the worker: class MyWorker(context: Context, params: WorkerParameters) : Worker(context, params) { override fun doWork(): Result { // Perform task return Result.success() } }.

Use DataStore for preferences: Add implementation 'androidx.datastore:datastore-preferences:1.0.0'. Access it: val dataStore = applicationContext.dataStore. Read/write: dataStore.edit { settings -> settings[STRING_KEY] = "value" }.

With CameraX, bind the camera: ProcessCameraProvider.getInstance(context).use { provider -> val camera = provider.bindToLifecycle(this, cameraSelector, preview) }. Configure preview: val preview = Preview.Builder().build().also { it.setSurfaceProvider(viewFinder.surfaceProvider) }.

For Paging 3, create a PagingSource: class UserPagingSource : PagingSource<Int, User>() { override suspend fun load(params: LoadParams<Int>): LoadResult<Int, User> { // Fetch data return LoadResult.Page(data, prevKey, nextKey) } }. Use in ViewModel: val pager = Pager(config) { UserPagingSource() }.flow.

Common Commands/API

  • Room CLI: Use ./gradlew dependencies to verify Room integration. For migrations, run database queries via ADB: adb shell sqlite3 /data/data/your.package/databases/yourdb "PRAGMA user_version;".
  • Navigation API: Call NavController.navigate(actionId) for transitions. Use deep links: <deepLink app:uri="yourapp://details/{id}" /> in Nav Graph.
  • WorkManager API: Enqueue with constraints: OneTimeWorkRequestBuilder<MyWorker>().setConstraints(Constraints.Builder().setRequiredNetworkType(NetworkType.CONNECTED).build()).build(). Query status: WorkManager.getInstance().getWorkInfosForUniqueWork("workName").observe(...).
  • DataStore API: Read preferences: dataStore.data.map { preferences -> preferences[STRING_KEY] }. Handle flows: Use collect { value -> /* process */ }.
  • CameraX API: Capture image: imageCapture.takePicture(outputFileOptions, executor, object : ImageCapture.OnImageSavedCallback { override fun onImageSaved(output: ImageCapture.OutputFileResults) { // Handle saved file } }).
  • Hilt API: Generate code with ./gradlew hiltGenerateSources. Inject modules: @Module @InstallIn(SingletonComponent::class) class AppModule { @Provides fun provideService(): Service = Service() }.
  • Paging 3 API: Combine with RemoteMediator for network + DB: Pager( config = PagingConfig(pageSize = 20), remoteMediator = UserRemoteMediator(), pagingSourceFactory = { UserPagingSource() } ).

Integration Notes

Integrate Room with Hilt by annotating the database: @Database(entities = [User::class], version = 1) @HiltDatabase abstract class AppDatabase : RoomDatabase() { abstract fun userDao(): UserDao }. For WorkManager and Navigation, observe work status in a fragment: WorkManager.getInstance().getWorkInfoByIdLiveData(workId).observe(viewLifecycleOwner) { info -> if (info.state == WorkInfo.State.SUCCEEDED) navigateToResult() }. Use DataStore with Paging: Store pagination keys in DataStore and retrieve via flows. For CameraX, ensure permissions: Check with ContextCompat.checkSelfPermission(context, Manifest.permission.CAMERA) == PackageManager.PERMISSION_GRANTED. If API keys are needed (e.g., for external services in WorkManager), use env vars like $GOOGLE_API_KEY in build.gradle or strings.xml. Combine Paging with Room: Use Room as the data source in PagingSource.

Error Handling

For Room, catch SQLite exceptions: try { dao.insert(user) } catch (e: SQLiteConstraintException) { Log.e("RoomError", e.message ?: "Constraint violation") }. Handle Navigation errors: Use NavController.addOnDestinationChangedListener to catch invalid actions. For WorkManager, check Result.retry() in doWork: if (error) return Result.retry(). DataStore errors: Wrap reads in try-catch for IOException. CameraX: Handle CameraX.bindToLifecycle failures with try { provider.unbindAll() } catch (e: IllegalStateException) { Log.e("CameraError", "Binding failed") }. Hilt: Resolve injection errors by checking @Inject annotations and running ./gradlew clean. Paging 3: Catch LoadState errors: pager.loadStateFlow.collect { state -> if (state.refresh is LoadState.Error) Log.e("PagingError", state.refresh.error.message ?: "Load failed") }.

Concrete Usage Examples

  1. Example: User app with Room and Hilt: In a ViewModel, inject Room DAO: @HiltViewModel class UserViewModel @Inject constructor(private val userDao: UserDao) : ViewModel() { fun getUsers() = userDao.getAll() }. In Activity: Use Hilt to inject and display: viewModel.getUsers().observe(this) { users -> adapter.submitList(users) }.
  2. Example: Background sync with WorkManager and DataStore: Enqueue a worker to fetch data and store in DataStore: WorkManager.enqueue(OneTimeWorkRequestBuilder<SyncWorker>().build()). In worker: dataStore.edit { it[LAST_SYNC_KEY] = System.currentTimeMillis() }. Then, in UI, read from DataStore to check last sync.

Graph Relationships

  • Room depends on: Android core (for SQLite) and Hilt (for injection).
  • Navigation integrates with: WorkManager (for async nav) and Paging 3 (for list navigation).
  • WorkManager relates to: DataStore (for storing results) and CameraX (for background processing).
  • DataStore connects to: Room (as an alternative storage) and Hilt (for injected access).
  • CameraX links to: Navigation (for camera UI flow).
  • Hilt provides injection for: All other components (Room, WorkManager, etc.).
  • Paging 3 works with: Room (as data source) and Navigation (for infinite lists).