當(dāng)前位置:首頁(yè) > 物聯(lián)網(wǎng) > 《物聯(lián)網(wǎng)技術(shù)》雜志
[導(dǎo)讀]摘 要:在Winform中,許多時(shí)候都要用到地圖,而現(xiàn)在一般都是用Google地圖。Google地圖的許多服務(wù)是由Javascript 控制的,為了提高操作地圖的效率。文章探討了基于Google Maps API在Winfbrm下的開發(fā),并以WebBrowser控件為橋梁,建立了 Google地圖服務(wù)與窗口程序之間的信息交互,從而實(shí)現(xiàn)了 在Winform窗口中訪問與控制Google地圖之目的。

引言

近年來,地理信息技術(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ī)圖像。

基于Google Maps API的Winform開發(fā)

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ā)

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉