C#的百度地图开发(四)前端显示与定位
有了这些定位信息,那要如何在前端的页面上显示出来呢?这需要用到百度地图的JavaScript的API。下面是示例代码。
前端代码
- <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="ViewMap.aspx.cs" Inherits="TEST.ViewMap" %>
- <!DOCTYPE html>
- <html xmlns="http://www.w3.org/1999/xhtml">
- <head id="Head1" runat="server">
- <title>地图</title>
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
- <script src="/js/map.js"></script>
- <script src="/js/jquery.js"></script>
- <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=XXXXXXXXXXXX"></script>
- </head>
- <body>
- <div id="normal_map"></div>
- <input type="hidden" runat="server" id="HiddenCoord" />
- <input type="hidden" runat="server" id="HiddenAddress" />
- </body>
- </html>
- <script type="text/javascript">
- $(document).ready(function () {
- var w = $(window).width();
- var h = $(document).height();
- var coord = $('#<%=HiddenCoord.ClientID%>').val().split(',');
- var lat = coord[0];
- var lng = coord[1];
- var address = $('#<%=HiddenAddress.ClientID%>').val();
- $("#normal_map").css({
- "width": w + "px",
- 'height': h + 'px'
- });
- MapApi.LoadLocationMap(lat, lng, 'normal_map', "<p>" + address + "</p>");
- });
- </script>
注:
(1).script中http://api.map.baidu.com后面的ak是申请的key,与前面文章中所说的key一致。
(2).引用了jquery的库。
(3).如果还引用了jquery.mobile的库,以适应移动端使用的,记得要将div设置相应的高度和宽度,不然可能会显示一片空白。因为jquery.mobile在渲染时会对页面进行适配的处理。
(4).载入地图的部分封装到了map.js中,其代码如下
- var MapApi = (function () {
- return {
- LoadLocationMap: function (lat, lng, containerId, showText) {
- ///<summary>载入地图</summary>
- ///<param name="lat">纬度值</param>
- ///<param name="lng">经度值</param>
- ///<param name="containerId">地图容器ID,一般为Div的Id.</param>
- var map = new BMap.Map(containerId); // 创建Map实例
- var point = new BMap.Point(lng, lat); // 创建点坐标
- var marker = new BMap.Marker(point); // 创建标注
- map.addOverlay(marker); // 将标注添加到地图中
- map.centerAndZoom(point, 15);
- map.enableScrollWheelZoom(); //启用滚轮放大缩小
- var opts = {
- width: 50, // 信息窗口宽度
- height: 30, // 信息窗口高度
- title: showText, // 信息窗口标题
- enableMessage: false,//设置允许信息窗发送短息
- message: showText
- }
- var infoWindow = new BMap.InfoWindow("", opts); // 创建信息窗口对象
- map.openInfoWindow(infoWindow, point); //开启信息窗口
- },
- LoadMap: function (lat, lng, panoramaContainerId, normalMapContainerId) {
- //全景图展示
- var panorama = new BMap.Panorama(panoramaContainerId);
- panorama.setPosition(new BMap.Point(lng, lat)); //根据经纬度坐标展示全景图
- panorama.setPov({ heading: -40, pitch: 6 });
- panorama.addEventListener('position_changed', function (e) { //全景图位置改变后,普通地图中心点也随之改变
- var pos = panorama.getPosition();
- map.setCenter(new BMap.Point(pos.lng, pos.lat));
- marker.setPosition(pos);
- });
- //普通地图展示
- var mapOption = {
- mapType: BMAP_NORMAL_MAP,
- maxZoom: 18,
- drawMargin: 0,
- enableFulltimeSpotClick: true,
- enableHighResolution: true
- }
- var map = new BMap.Map(normalMapContainerId, mapOption);
- var testpoint = new BMap.Point(lng, lat);
- map.centerAndZoom(testpoint, 18);
- var marker = new BMap.Marker(testpoint);
- marker.enableDragging();
- map.addOverlay(marker);
- marker.addEventListener('dragend', function (e) {
- panorama.setPosition(e.point); //拖动marker后,全景图位置也随着改变
- panorama.setPov({ heading: -40, pitch: 6 });
- });
- }
- }
- })();
注:该JS中还封装了全景图的函数。
下面看一下后端代码
- public partial class ViewMap : System.Web.UI.Page
- {
- protected void Page_Load(object sender, EventArgs e)
- {
- if (!IsPostBack)
- {
- InitLoad();
- }
- }
- private void InitLoad()
- {
- Coordinate coordinate = new Coordinate("39.92", "116.46");
- CoordLocationResult coordLocationResult = BaiduMap.FetchLocation(coordinate);
- HiddenAddress.Value = coordLocationResult.result.formatted_address;
- HiddenCoord.Value = String.Format("{0},{1}",
- coordLocationResult.result.location.lat,
- coordLocationResult.result.location.lng);
- }
- }
注:
(1).通过BaiduMap.FetchLocation得到坐标的定位信息。
(2).将得到的地址和坐标赋值到隐藏域中,以便前端使用JS来读取。
测试结果如下图
这样就实现了坐标的前端定位。当然如果有需要,还可以将某段时间内获取的坐标点在地图上画出轨迹来,这个可以参考百度地图的说明。
这是通过坐标来定位的,而坐标的定位一般都是在移动设备上,那如果在PC端呢?这个就需要使用到IP定位
C#的百度地图开发(四)前端显示与定位的更多相关文章
- [android] 百度地图开发 (两).所在地的城市定位和城市POI搜索
一个. 百度地图城市位置和POI搜索知识 上一篇文章"百度地图开发(一)"中讲述了怎样申请百度APIKey及解决显示空白网格的问题.该篇文章主要讲述怎样定位城市位置.定 ...
- Android 百度地图开发(一)--- 申请API Key和在项目中显示百度地图
标签: Android百度地图API Key 分类: Android 百度地图开发(2) 最近自己想研究下地图,本来想研究google Map,但是申请API key比较坑爹,于是从百度地 ...
- Android studio 百度地图开发(3)地图导航
Android studio 百度地图开发(3)地图导航 email:chentravelling@163.com 开发环境:win7 64位,Android Studio,请注意是Android S ...
- Android studio 百度地图开发(2)地图定位
Android studio 百度地图开发(2)地图定位 email:chentravelling@163.com 开发环境:win7 64位,Android Studio,请注意是Android S ...
- Android 百度地图开发之一(Hello BaiDu Map)
之前也接触过百度地图的开发,但那是在网上找的案例或代码,而且是比较老的版本.打算重新学习一下百度地图的开发. 本次使用的百度地图的版本是 Android SDK v3.0.0 本篇文章主要讲述百度地图 ...
- C#的百度地图开发(三)依据坐标获取位置、商圈及周边信息
原文:C#的百度地图开发(三)依据坐标获取位置.商圈及周边信息 我们得到了百度坐标,现在依据这一坐标来获取相应的信息.下面是相应的代码 public class BaiduMap { /// < ...
- C#的百度地图开发(一)发起HTTP请求
原文:C#的百度地图开发(一)发起HTTP请求 百度地图的开发文档中给出了很多的事例,而当用到具体的语言来开发时,又会有些差异.我是使用C#来开发的.在获取相应的数据时,需要通过URL传值,然后获取相 ...
- 【百度地图开发之二】基于Fragment的地图框架的使用
写在前面的话: [百度地图开发之二]基于Fragment的地图框架的使用(博客地址:http://blog.csdn.net/developer_jiangqq),转载请注明. Author:hmji ...
- 调用百度地图开发平台的JavascriptAPI实现将市县位置转换成坐标
最近的项目要做的地图比较多,有的还比较复杂,而地图用到的坐标,上网找json文件更是良莠不齐的.真是让人伤脑筋,后来突然想到了百度地图开发平台,没想到真的有对应的API哦,谢天谢地!!!下面说一下完整 ...
随机推荐
- js 动态切换视频
如图所示,想要一个这样的效果,就是点击下面视频标题时,上面的视频跟着切换,但是要求页面不重新加载. 参考文章在这里 这里贴上部分代码供大家参考. <li id="about_li6&q ...
- mui如何增加自定义字体icon图标
http://ask.dcloud.net.cn/article/128 字体地址:http://www.iconfont.cn/
- 阿里巴巴 web前端性能优化进阶路
Web前端性能优化WPO,相信大多数前端同学都不会陌生,在各自所负责的站点页面中,也都会或多或少的有过一定的技术实践.可以说,这个领域并不缺乏成熟技术理论和技术牛人:例如Yahoo的web站点性能优化 ...
- Swift - 使用socket进行通信(附聊天室样例)
在Swift开发中,如果我们需要保持客服端和服务器的长连接进行双向的数据通信,使用socket是一种很好的解决方案. 下面通过一个聊天室的样例来演示socket通信,这里我们使用了一个封装好的sock ...
- [置顶] ※数据结构※→☆线性表结构(queue)☆============队列 顺序存储结构(queue sequence)(八)
队列是一种特殊的线性表,特殊之处在于它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作,和栈一样,队列是一种操作受限制的线性表.进行插入操作的端称为队尾,进行删除操作的 ...
- Python金融应用编程(数据分析、定价与量化投资)
近年来,金融领域的量化分析越来越受到理论界与实务界的重视,量化分析的技术也取得了较大的进展,成为备受关注的一个热点领域.所谓金融量化,就是将金融分析理论与计算机编程技术相结合,更为有效的利用现代计算技 ...
- 基于visual Studio2013解决面试题之0209最大堆排序
题目
- KDB支持单步调试功能(ARM架构)
0 实践发现KDB不支持step调试功能 (本文针对的是arm CotexA9架构,各种架构的实现方式不一样, X86的好像已经支持,不过本人没有验证过) 1 首先看下要调试的代码段 ...
- 最全的Swift社交应用文本输入优化汇总
在大部分应用中,都有输入的需求,面对众多用户,他们的想法各异,输入的文本内容也是千奇百怪,面对不同的输入,我们该如何优化输入体验?本文将汇总一下Swift社交应用文本输入优化技巧. AD: 一.输入相 ...
- VC/MFC 工具栏上动态添加组合框等控件的方法
引言 工具条作为大多数标准的Windows应用程序的一个重要组成部分,使其成为促进人机界面友好的一个重要工具.通过工具条极大方便了用户对程序的操作,但是在由Microsoft Visual C++开发 ...