C#中Winform操作百度地圖

這里的博客實在是太不好寫了,這么用戶不友好的工具竟然來源于一個IT的專業網站,不可思議啊。
后面要做一個和地圖相關的應用,先做一些準備,今天申請了百度開發認證,得到一個地圖的AK,可以應用百度地圖了。
顯示地圖比較容易,直接得到AK時,可以設置后得到百度地圖的HTML,在Winform中嵌入就行了。

創新互聯 - 溫江服務器托管,四川服務器租用,成都服務器租用,四川網通托管,綿陽服務器托管,德陽服務器托管,遂寧服務器托管,綿陽服務器托管,四川云主機,成都云主機,西南云主機,溫江服務器托管,西南服務器托管,四川/成都大帶寬,服務器機柜,四川老牌IDC服務商

<!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>

  • {margin:0px;padding:0px;}
    </style>

    </head>

    <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);
    }

    var map;
    initMap();

    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();
    });

    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 = "

}

要總結的是,Winform要調用瀏覽器的功能(一般是函數),在網頁寫好函數,Winform直接調用即可。
比如:?webBrowser1.Document.InvokeScript("add_control");
網頁調用Winform的方法(一般是函數),在Winform中寫好,網頁里直接調用。
比如:window.external.WinFormGetCurrentLngAndLat();
這樣WinForm與瀏覽器就可以交互了,就可以做進一步的應用了。

新聞標題:C#中Winform操作百度地圖
分享地址:http://m.kartarina.com/article24/pihice.html

成都網站建設公司_創新互聯,為您提供品牌網站設計微信公眾號、網站收錄、軟件開發、App開發Google

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

主站蜘蛛池模板: 亚洲日韩乱码中文无码蜜桃臀网站| 亚洲中文字幕在线无码一区二区 | 国产精品无码a∨精品| 成年午夜无码av片在线观看| 一本加勒比hezyo无码专区| 无码任你躁久久久久久老妇App| 亚洲AV无码一区二区大桥未久| 亚洲精品无码久久久久去q| 亚洲一本到无码av中文字幕| 国产AV无码专区亚洲AVJULIA| 韩国精品一区二区三区无码视频| 亚洲AV无码久久| 亚洲午夜无码久久久久| 国产精品无码av片在线观看播| 色综合久久中文字幕无码| 久久精品无码专区免费| 精品久久久无码中文字幕边打电话| 未满小14洗澡无码视频网站| V一区无码内射国产| 日韩乱码人妻无码中文字幕视频| 精品爆乳一区二区三区无码av| 少妇无码一区二区三区免费| 八戒理论片午影院无码爱恋| 成人无码区免费视频观看| 无码国内精品人妻少妇| 无码一区二区三区| 日韩精品人妻系列无码专区免费| 国产AV无码专区亚洲AVJULIA| 亚洲精品无码专区久久久| 中文字幕无码精品三级在线电影| 国产成人无码精品一区在线观看 | 国产在线无码精品电影网| 色欲香天天综合网无码| 久久久国产精品无码一区二区三区| 久久久久久精品无码人妻| 亚洲国产成人无码AV在线| 无码中文字幕一区二区三区| 亚洲AV成人无码网站| 无码av大香线蕉伊人久久| 永久免费无码日韩视频| yy111111少妇无码影院|