KotlinのCursorとContentProviderの基礎を完全解説!初心者でもわかるデータ取得の仕組み
生徒
「Kotlinで連絡先や画像など、スマホに入ってるデータをアプリから取り出すことってできますか?」
先生
「できますよ。そのときに使うのがContentProvider(コンテントプロバイダー)とCursor(カーソル)という仕組みです。」
生徒
「聞いたことあるけど、よく分かりません…どんな役割なんですか?」
先生
「それじゃあ、KotlinでのContentProviderとCursorの基礎を一緒におさらいしてみましょう!」
1. ContentProvider(コンテントプロバイダー)とは?
ContentProviderとは、Androidが提供する「他のアプリやシステムのデータにアクセスするための窓口」のことです。
例えば、連絡先・カレンダー・画像・動画・SMSなどのデータは、直接は触れません。その代わりに、ContentProviderを通じて安全にアクセスできるようになっています。
このように、ContentProviderはアプリ間でデータを共有するための仲介役なのです。
2. Cursor(カーソル)とは?
Cursorは、データベースの中の情報を一行ずつ取り出すための道具です。
たとえるなら、図書館のカード目録のようなもの。データがズラッと並んでいて、必要な1行ずつを順番に取り出して読むことができます。
Kotlinでは、ContentProviderからデータを取得したとき、結果はCursorの形で返されます。
3. KotlinでContentProviderからデータを取得する基本コード
たとえば、スマホに保存されている画像一覧を取り出すには、以下のようなコードを書きます。
val uri = MediaStore.Images.Media.EXTERNAL_CONTENT_URI
val projection = arrayOf(MediaStore.Images.Media._ID, MediaStore.Images.Media.DISPLAY_NAME)
val cursor = contentResolver.query(
uri,
projection,
null,
null,
"${MediaStore.Images.Media.DATE_ADDED} DESC"
)
cursor?.use {
val idColumn = it.getColumnIndexOrThrow(MediaStore.Images.Media._ID)
val nameColumn = it.getColumnIndexOrThrow(MediaStore.Images.Media.DISPLAY_NAME)
while (it.moveToNext()) {
val id = it.getLong(idColumn)
val name = it.getString(nameColumn)
// ここで画像IDや名前を使った処理をする
}
}
4. URIとは?ContentProviderの住所のようなもの
uriは、取得したいデータがどこにあるのかを指定する「住所」のようなものです。画像ならMediaStore.Images.Media.EXTERNAL_CONTENT_URIを使います。
連絡先を取得したいときは別のURI、カレンダーならまた別のURIが使われます。
5. projectionとは?欲しいデータだけを選ぶ
projectionは、「どのカラム(列)の情報がほしいか」を指定するものです。
たとえば、画像のIDとファイル名だけ欲しいなら、次のように書きます。
val projection = arrayOf(
MediaStore.Images.Media._ID,
MediaStore.Images.Media.DISPLAY_NAME
)
6. query関数の仕組み
contentResolver.query() は、ContentProviderに問い合わせをして、指定した情報をCursorの形で返してくれる関数です。
- 第1引数: どのデータを取るか(URI)
- 第2引数: どの列を取るか(projection)
- 第3~4引数: 絞り込み条件(今回はなし)
- 第5引数: 並び順(今回は新しい順)
7. Cursorの読み取り方と注意点
Cursorは、必ずwhile (it.moveToNext())で繰り返し処理をします。これにより、すべてのデータを1行ずつ順番に取り出すことができます。
そして、忘れてはいけないのがcursor?.use { ... }の形。これは、データを読み終えたら自動で閉じてくれる便利な書き方です。メモリの無駄遣いを防ぎます。
8. ContentProviderを使うときのパーミッションに注意
ContentProviderで画像や連絡先にアクセスするには、AndroidManifestにパーミッションを追加する必要があります。例えば画像を読む場合:
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
また、Android 10以降はScoped Storage(スコープ付きストレージ)という新しいルールがあるため、アクセス制限にも注意しましょう。
Kotlinを基礎からしっかり学びたい人や、 Java経験を活かしてモダンな言語にステップアップしたい人には、 定番の入門書がこちらです。
基礎からわかるKotlinをAmazonで見る※ Amazon広告リンク
9. ContentProviderはRoomとは別物
初心者が混乱しがちなのが、RoomとContentProviderの違いです。
Roomは自分のアプリ内で使うデータベース。
ContentProviderは他のアプリやシステムからデータを取得するための仕組み。
つまり、ContentProviderは「他人の家のデータを安全に見るための窓口」のようなものなんです。
【未経験OK】Kotlinで始めるプログラミング入門|ゼロから「動く喜び」を体験する60分
「プログラミングを始めたい」を形にする。最新言語Kotlinで楽しむ、ものづくりの第一歩。
本講座は、プログラミング経験が全くない方のためのエントリー講座です。「コードを書くってどういうこと?」という基本から、世界中で使われている最新言語Kotlin(コトリン)を使って、実際にプログラムを動かすまでを体験します。難しい理屈よりも、まずは「自分の手で動かす楽しさ」を最短距離で実感していただきます。
具体的な体験内容と環境
【つくるもの】
簡単な言葉を入力すると自動で返答してくれる「対話型ミニプログラム」や、計算を自動化する「便利ツール」をゼロから作成します。黒い画面に自分の書いた文字が表示される瞬間は、最高の感動体験です。
【開発環境】
プロのエンジニアが実際に使っている開発ツールIntelliJ IDEA(インテリジェイ)をインストールします。ボタン一つで日本語化し、初心者でも迷わず操作できる「魔法の設定」を一緒に行います。
この60分で得られる3つの体験
プロと同じ道具を揃えることで、明日から一人でもプログラミングを続けられる環境が整います。
「変数」や「型」といった難しい言葉も、身近な例え話で解説。モヤモヤをゼロにします。
Kotlinは英語に近くて読みやすいのが特徴。自分でコードを読んで、間違いを見つけるコツも伝授します。
※本講座は、パソコン操作が不安な方でも安心して受講いただける完全マンツーマンです。あなたのペースに合わせて、一つずつ丁寧に進めていきます。
Kotlinで始めるプログラミング入門|ゼロから「動く喜び」を体験