1

我实际上正在开发一个正在读取(而不是写入).mbtiles 文件的cordova 应用程序。那是一个用瓷砖归档的数据库,以便显示带有传单的离线地图。

与文件有关的所有内容(称为 test.mbtiles)都在工作:下载和打开。但是还有一个大问题。我无法阅读表格。这是我的代码的非功能示例:

getTileUrl: function (tilePoint, callBack) {
    var x = tilePoint.x;
    var y = tilePoint.y;
    var z = tilePoint.z;

    var base64Prefix = 'data:image/png;base64,';

    var db2 = new window.sqlitePlugin.openDatabase({name: 'test.mbtiles'});

    db2.transaction(function(tx) {

        tx.executeSql("SELECT tile_data FROM images INNER JOIN map ON images.tile_id = map.tile_id WHERE zoom_level = ? AND tile_column = ? AND tile_row = ?", [z, x, y], function (tx, res) {

                if(res.rows.length>0) {
                    console.log("success");
                    var src = base64Prefix + res.rows.item(0).tile_data;
                    callBack(src);
                }
                else {
                    console.log("response : no data");
                }
                }, function (tx, er) {
                    console.log('error with executeSql : ', er.message);
                    return;
                });
            });
   }

所以现在每次我尝试使用离线地图(使用设备上存在的 test.mbtiles 中的图块)时,我都会收到此错误:

error with executeSql :  no such table: images (code 1): , while compiling: SELECT tile_data FROM images INNER JOIN map ON images.tile_id = map.tile_id WHERE zoom_level = ? AND tile_column = ? AND tile_row = ?

所以我假设我得到的文件 test.mbtiles 不好,因为它没有任何images表。但这是错误的。我用来SQLite Database Browser查看我的数据库方案,发现images表在这里并填充了正确的数据。

有没有其他人有这个错误并且知道如何解决它?

顺便说一句,我正在使用最新版本的 SQLite Plugin 和 Cordova,主要在 android 上进行测试(如果 android 工作,将移植到 ios)。并且我想尽可能只使用 .js 文件,不添加任何 java 类等(会破坏整个工作流程)。

谢谢。

4

1 回答 1

1

MBTiles 规范将图块存储在一个名为tiles, notimages的表中。

于 2014-09-02T14:26:45.397 回答