1

我正在尝试制作一个可以远距离控制的简单 android 媒体播放器应用程序。目前,我正在尝试解决在手机上发送有关艺术家/专辑/歌曲的所有信息的问题。目前我正在检索所有信息:

private val contentResolver = activity.contentResolver!!

fun getAll():Set<Album>{
    val res = mutableSetOf<Album>()
    val cursor = contentResolver.query(MediaStore.Audio.Albums.EXTERNAL_CONTENT_URI,
            arrayOf(
                    MediaStore.Audio.Albums.ALBUM,
                    MediaStore.Audio.Albums.ALBUM_ART,
                    MediaStore.Audio.Albums.NUMBER_OF_SONGS,
                    MediaStore.Audio.Albums.ARTIST)
            ,null,null)
    if(cursor!!.moveToFirst())
        do {
            res.add(Album().apply {
                name = cursor.getString(0)
                if (!cursor.getString(1).isNullOrEmpty())
                    albumArtUri = Uri.parse(cursor.getString(1))
                songCount = cursor.getInt(2)
                artist = Artist().apply {
                    name = cursor.getString(3)
                }
            })
            cursor.moveToNext()
        }while (!cursor.isAfterLast)
    cursor.close()
    return res
}

看到我正在使用游标,我以为我正在使用一种数据库(SQLite 左右)如您所见,这是一组仅包含少量信息的对象的大量代码;创建的专辑对象中没有歌曲。为此,您需要开始一个新的查询、开始和一个新的 URI。现在我想我可以使用 ORM。所以我实际上可以用歌曲列表等填充专辑对象。我决定尝试 Jetbrains Exposed,输入:

 val database = Database.connect(....)

我很茫然,我不知道如何连接到这个数据库。我似乎找不到任何关于如何开始的例子。

4

1 回答 1

1

暴露用于 JDBC。ContentResolver没有使用 JDBC,并且Cursor不是来自 JDBC 的对象。通常,Android 在应用程序或操作系统级别不使用 JDBC。

于 2019-01-06T23:31:24.867 回答