在SQLite中保存坐标

时间:2012-08-10 07:06:05

标签: sqlite cordova storage

我正在为Cordova 2.0.0开发。我在android 2.2上测试我的应用程序。 现在我获得了获取用户位置的代码,然后使用标记在谷歌地图中显示它。首先是我的retreiving地理位置代码并在谷歌地图中显示:

> function onLoad() { document.addEventListener("deviceready",
> onDeviceReady, false); }
> 
> function onDeviceReady() {
> 
> }
> 
> var onSuccess = function(position) {
>     var myLat = position.coords.latitude;
>     var myLong = position.coords.longitude;
> 
>     
>     var mapOptions = {
>         center: new google.maps.LatLng(myLat, myLong),
>         zoom: 14,
>         mapTypeId: google.maps.MapTypeId.ROADMAP
>     };
> 
> var map = new google.maps.Map(document.getElementById("map_canvas"),
>                                   mapOptions);
> 
>     var marker = new google.maps.Marker({
>                                    position: new google.maps.LatLng(myLat, myLong),
>                                         map: map,
>                                         title:"Hello World!"
>                                         });
> 
> };
> 
> 
> function onError(error) {
>     alert('code: '    + error.code    + '\n' +
>           'message: ' + error.message + '\n'); }
> 
> 
> 
> navigator.geolocation.getCurrentPosition(onSuccess, onError,
>       {'enableHighAccuracy':true,'timeout':10000});

现在是我的数据库的代码,我使用了http://docs.phonegap.com/en/2.0.0/cordova_storage_storage.md.html#Storage中的示例:

> <!DOCTYPE html> <html>   <head>
>     <title>Storage Example</title>
>     <script type="text/javascript" src="jqtouch/jquery.js" charset="utf-8"></script>
>     <script type="text/javascript" src="jqtouch/jqtouch.js" charset="utf-8"></script>
>     <script type="text/javascript" charset="utf-8" src="cordova-2.0.0.js"></script>
>     <script type="text/javascript" charset="utf-8">
> 
>     // Wait for Cordova to load
>     //
>     document.addEventListener("deviceready", onDeviceReady, false);
> 
>     // Populate the database 
>     //
>     function populateDB(tx) {
>         tx.executeSql('DROP TABLE IF EXISTS DEMO');
>         tx.executeSql('CREATE TABLE IF NOT EXISTS DEMO (id unique, longitude, latitude)');
>         tx.executeSql('INSERT INTO DEMO (id INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT, longitude, latitude);
>     }
> 
>     // Query the database
>     //
>     function queryDB(tx) {
>         tx.executeSql('SELECT * FROM DEMO', [], querySuccess, errorCB);
>     }
> 
>     // Query the success callback
>     //
>     function querySuccess(tx, results) {   console.log("Returned rows = " + results.rows.length);   if (!results.rowsAffected) {
>     console.log('No rows affected!');
>     return false;   }   // for an insert statement, this property will return the ID of the last inserted row   console.log("Last inserted
> row ID = " + results.insertId);
>     }
> 
>     // Transaction error callback
>       function errorCB(err) {
>        console.log("Error processing SQL: "+err.code);
>     }
> 
>     // Transaction success callback
>    
>     function successCB() {
>         var db = window.openDatabase("Database", "1.0", "Cordova Demo", 200000);
>         db.transaction(queryDB, errorCB);
>     }
> 
>     // Cordova is ready
>     //    function onDeviceReady() {
>         var db = window.openDatabase("Database", "1.0", "Cordova Demo", 200000);
>         db.transaction(populateDB, errorCB, successCB);
>     }
> 
>     </script>   </head>   <body>
>     <h1>Example</h1>
>     <p>Database</p>   </body> </html>

我不确定如何将我将从我的GPS(地理位置)中检索的长/纬度值放入我的数据库中。 任何教程,示例代码或建议都非常感谢。

我想了很多这样的事情:

> //GEOLOCATION 
>     var onSuccess = function(position) {
>     var myLat = position.coords.latitude;
>     var myLong = position.coords.longitude;
>     insertEntry(latitude, longitude);
>     //MAP
> 
> 
> function insertEntry(latitude, longitude) {
>     db.transaction(
>         function(populateDB) {
>             tx.executeSql(
>                 'INSERT INTO entries (latitude, longitude) ' + 
>                     'VALUES (?, ?);',
>                 [latitude, longitude],
>                 function(){
>                    }, 
>                 errorHandler
>             );
>         }
>     );

1 个答案:

答案 0 :(得分:1)

您需要打开一个数据库:

var db = window.openDatabase("dbName", "1.0", "Db Name", 100000);

然后

db.transaction(
     function(populateDB) 
        .....

检查Phonegap Storage Docs