Я пытаюсь взаимодействовать с картой Google с помощью Python.Я построил приложение в PyQT с QWebView.QWebView загружает локальную HTML-страницу, как показано здесь:
browser = QwebView()
browser.load(QUrl("file:///c:/main.html"))
frame = browser.page().currentFrame()
frame.evaluateJavaScript(QString("addMarker(-33.89, 151.275)"))
HTML-страница выглядит следующим образом:
<!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
<style type="text/css">
html { height: 100% }
body { height: 100%; margin: 0px; padding: 0px }
#map_canvas { height: 100% }
</style>
<script type="text/javascript"
src="http://maps.google.com/maps/api/js?sensor=false">
</script>
<script type="text/javascript">
var map;
function initialize() {
var latlng = new google.maps.LatLng(-34.397, 150.644);
var myOptions = {
zoom: 8,
center: latlng,
mapTypeId: google.maps.MapTypeId.ROADMAP
};
map = new google.maps.Map(document.getElementById("map_canvas"),
myOptions);
}
function addMarker(lat, lng) {
var myLatLng = new google.maps.LatLng(lat, lng);
var beachMarker = new google.maps.Marker({position: myLatLng,
map: map
});
}
</script>
</head>
<body onload="initialize();">
<div id="map_canvas" style="width:100%; height:100%"></div>
</body>
</html>
Как я могу вызвать addMarker
из Python?
Я попытался вызвать addMarker из HTML (добавил вызов к вызову onload
) и попытался использовать простое выражение javascript из python (frame.evaluateJavaScript("alert(5)")
).Оба из них работали, так что я знаю, что addMarker
и evaluateJavaScript
могут работать, я просто не знаю как.
Я также пытался вызвать evaluateJavaScript("addMarker(-33.89,151.275)")
для объекта frame.documentElement()
, но это тоже не сработало.