這裏的博客實在是太很差寫了,這麼用戶不友好的工具居然來源於一個IT的專業網站,難以想象啊。
後面要作一個和地圖相關的應用,先作一些準備,今天申請了百度開發認證,獲得一個地圖的AK,能夠應用百度地圖了。
顯示地圖比較容易,直接獲得AK時,能夠設置後獲得百度地圖的HTML,在Winform中嵌入就好了。javascript
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">;
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta name="keywords" content="百度地圖,百度地圖API,百度地圖自定義工具,百度地圖所見即所得工具" />
<meta name="description" content="百度地圖API自定義地圖,幫助用戶在可視化操做下生成百度地圖" />
<title>百度地圖的學習應用</title>
<script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=百度的AK"></script>;
<style type=text/css>css
{margin:0px;padding:0px;}
</style>html
</head>java
<body>
<div style="width:1120px;height:433px;border:#ccc solid 1px;font-size:12px" id="map"></div>
<div id="lng" style="display:none"></div>
<div id="lat" style="display:none"></div>
</body>
<script type="text/javascript">
//建立和初始化地圖函數:
function initMap(){
createMap();//建立地圖
setMapEvent();//設置地圖事件
addMapControl();//向地圖添加控件
addMapOverlay();//向地圖添加覆蓋物
}
function createMap(){
map = new BMap.Map("map");
map.centerAndZoom(new BMap.Point(87.307622,43.996322),16);
}
function setMapEvent(){
map.enableScrollWheelZoom();
map.enableKeyboard();
map.enableDragging();
map.enableDoubleClickZoom()
}
function addClickHandler(target,window){
target.addEventListener("click",function(){
target.openInfoWindow(window);
});
}
function addMapOverlay(){
var labels = [
{position:{lng:87.306616,lat:43.994921},content:"YQCY Company"}
];
for(var index = 0; index < labels.length; index++){
var opt = { position: new BMap.Point(labels[index].position.lng,labels[index].position.lat )};
var label = new BMap.Label(labels[index].content,opt);
map.addOverlay(label);
};
}
//向地圖添加控件
function addMapControl(){
var scaleControl = new BMap.ScaleControl({anchor:BMAP_ANCHOR_BOTTOM_LEFT});
scaleControl.setUnit(BMAP_UNIT_IMPERIAL);
map.addControl(scaleControl);
var navControl = new BMap.NavigationControl({anchor:BMAP_ANCHOR_TOP_LEFT,type:BMAP_NAVIGATION_CONTROL_LARGE});
map.addControl(navControl);
var overviewControl = new BMap.OverviewMapControl({anchor:BMAP_ANCHOR_BOTTOM_RIGHT,isOpen:true});
map.addControl(overviewControl);
}web
var map;
initMap();api
var mapType1 = new BMap.MapTypeControl(
{
mapTypes: [BMAP_NORMAL_MAP,BMAP_HYBRID_MAP],
anchor: BMAP_ANCHOR_TOP_LEFT
}
);瀏覽器
var overView = new BMap.OverviewMapControl();
var overViewOpen = new BMap.OverviewMapControl({isOpen:true, anchor: BMAP_ANCHOR_BOTTOM_RIGHT});
//添加地圖類型和縮略圖
function add_control(){
map.addControl(mapType1); //2D圖,混合圖
map.addControl(overView); //添加默認縮略地圖控件
map.addControl(overViewOpen); //右下角,打開
}
//移除地圖類型和縮略圖
function delete_control(){
map.removeControl(mapType1); //移除2D圖,混合圖
map.removeControl(overView);
map.removeControl(overViewOpen);
}服務器
map.addEventListener("click",function(e){
document.getElementById("lng").innerText=e.point.lng;
document.getElementById("lat").innerText=e.point.lat;
window.external.WinFormGetCurrentLngAndLat();
});ide
map.addEventListener("mousemove",function(e){
if(e.point.lng!=null){
document.getElementById("lng").innerText=e.point.lng;
document.getElementById("lat").innerText=e.point.lat;
//調用Winform函數
window.external.WinFormGetCurrentLngAndLat();函數
}
});
</script>
</html>
在窗體中放入WebBrowse控件,剩下的問題就是Winform怎樣與這個控件交互了。
我只作了一個簡單的應用,好比獲取實時的經緯度,若是這個解決了,其餘的都應該能夠。
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Security.Permissions;
using System.Runtime.InteropServices.ComTypes;
namespace 百度地圖應用
{
[System.Runtime.InteropServices.ComVisibleAttribute(true)]
public partial class Form1 : Form
{
[PermissionSet(SecurityAction.Demand,Name ="FullTrust")]
public Form1() { InitializeComponent(); } private void Form1_Load(object sender, EventArgs e) { string sURL = "服務器的網址"; Uri url = new Uri(sURL); webBrowser1.Url = url; //屏蔽瀏覽器的右鍵菜單 webBrowser1.IsWebBrowserContextMenuEnabled = false; //禁止彈出腳本錯誤的對話框 webBrowser1.ScriptErrorsSuppressed = true; //爲了與Windows Form交互,設置能夠調用js方法 webBrowser1.ObjectForScripting = this; } public void WinFormGetCurrentLngAndLat() { //獲取當前百度地圖的經緯度座標 string sLng = webBrowser1.Document.GetElementById("lng").InnerText;//經度 string sLat = webBrowser1.Document.GetElementById("lat").InnerText;//緯度 this.toolStripStatusLabel1.Text = "經度:"+sLng+","+"緯度:"+sLat; } private void button5_Click(object sender, EventArgs e) { WinFormGetCurrentLngAndLat(); } }
}
要總結的是,Winform要調用瀏覽器的功能(通常是函數),在網頁寫好函數,Winform直接調用便可。 好比: webBrowser1.Document.InvokeScript("add_control"); 網頁調用Winform的方法(通常是函數),在Winform中寫好,網頁裏直接調用。 好比:window.external.WinFormGetCurrentLngAndLat(); 這樣WinForm與瀏覽器就能夠交互了,就能夠作進一步的應用了。