javascript - خرائط Google و JavaFX: عرض علامة على الخريطة بعد النقر فوق زر JavaFX




google-maps javafx-webengine (2)

كنت أحاول عرض علامة على الخريطة عندما أقوم بالنقر فوق زر تطبيق JavaFX الخاص بي. إذاً ما يحدث عندما أنقر على هذا الزر ، أكتب الموضع في ملف JSON ، سيتم تحميل هذا الملف في ملف html الذي يحتوي على الخريطة. المشكلة هي أنه يعمل بشكل مثالي عندما أقوم بفتح صفحة html في المستعرض ، لكن لا شيء يحدث في عرض الويب الخاص بـ JavaFX ، ولا أعرف لماذا!

هذا هو ملف html:

<!DOCTYPE html>
<html>
  <head>
  <title>Simple Map</title>
  <meta name="viewport" content="initial-scale=1.0">
  <meta charset="utf-8">
  <style>
  /* Always set the map height explicitly to define the size of the div
   * element that contains the map. */
  /*#map {
    height: 100%;
  }*/
  #map{width:100%;height:100%;margin:auto;}
  /* Optional: Makes the sample page fill the window. */
  html, body {
    height: 100%;
    margin: 0;
    padding: 0;
  }
</style>
</head>
<body>
<div id="map"></div>
<script>
  var map;
  var marker;
  // Multiple Markers
  var markers = [];
  var pos = {lat: 46.662388, lng: 0.3599617};
  var itinerary_markers = [];

  function initMap() {

    var currentLat, currentLng;//Latitude et longtitude courante

    $.ajax({
      url: 'https://maps.googleapis.com/maps/api/geocode/json?address=My+ADDRESS&key=MY_KEY',
      async: false,
      dataType: 'json',
      success: function (data) {
        currentLat = data.results[0].geometry.location.lat;
        currentLng = data.results[0].geometry.location.lng;
      }
    });

    map = new google.maps.Map(document.getElementById('map'), {
      center: {lat: currentLat, lng: currentLng},
      zoom: 15,
      mapTypeId: google.maps.MapTypeId.ROADMAP
    });


    /*MARQUEUR*/ 
    $.ajax({
        async: false,
        url: 'test.json',
        data: "",
        accepts:'application/json',
        dataType: 'json',
        success: function (data) {
            for (var i = 0; i < data.hydrants.length; i++) {
                markers.push( data.hydrants[i]);
            }
        }
    });

      var posi = new google.maps.LatLng(markers[0].Lat, markers[0].Lng);
      marker = new google.maps.Marker({
          position: posi,
          map: map,
          //title: markers[i][0]
          title: markers[0].Name
        });

  }
</script>

<script
    src="https://code.jquery.com/jquery-3.2.1.min.js"
    integrity="sha256-hwg4gsxgFZhOsEEamdOYGBf13FyQuiTwlAQgxVSNgt4="
    crossorigin="anonymous">
</script>


<script src="https://maps.googleapis.com/maps/api/js?key=MY_KEY&callback=initMap&language=fr"
async defer></script>

</body>
</html>

عندما أقوم بالنقر فوق الزر ، أملأ ملف JSON (الذي يعمل بشكل مثالي) ثم أقوم بتنفيذ هذا لتحديث عرض الويب:

this.webView.getEngine().load(getClass().getResource("/data/index.html").toString());

كما قلت من قبل ، عندما أقوم بفتح الملف على المتصفح ، أرى النتيجة المتوقعة ، لكنني لا أعرف ما هي مشكلة JavaFX. إذا كان هناك طريقة أفضل للقيام بذلك من فضلك قل لي.

تصحيح:

لقد وجدت حلاً للمشكلة عن طريق إرسال البيانات مباشرة (إحداثيات GPS) من JavaFX إلى Javascript باستخدام طريقة executeScript () ، لذلك لست بحاجة إلى ملف json كجسر بين النظامين الأساسيين. هذا مثال على كيفية ظهور الكود:

eng.executeScript("updateMarker(" + lat + ", " + lng + ")");//eng is a WebEngine instance

وها هي جافا سكريبت:

/*The initial latitude and longtitude*/
var currentLat = the latitude;
var currentLng = the longtitude;

function initMap() {

    map = new google.maps.Map(document.getElementById('map'), {
      center: {lat: currentLat, lng: currentLng},
      zoom: 15,
      mapTypeId: google.maps.MapTypeId.ROADMAP
    });

    var posi = new google.maps.LatLng(currentLat, currentLng);
    marker = new google.maps.Marker({
        position: posi,
        map: map,
        visible: false
    });
  }

/*The method that is I call from JavaFX*/
function updateMarker(_lat, _lng){
    marker.setPosition({lat: _lat, lng: _lng});
    map.setCenter(new google.maps.LatLng(_lat, _lng));
    marker.setVisible(true);
  }

شكرًا لك على تعليقاتك وإجاباتك ، وعلى تبادل لإطلاق النار خاص.


إذا اضطررت إلى التخمين - يحدث أحد شيئين:

إما أ) لا تدعم javaFX مكالمات ajax عبر الموقع أو B) فهي لا تنتظر استجابة أياكس غير المتزامنة / هناك خطأ آخر.

لذلك دعونا نفعل بعض الاختبارات معا. أولاً ، هل يمكننا تنظيف هذا حتى عش مكالمات أياكس؟ ثم يمكنك إضافة بعض عبارات console.log لمعرفة ما يرسله كل منهم؟ إذا فاتتك بعض المخرجات ، فنحن نعرف إلى أين تسير الأمور بشكل خاطئ وسيساعدنا ذلك في إصلاح الأشياء.

ملاحظة لقد غيرت النجاح إلى الإضافات "التي تم تنفيذها" نظرًا لأن النجاح قديم بعض الشيء ، وكل شيء متداخل لإزالة السؤال حول ما إذا كان يتم إرسال أي فراغات إلى المكالمات التالية (مشكلات التزامن):

$.ajax({
    url: 'https://maps.googleapis.com/maps/api/geocode/json?address=My+ADDRESS&key=MY_KEY',
    async: false,
    dataType: 'json'
}).done(function(data) {
    currentLat = data.results[0].geometry.location.lat;
    currentLng = data.results[0].geometry.location.lng;
    console.log(currentLat);
    console.log(currentLng);
    // Multiple Markers
    var markers = [];
    var pos = {lat: 46.662388, lng: 0.3599617};
    var itinerary_markers = [];
    var map = new google.maps.Map(document.getElementById('map'), {
        center: {lat: currentLat, lng: currentLng},
        zoom: 15,
        mapTypeId: google.maps.MapTypeId.ROADMAP
    });
    console.log(map);
    /*MARQUEUR*/ 
    $.ajax({
        async: false,
        url: 'test.json',
        data: "",
        accepts:'application/json',
        dataType: 'json'
    }).done(function(data) {
        for (var i = 0; i < data.hydrants.length; i++) {
            markers.push( data.hydrants[i]);
        }
        console.log(markers);
        var posi = new google.maps.LatLng(markers[0].Lat, markers[0].Lng);
        console.log(posi);
        var marker = new google.maps.Marker({
            position: posi,
            map: map,
            //title: markers[i][0]
            title: markers[0].Name
        });
        console.log(marker);
    }).fail(function(jqXHR, testStatus){
        console.log(textStatus);
    });
}).fail(function(jqXHR, testStatus){
    console.log(textStatus);
});

فيما يلي رابط حول الحصول على إخراج console.log في System.out في Java إذا كانت هذه مشكلة: JavaFX 8 WebEngine: كيفية الحصول على console.log () من javascript إلى System.out في java؟

... مرحبا أيضا من reddit.


إذا تم استخدام عجلة الماوس لتكبير الخريطة أو التصغير وظهرت العلامة ، فأنت تواجه نفس المشكلة التي واجهتها.

حاول تكبير عرض الخريطة يدويًا لاستعادة العلامات. كان علي أيضًا استخدام هذه التقنية عند عرض طريق من خدمة الاتجاهات ، وإلا فإن علامات نقاط الطريق لم تكن تعرض بشكل صحيح.

هذا هو الكود الموجود في فصل تحكم Javafx الخاص بي للقيام بذلك:

KeyFrame kf1 = new KeyFrame(Duration.seconds(0.75), e -> map.setZoom(map.getZoom() - 1));
KeyFrame kf2 = new KeyFrame(Duration.seconds(1.5), e -> map.setZoom(map.getZoom() + 1));
Timeline timeline = new Timeline(kf1, kf2);
Platform.runLater(timeline::play);

كان هذا يستخدم GMapsFX ، وهو مجرد غلاف جافا رقيق حول مكالمات مشغل جافا سكريبت على JavaFX WebView. نأمل أن يساعد.





javafx-webengine