C#操作百度地图

  后面要做一个和地图相关的应用,先做一些准备,今天申请了百度开发认证,得到一个地图的AK,可以应用百度地图了。

  显示地图比较容易,直接得到AK时,可以设置后得到百度地图的HTML,在Winform中嵌入就行了。


<!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>
    <!--引用百度地图API-->
    <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=百度的AK"></script>
    <style type=text/css>
	* {margin:0px;padding:0px;}
    </style>

  </head>
  
  <body>
    <!--百度地图容器-->
    <div style="width:1120px;height:433px;border:#ccc solid 1px;font-size:12px" id="map"></div>

	<!--设置两个DIV用于存放经纬度值与Winform窗口交互-->
	<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);
    }

    var map;
    initMap();

    <!--Start以下函数定义来自百度官网http://lbsyun.baidu.com/jsdemo.htm#b0_3-->
	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);
	}

	// 百度地图API功能:获取经纬度坐标
//	var map = new BMap.Map("allmap");            
//	map.centerAndZoom("重庆",12);           
	//单击获取点击的经纬度
	map.addEventListener("click",function(e){
//		alert(e.point.lng + "," + e.point.lat);
		document.getElementById("lng").innerText=e.point.lng;
		document.getElementById("lat").innerText=e.point.lat;
		window.external.WinFormGetCurrentLngAndLat();
	});

    <!--End-->

    <!--Start添加的函数-->
	<!--添加鼠标移动事件及处理函数-->
	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();
		
		}
	});

    <!--End-->

  </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与浏览器就可以交互了,就可以做进一步的应用了。

  • 1
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 10
    评论
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值