4

私はPythonでQtアプリを構築しています。ここでは、(Google)マップをポイントしてクリックして、場所の座標を取得できます。単純な HTML ページを読み込むとマップが表示されQWebView、ユーザーはクリックしてマーカーを作成できます。地図をクリックした後のウィジェットのスクリーンショット。

ただし、クリックしたばかりの位置座標を Qt に戻すのに問題があります (変数として使用できるようにするためです。たとえば、QLineEdit左上隅の s に、マーカー)。

これは、HTML ファイルの関連部分です。

<script type="text/javascript">
var map;
function initialize() { 
    var local = new google.maps.LatLng(-23.4,-40.3);
    var myOptions = {
        zoom: 5,
        center: local,
        mapTypeId: google.maps.MapTypeId.ROADMAP
    } 
    map = new google.maps.Map(document.getElementById("map_canvas"), myOptions);

    google.maps.event.addListener(map, 'rightclick', function(event) {
        placeMarker(event.latLng);
    });
}

function placeMarker(location) {
    var clickedLocation = new google.maps.LatLng(location);
    var marker = new google.maps.Marker({
        position: location,
        map: map
    });

    map.setCenter(location);
}

function dummyTxt() {
    return 'This works.';
}
</script>

で試してみましたがevaluateJavaScript、座標を取得できませんでした。で位置にアクセスする関数を作成しようとしましたmarker.getPosition()が、うまくいきませんでした。以下のダミーは動作しますが..

newplace = QWebView.page().mainFrame().evaluateJavaScript(QString('dummyTxt()'))

>>> print newplace.toString()
This works.

座標を Qt に戻す方法について何か提案はありますか?

編集:

これが私のために働いたコードです:

def update_geo(self):
    # Capture coordinates of the last marker on the map.
    mark = self.map.page().mainFrame().evaluateJavaScript('document.getElementById("markerlocation").value').toString()
    # Convert string to list of floats, stripping parentheses.
    marker = str(mark).strip('()').split(', ')
    decimals = [float(c) for c in marker]

https://github.com/nelas/veliger/blob/master/veliger.py#L2374の完全なソース

4

1 に答える 1

1

それを機能させるための回避策を見つけましたが、それが正しいアプローチになるかどうかはわかりません。とにかく、これは私がやったことです:

  1. html ドキュメントの body セクションに非表示の入力を作成して、マーカーの位置データを保存します。

    <body>
        (...)
        <input id="locationData" type="hidden">
        (...)
    </body>
    
  2. JavaScript コードでは、作成されるたびに非表示の入力にマーカーの位置を保存します。

    function placeMarker(location) {
        (...)
        document.getElementById("locationData").value = marker.position;
        (...)
    }
    
  3. Qt コードで、次の命令を使用して隠し入力の値を読み取ります。

    webView->page()->mainFrame()->findFirstElement("#locationData").evaluateJavaScript("this.value").toString();
    

それが役立つことを願っています!

ソース: http://opendocs.net/qt/4.6/webkit-formextractor.html

于 2010-05-22T09:27:32.060 に答える