3大 AIプラグイン ショートカット比較表(Copilot / JetBrains AI / Gemini)

 

🤔 3大AIプラグイン ショートカット比較表(Copilot / JetBrains AI / Gemini)

機能 GitHub Copilot JetBrains AI Assistant Gemini for Android Studio
AIコード補完の表示 ⌥](次候補)
⌥[(前候補)
⌥Space ⌘I または Ctrl+I
AI候補を確定 Tab または Enter Enter Enter
補完候補を拒否 Esc Esc Esc
AIチャットを開く ⌘⇧I ⌥⇧A ⌘⇧.
選択コードの説明 / 修正 ⌘⇧\\ ⌥Enter → 「AI提案」 ⌘⇧L
コメントからコード生成 // コメント後に Enter AIチャットから「コード生成」 コメント入力 → ⌘Enter
コードの最適化・修正 ⌘.(Quick Fix) ⌥Enter → 「AIでリファクタ」 ⌘⇧M
ドキュメント生成 / 説明追加 ⌘⇧/ AIチャット「この関数を説明して」 ⌘⇧D
選択範囲に対するAI操作 ⌘⇧\\(説明・修正) ⌥Enter ⌘⇧L
ファイル全体を改善 なし(コメントから提案) ⌥⇧A → 「ファイルを改善」 ⌘⇧F

 

🤔 AIプラグイン運用おすすめ(衝突回避パターン)

利用スタイル 構成 特徴・おすすめポイント
① コーディング中心型
(AI補完を重視)
Copilot + JetBrains AI(Copilot優先) Copilotの補完をメインに、JetBrains AIは「説明」「修正」時のみ使用。
⌥EnterをAI専用に割り当てると安定。
② 設計・レビュー重視型
(AI説明とチャットを多用)
JetBrains AI + Gemini(Copilotオフ) チャットでの説明・リファクタが中心。GeminiでAndroid特有の質問も可能。
⌥⇧A⌘⇧. の競合に注意。
③ Android特化開発型
(Geminiメイン)
Geminiのみ or Gemini + Copilot Android Studio統合が深く、ComposeやAPI質問が即答。
Copilotを補完専用に使うと最も安定。
④ 学習・試行型
(全部試すタイプ)
Copilot + JetBrains AI + Gemini(全併用) ショートカット競合が多発。どれを「補完用」「チャット用」にするか明確化必須。
設定から「Keymapのカスタム」を推奨。

 

🤔 AIプラグイン ショートカット競合リスク表

組み合わせ 競合リスク 主な衝突ショートカット 対策・回避策
Copilot + JetBrains AI ★★★☆(中〜高) ⌥Enter, Tab, ⌘. JetBrains側のAI提案を「右クリック呼び出し」に変更推奨。
CopilotをTab確定中心に設定。
JetBrains AI + Gemini ★★★(中) ⌥⇧A, ⌘⇧. どちらを「チャット起動」に使うか決める。
Geminiを ⌘⇧; にリマップ推奨。
Copilot + Gemini ★★(低〜中) Enter, ⌘I 競合は軽度。Copilotを補完専用・Geminiをチャット専用に分離。
Copilot + JetBrains AI + Gemini ★★★★(高) ⌘⇧I, ⌥Enter, Enter 全AIのショートカットを手動で再割り当て必須。
Preferences → Keymapで確認・上書きを推奨。

 

🤔 まとめ:

・同時導入するなら「補完」「チャット」「リファクタ」の役割を分ける。
・競合は特に ⌥Enter⌘⇧I に集中。
・キー設定は Keymap → Search: “AI” で全体を確認しておくのが安全。

Copilot:補完が最速で自然、Tab確定中心の軽快操作。
JetBrains AI:リファクタやドキュメント生成など開発支援が得意。
Gemini:Android Studioに最も深く統合され、自然言語操作が強力。


『AIで書いたコードは危険』と語る著名プログラマーたちのコメント

 

🤔 Jake Wharton

I really dislike all this 'auto complete sold as AI by big corpo' crap.

私はこの“大企業がAIとして売っているオートコンプリート”というクソみたいなものが本当に嫌いだ。

Don't blindly trust code generated by AI; always review and understand it.

AIが生成したコードを盲目的に信頼してはいけない。必ずレビューし、理解すること。

 

🤔 Andrew Ng

Just vibe coding is not going to help. Using and relying on generated code is dangerous. AI generated code can produce hallucinations.

vibe codingは役に立たない。生成されたコードを使って頼るのは危険だ。AIが生成するコードは幻覚を生じる可能性がある。

 

🤔 Martin Fowler

When I’m using AI for coding, I find myself constantly making little risk assessments about whether to trust the AI, how much to trust it, and how much work I need to put into the verification of the results.

AIを使ってコーディングをしているとき、私は常にAIを信頼するかどうか、その信頼度をどの程度にするか、結果の検証にどれだけの労力をかけるべきかを小さなリスク評価として行っています。

 

🤔 Kent Beck

I feel good about the correctness & performance, not so good about the code quality. When I try to write the code as a literate program there's ...

私は正確性とパフォーマンスには満足していますが、コードの品質にはあまり満足していません。コードをリテラルプログラムとして書こうとすると…

 

🤔 Robert C. Martin

The clean coder 'Uncle Bob' aka Robert C. Martin reflects on his career, the way he works and what advice he would give to his younger self if he were to start ...

クリーンコーダー“Uncle Bob”ことRobert C. Martinは、自身のキャリア、働き方、そして若い頃の自分にどんなアドバイスをするかについて振り返っています。

 

🧑🏻‍💻 まとめ

著名なプログラマー達は、AIをコーディングの補助ツールとして評価しつつも慎重な姿勢を見せています。

AIが生成したコードは盲信せず、品質管理の最終的な責任は開発者自身が負うべきだと彼らは強調します。

結論として、AIは便利なツールですが、その出力は常に人間の手でレビュー・検証される必要があります。


Jetpack Compose 1.7+ でクリップボードコピーをどう書く?

 

🧑🏻‍💻 LocalClipboard と suspend 関数の組み合わせ

Compose 1.7 以降では、従来の ClipboardManager が非推奨になり、代わりに LocalClipboard + 非同期コピー が公式に推奨されています。

以下はシンプルなサンプルです。rememberCoroutineScope を使い、クリックイベントで非同期コピーを行っています。


val clipboard = LocalClipboard.current
val scope = rememberCoroutineScope()

Box(modifier = Modifier.clickable {
    scope.launch {
        val clipData = ClipData.newPlainText(uuid, uuid)
        clipboard.setClipEntry(clipData.toClipEntry())
    }
})

👉 Jason Ernst: Android ClipboardManager Deprecated: How to fix

 

🧑🏻‍💻 ViewModel 側でコピー処理をまとめる

世界的に著名な Android 開発者 Chris Banes や Jake Wharton のサンプルコードでは、UI 層から直接 Clipboard を操作せず、ViewModel に処理をまとめる パターンが多く見られます。

このアプローチを取ることで、UI の再コンポーズと Clipboard 操作が分離でき、よりテストしやすい設計になります。


class NoteViewModel : ViewModel() {
  fun copy(block: suspend () -> Unit) {
    viewModelScope.launch {
      block()
    }
  }
}

UI 側では以下のように呼び出せます:


IconButton(
  onClick = { 
    viewModel.copy {
      clipboard.setText(item.text)
    }
  }
) {
  Icon(Icons.Default.ContentCopy, contentDescription = null)
}

Clipboard 拡張関数を定義しておくと便利です。


suspend fun Clipboard.setText(text: String) { 
    val clipData = ClipData.newPlainText(text, text).toClipEntry() 
    setClipEntry(clipData)
}

 

🧑🏻‍💻 まとめ

ClipboardManager は非推奨 → LocalClipboard + suspend が公式推奨。

UI 層はイベントを投げるだけ、コピー処理は ViewModel で完結。

Coroutine scope を ViewModel 内で扱うことで UI の再コンポーズに影響しない。

ViewModel が clipboard を直接握るのは避けたほうがベター。
(非 UI 層に UI 依存を持ち込むことになるため)

拡張関数で共通処理化すれば再利用性が高まる。

つまり、

「UI はシンプルに」「コピー処理は ViewModel に集約」

これが現代的な Compose + Clipboard のベストプラクティスです。