Как интегрировать карту Yahoo в веб-сайте ASP.NET
-
27-09-2019 - |
Вопрос
Как отображать статическую карту Yahoo в GridView, если мы пройдем адрес в качестве строки запроса? Также, пожалуйста, скажите, как отображать динамические карты Yahoo. Я искал о карта Yahoo и получила следующие ссылки http://developer.yahoo.com/flash/maps/examples.html., http://developer.yahoo.com/maps/rest/v1/ и http://developer.yahoo.com/maps/. Отказ Я не получил никакой ссылки, которая имеет код для интеграции карты Yahoo в веб-сайте ASP.NET!
Решение
Я создал динамическую карту Yahoo, адрес может быть передан в виде значения скрытого поля, присутствующего на странице. Значение для скрытого поля может быть динамически передано в событии Page_Load. Я создал это на дочерней странице, инкапсулированной главной страницей в ASP.NET.
Перед началом пользователь должен генерировать идентификатор приложения для использования карты Yahoo, войдя в свой идентификатор Yahoo и навигации по этой ссылке https://login.yahoo.com/config/login_verify2?.src=devnet&.done=http://developer.apps.yahoo.com/wsregapp/ и предоставление нашего сайта URL.
Код для отображения карты Yahoo приведен ниже:
.map {высота: 400px; Ширина: 700 пикселей; Семья шрифта: Вердана; Размер шрифта: 11px; Вес шрифта: смелый; }
<script type="text/javascript" src="http://api.maps.yahoo.com/ajaxymap?v=3.8&appid=YourAPPID">
</script>
<script type="text/javascript">
// Capture the user mouse-click and expand the SmartWindow
function onSmartWinEvent() {
// Create a map object
var map = new YMap(document.getElementById('<%= map.ClientID %>'));
// Add a pan control
map.addPanControl();
// Add a slider zoom control
map.addZoomLong();
// Display the map centered on the address specified
map.drawZoomAndCenter(document.getElementById('<%= HiddenField1.ClientID %>').value, 3);
// Create a marker positioned at the address specified
var marker = new YMarker(document.getElementById('<%= HiddenField1.ClientID %>').value, createCustomMarkerImage());
// Add a label to the marker
//marker.addLabel("<blink>*</blink>");
// Call onSmartWinEvent when the user clicks on the marker
YEvent.Capture(marker, EventsList.MouseClick, onSmartWinEvent);
// Display the marker
map.addOverlay(marker);
var words = document.getElementById('<%= HiddenField1.ClientID %>').value;
marker.openSmartWindow(words);
// Add map type control
map.addTypeControl();
// Default map to satellite (YAHOO_MAP_REG) -- other opts: YAHOO_MAP_HYB,YAHOO_MAP_SAT
map.setMapType(YAHOO_MAP_REG);
}
function createCustomMarkerImage() {
var myImage = new YImage();
myImage.src = 'http://l.yimg.com/www.flickr.com/images/dot_splat.png';
myImage.size = new YSize(30, 31);
myImage.offsetSmartWindow = new YCoordPoint(15, 15);
return myImage;
}
</script>
<table width="100%" align="left">
<tr>
<td>
<body onload="onSmartWinEvent()">
<div id="map" class="map" runat="server">
</div>
<asp:HiddenField ID="HiddenField1" runat="server" />
</body>
</td>
</tr>
</table>
Примечание: ограничение скорости: Yahoo! AJAX MAPS API ограничен 50 000 запросов на IP в день. Проверьте эту ссылкуhttp://developer.yahoo.com/search/rate.html.