Получение значений переменных App Inventor 2 в файле HTML/Javascript

Я настраиваю простую картографическую программу, чтобы пользователь мог видеть местоположения на встроенной карте Google. У меня работает карта, но мне было интересно, есть ли способ для пользователя вводить координаты в 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>

person Josh Young    schedule 27.03.2015    source источник


Ответы (1)


Да, это возможно.

Вы можете использовать WebViewString для обмена значениями между вашим приложением и WebViewer. В своем приложении вы получаете и устанавливаете свойства WebViewer.WebViewString. В вашем webviewer вы открываете страницу с Javascript, который ссылается на объект window.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>
person Taifun    schedule 27.03.2015
comment
Спасибо. Я действительно смотрел на вашу страницу о том, как реализовать карту. - person Josh Young; 30.03.2015