Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/redis/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
谷歌地图API3,javascript_Javascript_Google Maps_Google Maps Api 3 - Fatal编程技术网

谷歌地图API3,javascript

谷歌地图API3,javascript,javascript,google-maps,google-maps-api-3,Javascript,Google Maps,Google Maps Api 3,为从下面编写的代码中输入的地址添加标记的最简单方法是什么。代码读取地址并将数据库中最近的三个存储返回到地图上。但是它没有显示用户输入的地址,我希望它有不同的颜色 我很抱歉它是如何从剪贴板上粘贴的 <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="content-type" content="text/html; charset=utf-8" /&

为从下面编写的代码中输入的地址添加标记的最简单方法是什么。代码读取地址并将数据库中最近的三个存储返回到地图上。但是它没有显示用户输入的地址,我希望它有不同的颜色

我很抱歉它是如何从剪贴板上粘贴的

    <html xmlns="http://www.w3.org/1999/xhtml">

    <head>
        <meta http-equiv="content-type" content="text/html; charset=utf-8" />
        <meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
        <title>Google Maps AJAX + mySQL/PHP Example</title>
        <script src="http://maps.google.com/maps/api/js?sensor=false"
        type="text/javascript"></script>
        <script type="text/javascript">
        //<![CDATA[
        var map;
        var markers = [];
        var infoWindow;
        var locationSelect;
        var geocoder = null;

        function load() {
            map = new google.maps.Map(document.getElementById("map"), {
                center: new google.maps.LatLng(40, -100),
                zoom: 4,
                mapTypeId: 'roadmap',
                mapTypeControlOptions: {
                    style: google.maps.MapTypeControlStyle.DROPDOWN_MENU
                }
            });
            infoWindow = new google.maps.InfoWindow();
            locationSelect = document.getElementById("locationSelect");
            locationSelect.onchange = function () {
                var markerNum = locationSelect.options[locationSelect.selectedIndex].value;
                if (markerNum != "none") {
                    google.maps.event.trigger(markers[markerNum], 'click');
                }
            };
        }

        function showAddress(addressInput) {
            if (geocoder) {
                geocoder.getLatLng(
                addressInput, function (point) {
                    if (!point) {
                        alert(addressInput + " not found");
                    } else {
                        map.setCenter(point, 15);
                        var marker1 = new GMarker(point, {
                            draggable: true
                        });
                        map.addOverlay(marker1);
                        GEvent.addListener(marker1, "dragend", function () {
                            marker1.openInfoWindowHtml(marker1.getLatLng().toUrlValue(6));
                        });
                        GEvent.addListener(marker1, "click", function () {
                            marker1.openInfoWindowHtml(marker1.getLatLng().toUrlValue(6));
                        });
                        GEvent.trigger(marker1, "click");
                    }
                });
            }
        }

        function searchLocations() {
            var address = document.getElementById("addressInput").value;
            var geocoder = new google.maps.Geocoder();
            geocoder.geocode({
                address: address
            }, function (results, status) {
                if (status == google.maps.GeocoderStatus.OK) {
                    searchLocationsNear(results[0].geometry.location);
                } else {
                    alert(address + ' not found');
                }
            });
        }

        function clearLocations() {
            infoWindow.close();
            for (var i = 0; i < markers.length; i++) {
                markers[i].setMap(null);
            }
            markers.length = 0;
            locationSelect.innerHTML = "";
            var option = document.createElement("option");
            option.value = "none";
            option.innerHTML = "See all results:";
            locationSelect.appendChild(option);
        }

        function searchLocationsNear(center) {
            clearLocations();
            var radius = document.getElementById('radiusSelect').value;
            var searchUrl = 'phpsqlsearch_genxml.php?lat=' + center.lat() + '&lng=' + center.lng() + '&radius=' + radius;
            downloadUrl(searchUrl, function (data) {
                var xml = parseXml(data);
                var markerNodes = xml.documentElement.getElementsByTagName("marker");
                var bounds = new google.maps.LatLngBounds();
                for (var i = 0; i < markerNodes.length; i++) {
                    var name = markerNodes[i].getAttribute("name");
                    var address = markerNodes[i].getAttribute("address");
                    var distance = parseFloat(markerNodes[i].getAttribute("distance"));
                    var latlng = new google.maps.LatLng(
                    parseFloat(markerNodes[i].getAttribute("lat")), parseFloat(markerNodes[i].getAttribute("lng")));
                    createOption(name, distance, i);
                    createMarker(latlng, name, address);
                    bounds.extend(latlng);
                }
                map.fitBounds(bounds);
                locationSelect.style.visibility = "visible";
                locationSelect.onchange = function () {
                    var markerNum = locationSelect.options[locationSelect.selectedIndex].value;
                    google.maps.event.trigger(markers[markerNum], 'click');
                };
            });
        }

        function createMarker(latlng, name, address) {
            var html = "<b>" + name + "</b> <br/>" + address;
            var marker = new google.maps.Marker({
                map: map,
                position: latlng
            });
            google.maps.event.addListener(marker, 'click', function () {
                infoWindow.setContent(html);
                infoWindow.open(map, marker);
            });
            markers.push(marker);
        }

        function createOption(name, distance, num) {
            var option = document.createElement("option");
            option.value = num;
            option.innerHTML = name + "(" + distance.toFixed(1) + ")";
            locationSelect.appendChild(option);
        }

        function downloadUrl(url, callback) {
            var request = window.ActiveXObject ? new ActiveXObject('Microsoft.XMLHTTP') : new XMLHttpRequest;
            request.onreadystatechange = function () {
                if (request.readyState == 4) {
                    request.onreadystatechange = doNothing;
                    callback(request.responseText, request.status);
                }
            };
            request.open('GET', url, true);
            request.send(null);
        }

        function parseXml(str) {
            if (window.ActiveXObject) {
                var doc = new ActiveXObject('Microsoft.XMLDOM');
                doc.loadXML(str);
                return doc;
            } else if (window.DOMParser) {
                return (new DOMParser).parseFromString(str, 'text/xml');
            }
        }

        function doNothing() {}
        //]]>
        </script>
    </head>

    <body style="margin:0px; padding:0px;" onload="load()">
        <div>Adress:
            <input type="text" id="addressInput" size="10" />Product:
            <input type="text" id="ProductInput" size="10" />
            <select id="radiusSelect">
                <option value="3" selected>3mi</option>
                <option value="5">5mi</option>
                <option value="10">10mi</option>
                <option value="25">25mi</option>
            </select>
            <input type="button" onclick="searchLocations(); showAddress(this.address.value); "
            value="Search" />
            <br>
            <input type="checkbox" name="currentLocation" value="currentLocation"
            />Use Current Location</div>
        <div>
            <select id="locationSelect" style="width:500;visibility:hidden"></select>
        </div>
        <div id="map" style="width: 500; height: 500"></div>
    </body>

</html>

googlemapsajax+mySQL/PHP示例
//
地址:
产品:
3mi
5mi
10mi
25英里

使用当前位置
使用谷歌将地址字符串转换为(纬度、经度)坐标。将坐标作为标记添加到地图上。如果需要不同颜色/样式的标记,请使用自定义标记图像。我以前做过,您需要的所有信息都应该在phpsqlsearch_genxml.php文件中 为位置ie创建标记

$node = $dom->createElement("marker");
$newnode = $parnode->appendChild($node);
$newnode->setAttribute("name", "Location");
$newnode->setAttribute("address", "Location");
$newnode->setAttribute("lat", $center_lat);
$newnode->setAttribute("lng", $center_lng);
$newnode->setAttribute("distance", 0);
然后遍历这些行,为每个行添加XML节点

在你的函数中,创建一个类似

if(address=="Location"){
  var marker = ??,
  }
  else{
  var marker = !!?,
  }

哪里??和你选择的标记是不是很糟糕,空行有什么用?什么都没有,它是那样复制和粘贴的。。。