基于Google Maps API的Winform開發(fā)
掃描二維碼
隨時(shí)隨地手機(jī)看文章
引言
近年來,地理信息技術(shù)得到了很大的發(fā)展,特別是 Google公司推出的Google Maps得到了廣泛的應(yīng)用,Google 推出了 Google地圖的應(yīng)用程序接口 Google Maps API供用 戶應(yīng)用。與此同時(shí),Winform由于具有簡(jiǎn)單強(qiáng)大、安全、靈 活的控件等特點(diǎn)被大量的開發(fā)者使用,并且,Google地圖運(yùn) 用于Windows窗體應(yīng)用程序成為了當(dāng)今的熱點(diǎn)。本文通過 對(duì)Google Maps在Winform中實(shí)現(xiàn)的研究,重點(diǎn)探討基于 Google Maps API的Winform開發(fā),對(duì)Google地圖解析在 Windows form中進(jìn)行設(shè)計(jì)實(shí)現(xiàn)。
1 Google Maps API 的應(yīng)用
Google向開發(fā)者免費(fèi)發(fā)布全球地圖和衛(wèi)星影像的同時(shí), 開發(fā)了其應(yīng)用程序接口,開發(fā)人員可以根據(jù)自己的需求開發(fā)基 于Google Maps API的地圖服務(wù),將Google Maps嵌入自己 的Winform應(yīng)用。
載入 Google Map API
在HTML頁(yè)面中使用Google Maps API時(shí),頁(yè)面中必 須含有指向Google Maps API的URL,最基本格式為http : 〃maps.google.com/maps/api/js?sensor=false。這說明使用了 Google Maps API 定義的 JavaScript 文件的位置。sensor=false 代表沒有使用傳感器(類似于定位當(dāng)前位置的GPS)。
1.2初始化地圖
要讓地圖在網(wǎng)頁(yè)上顯示,必須為其留出一個(gè)位置。通 常都通過創(chuàng)建名為div的元素并在瀏覽器的文檔對(duì)象模型 (DOM)中獲取此元素的引用來執(zhí)行此操作。而通過div的樣式,可以指定地圖的大小。例如:
<div id="map"style="width : 400px ; height: 400px"></ div>
Google Maps API中通過對(duì)HTML頁(yè)面的<body>元素 添加onload事件來控制地圖的載入與初始化。例如:
創(chuàng)建latlng對(duì)象,用來設(shè)置地圖的中心:
var latlng = new google.maps.LatLng(57.8, 14.0);
創(chuàng)建options對(duì)象,設(shè)置地圖的基本屬性:
var options = {
zoom : 6,
center: latlng,
mapTypeId : google.maps.MapTypeId.ROADMAP }; 調(diào)用函數(shù),初始化地圖:
var map=new google.maps.Map(document.getElement
ById(/map/), options);
以上內(nèi)容需要包含在一個(gè)函數(shù)中:
function initialize()
{
}
最后,再通過body標(biāo)簽的onload事件來初始化地圖對(duì)象:
<body onload="initialize()">
<div id="map">
</div>
</body>。
1.3設(shè)置坐標(biāo)
在Google地圖上設(shè)置坐標(biāo),并確定坐標(biāo)在地圖上的位置,
例如:
var marker = new google.maps.Marker(
{
position : new google.maps.LatLng(56.8848, 14.7730),
map : map
title : 'My workplace',
clickable : false,
icon : 'http : //google-maps-icons.googlecode.com/files/ factory.png'
});
設(shè)置坐標(biāo)后,即可得到如圖1所示的計(jì)算機(jī)圖像。
2 Google地圖服務(wù)與Winform后臺(tái)數(shù)據(jù)交互
Winform的后臺(tái)C#代碼可以實(shí)現(xiàn)與窗口內(nèi)的控件進(jìn)行信 息交互,Google地圖服務(wù)可以實(shí)現(xiàn)基于Google Map API的地 圖顯示,但Google地圖服務(wù)與Web服務(wù)之間的信息不能直接 互通信息,本文以WebBrowser控件為橋梁,實(shí)現(xiàn)Google地 圖服務(wù)與Winform后臺(tái)數(shù)據(jù)互通。
WebBrowser 控件
WebBrowser控件可以在Windows窗體應(yīng)用程序中承載 網(wǎng)頁(yè)以及支持瀏覽器的其他文檔,并且可以在應(yīng)用程序中提供 基于HTML的集成用戶幫助或Web瀏覽功能。此外,還可以 使用WebBrowser控件向Windows窗體客戶端應(yīng)用程序添加 基于Web的現(xiàn)有控件。
利用Uri類,加載指定的HTML頁(yè)面,并初始化 WebBrowser,例如:
Uri url = new Uri(address, UriKind.Absolute);
WebBrowserLUrl = url ;
Google地圖中的Javascript函數(shù)與Winform中C#函數(shù)的 互相調(diào)用
InteropServices. ComVisibleAttribute (true)],使 com 對(duì)象是對(duì) 網(wǎng)頁(yè)里的javascript可見的。
其次,Winfrom后臺(tái)函數(shù)設(shè)置成Public函數(shù):
public string LonString()
{
double[] lon = new double⑵;
lon[0] = 116.407113 ;
lon[1] = 117.202148 ; return String(lon);
}
并在Javascript中通過window.external捕獲調(diào)用C#定 義好的函數(shù):
var lon_string=window. external.LonString();
C#里Javascript函數(shù)的執(zhí)行
定義一個(gè)Javascript函數(shù):
function SetHybridMap()
{
map.setMapTypeld(google.maps.MapTypeld.HYBRID);
}
之后,執(zhí)行Javascript函數(shù):
mshtml.IHTMLDocument2 currentDoc =(mshtml.IHTM LDocument2)webBrow ser1.Doc ument.DomDocument ;
mshtml.IHTMLWindow2 win = (mshtml. IHTMLWindow2)currentDoc.parentWindow ;
win.execScript(" SetHybridMap()", "javascript");
3結(jié)語(yǔ)
Winform憑借著豐富的控件,以及簡(jiǎn)單強(qiáng)大等優(yōu)點(diǎn),在 近些年迅速崛起,充分利用公共語(yǔ)言運(yùn)行庫(kù)的安全特性,一 切都可以在Windows窗體中實(shí)現(xiàn)。而Google地圖服務(wù)能夠?qū)?現(xiàn)不同國(guó)家、不同地區(qū)的地理數(shù)據(jù)標(biāo)識(shí)和地圖顯示功能。本 文將Google地圖實(shí)現(xiàn)在Winform窗體上,可以利用Google 服務(wù)的定位、搜索等服務(wù),為大型客戶端系統(tǒng)提供了思路。
20211118_6195dc7485580__基于 Google Maps API的Winform開發(fā)