1

PhoneGap APIドキュメントを使用してジオロケーションを使用しようとしていますが、ジオロケーションはindex.htmlで機能しますが、別のページで同じ関数を使用しようとすると機能しません。

http://docs.phonegap.com/en/1.8.1/cordova_geolocation_geolocation.md.html#Geolocation

これは私が使用しているJSです。

これは、他のページに移動するために使用しているボタンです。

私もjQueryMobileを使用しています。

 <a href="test.html" data-theme="b" data-icon="plus">Add category</a></li>

これがtest.htmlのヘッドです

<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" />
<title></title>
<link rel="stylesheet" href="styles/jquery.mobile-1.1.0.min.css" />
<link rel="stylesheet" href="styles/jquery.mobile.structure-1.1.0.min.css" />
<link rel="stylesheet" href="styles/jquery.mobile.theme-1.1.0.min.css" />
<link rel="stylesheet" href="styles/my.css" />
<script src="scripts/jquery-1.7.2.min.js"></script>
<script src="scripts/jquery.mobile-1.1.0.min.js"></script>
<script src="scripts/cordova-1.8.1.js"></script>
<script>

    // Wait for Cordova to load
    //
    document.addEventListener("deviceready", onDeviceReady, false);

    var watchID = null;

    // Cordova is ready
    //
    function onDeviceReady() {
        // Throw an error if no update is received every 30 seconds
        var options = { timeout: 10000 };
        watchID = navigator.geolocation.watchPosition(onSuccess, onError, options);
    }

    // onSuccess Geolocation
    //
    function onSuccess(position) {
        var element = document.getElementById('geolocation');
        element.innerHTML = 'Latitude: ' + position.coords.latitude + '<br />' +
                        'Longitude: ' + position.coords.longitude + '<br />' +
                        '<hr />' + element.innerHTML;
    }

    // onError Callback receives a PositionError object
    //
    function onError(error) {
        alert('code: ' + error.code + '\n' +
          'message: ' + error.message + '\n');
    }
</script>
4

2 に答える 2

2

まず、Androidマニフェストで権限を付与します。

      android.permission.ACCESS_FINE_LOCATION
      android.permission.ACCESS_LOCATION_EXTRA_COMMANDS
      android.permission.ACCESS_COARSE_LOCATION

次に、cordova-1.8.1.jsをコピーし、アセットのwwwサブフォルダー内にindex.htmlを作成し、その後、cordova-1.8.1.jarをlibsにコピーして、cordova-1.8.1.jarでビルドパスを構成します。

次に、res-> xmlを作成し、プラグインをコピーします(以前にダウンロードしたPhoneGap 1.8.1から)。

次に、アプリケーションを実行します。間違いなくあなたは出力を得るでしょう。

于 2012-10-17T21:39:53.097 に答える
0

問題は、cordova.jarファイルをプロジェクトにロードしなかったために機能しなかったことです。

于 2012-07-10T20:02:50.030 に答える