在HTML/Javascript文件中获取App Inventor 2变量值

Getting App Inventor 2 variable values in an HTML/Javascript file

本文关键字:App Inventor 变量值 获取 HTML Javascript 文件      更新时间:2023-09-26

我正在为用户设置一个简单的地图程序,以便在嵌入式谷歌地图上查看位置。我有地图在工作,但我想知道是否有一种方法让用户在AI2中输入坐标,然后把地图中心放在那里。这是我用来显示地图的HTML文件。

<!DOCTYPE html>
<html>
   <head>
     <meta charset="utf-8">
     <meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
     <style type="text/css">
     html { height: 100% }
     body { height: 100%; margin: 0; padding: 0 }
     #map_canvas { height: 100% }
     </style>
     <script type="text/javascript" src="https://maps.googleapis.com/maps/api/js?&sensor=true&language=en"></script>
     <script type="text/javascript">
  function initialize() {
    var mapOptions = {
      center: new google.maps.LatLng(-34.397, 150.644),
      zoom: 8,
      mapTypeId: google.maps.MapTypeId.ROADMAP
     };
     map = new google.maps.Map(document.getElementById("map_canvas"), mapOptions);
    // Add a listener for the click event
    google.maps.event.addListener(map, 'click', showPosition);
  }
  function showPosition(event) {
    // display a marker on the map
    marker = new google.maps.Marker({
      position: event.latLng,
      map: map,
      icon: "./marker.png"
    });
    // print the selected position to the page title
    var position = event.latLng.lat().toFixed(6) + ", " + event.latLng.lng().toFixed(6);
    window.document.title = position;
  }
</script>
  </head>
  <body onload="initialize()">
    <div id="map_canvas" style="width:100%; height:100%"></div>
  </body>
</html>

是的,这是可能的。

您可以使用WebViewString在应用程序和WebViewer之间来回传递值。在您的应用程序中,您可以获取并设置WebViewer.WebViewString属性。在webviewer中,打开一个具有引用该窗口的Javascript的页面。AppInventor对象,使用其getWebViewString()setWebViewString(text)方法。

另请参阅以下片段以获取完整的示例。

<!doctype html>
<head>
  <meta name="author" content="puravidaapps.com">
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width, initial-scale=1">
  <title>Test</title>
</head>
<body>
  <script>
    document.write("The value from the app is<br />" + window.AppInventor.getWebViewString());
    window.AppInventor.setWebViewString("hello from Javascript")
  </script>
</body>
</html>