私は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の完全なソース