百度3D地图API的调用以及适应过程

简介:

做软件工程大作业的时候需要使用到baidu地图的API。这里将调用百度地图API的过程说明一下。其实大部分是参照百度API的实例说明做了。只做了一些小小的改动。因为个人对javascript非常不熟。只能一边写代码一边上网查找。为了使地图显示效果达到和follow5显示的效果一致,我自己写了一个javascript函数show()。估计这个就是此处的重点吧。

aspx页面

html代码唯一要注意的就是

<div style="width:797px;height:597px;border:1px solid gray;font-size:12px" id="container"></div><!--地图-->

因为这个是地图显示的div。注意的是id必须和下文javascript代码中的id保持一致。
<div style="height:auto; width:1440px;">
            <div style=" background-color:#CCC; height:600px; float:left; margin:10px auto auto 40px; width:800px; border:solid 3px #CCC">
            <div style="width:797px;height:597px;border:1px solid gray;font-size:12px" id="container"></div><!--地图-->
            </div>
            <div style="width:500px; height:550px; float:left; margin:auto auto auto 5px;">
                <div style="height:30px; width:450px; padding-bottom:0px;"></div>
                <div style="width:442px;Z-INDEX:1;height:560px;OVERFLOW:auto;">
                    <table cellpadding="5px" cellspacing="20px" style="font:'微软雅黑'; color:#FFF;">
                    
                        <asp:Literal ID="ltrShow" runat="server"></asp:Literal><!--右框显示数据-->
                   
                    </table>
                </div>
                <div style="height:30px; width:450px; padding-top:0px;"></div>
            </div>
        </div>


JS部分(放在aspx页面底部即可)

当然还需要在aspx页面的head里面加入一段

<script type="text/javascript" src="http://api.map.baidu.com/api?v=1.2"></script>

这个表示将baidu地图提供的api文件包涵进来。不然下面的javascript代码是无法执行的。

var map = new BMap.Map("container", {mapType:BMAP_PERSPECTIVE_MAP});
表示新建一个地图对象。第一个参数为你显示的div的id。第二个参数为地图类型,BMAP_PERSPECTIVE_MAP表示的是3D模式。
var point = new BMap.Point(113.403, 23.070);
设置地图中心坐标。113.403, 23.070 是广州大学城的坐标。可以自己设置。
map.setCurrentCity("广州");  
设置地图显示的城市 此项是3D模式地图必须设置的。
map.centerAndZoom(point,18);
设置中心点级默认的地图缩放大小。缩放范围为1-19.。。越大表示越精细,比例尺越大。
map.enableScrollWheelZoom(true);
设置地图是否可以缩放。这里设置可以缩放
show(i)函数是可以将窗口跳动显示的核心。当然我只是依葫芦画瓢自己写的。setTimeout("函数",时间)表示每隔固定的时间调用函数一次。所以这里会一直每隔5秒就会调用一次show()函数。因为后台数据传送过来的是30条数据,当显示完数据的时候需要重头开始。将i重新设置为0.其实我觉得用i%30更加优化。
<script type="text/javascript">

var map = new BMap.Map("container", {mapType:BMAP_PERSPECTIVE_MAP});
var point = new BMap.Point(113.403, 23.070);
map.setCurrentCity("广州");          // 设置地图显示的城市 此项是必须设置的
map.centerAndZoom(point,18);
map.enableScrollWheelZoom(true);

var opts = {
  width : 300,     // 信息窗口宽度
}

var BASEDATA = <%=jsData %>
                
function show(i){
    var infoWindow = new BMap.InfoWindow(BASEDATA[i].t,opts);  // 创建信息窗口对象
    map.openInfoWindow(infoWindow, new BMap.Point(BASEDATA[i].j,BASEDATA[i].w));      // 打开信息窗口
    i++;
    if(i>=BASEDATA.length)
    i=0;
    timer = setTimeout("show("+i+")", 5000);
}
show(0);
</script>

cs后台代码

因为没有调用数据库,所以将循环显示一段数据。只改变经纬度的位置,数据就不保持变化了。

ltrShow是literal控件。在地图左侧显示所有内容。

jsData是一个全局变量,目的是为了将后台的数据传递给js代码中的BASEDATA变量。

public string jsData = "";
    protected void Page_Load(object sender, EventArgs e)
    {
        ShowData();
    }
    //显示数据
    //显示数据
    void ShowData()
    {
        int count = 30;
            ltrShow.Text = "";
            jsData = "[";//传递给js数据的变量
            for (int i = 0; i < count; i++)
            {
                ltrShow.Text += "<tr>";
                ltrShow.Text += "<td class='style3'><a href='http://weibo.com/rondsny'><img src='http://tp1.sinaimg.cn/1719298984/50/5620017623/1'>";
                ltrShow.Text += "</a><br/><center>Ron_N";
                ltrShow.Text += "</center></td><td class=\"style2\">你的微笑在12月略显单薄/寒冬并未真正到来/午后的阳光温暖而明亮/";
                ltrShow.Text += "</td></tr>";
                string jsContent = "";
                sContent += "<img style='float:right;margin:4px' id='imgDemo' src='http://ww1.sinaimg.cn/bmiddle/667a6ba8gw1dohjaa085zj.jpg' width='139' title=''/>";
                jsContent += "<p style='margin:0;line-height:1.5;font-size:13px;text-indent:2em'>你的微笑在12月略显单薄/寒冬并未真正到来/午后的阳光温暖而明亮/</p>";
                jsContent += "</div>";
                jsData += "{t:\"" + jsContent + "\",j:\"" + 113.403+i/10 + "\",w:\"" + 23.070+i/10 + "\"},";
            }
            jsData += "]";//传递给js数据的变量
        }
    }

以上就是调用和修改的过程。个人涉及的只是一点牛毛而已。主要为了完成作业。

有什么说的不好或者不清楚的地方,欢迎各位指正。


相关文章
|
3月前
|
JSON JavaScript 前端开发
震惊!JS如何悄无声息追踪你的每一步?揭秘页面访问与关闭的超级上报大法,让数据说话,优化体验不再难!
【8月更文挑战第4天】在Web开发中,跟踪用户行为对提升体验与留存至关重要。本文以在线学习平台为例,介绍如何用JavaScript监听页面访问及关闭,并上报数据。通过`window.onload`监测页面加载,记录用户访问;利用`navigator.sendBeacon`在用户离开时发送少量数据至服务器,无需担心请求失败。需注意隐私合规、性能影响及浏览器兼容性。此技术有助于深入理解用户行为,为产品迭代提供依据。
140 8
|
5月前
|
Windows
技术心得:心知天气网页调用源码
技术心得:心知天气网页调用源码
47 0
调用百度文字转语音接口实现自动报时的解决方案
调用百度文字转语音接口实现自动报时的解决方案
104 0
|
移动开发 小程序 JavaScript
微信小程序学习实录5(H5嵌入小程序、map组件、地图调起功能、腾讯百度高德导航页、返回web-view页)
微信小程序学习实录5(H5嵌入小程序、map组件、地图调起功能、腾讯百度高德导航页、返回web-view页)
542 0
|
6月前
|
数据挖掘 API
解锁新视角:小红书笔记详情API的隐藏价值探索
在数字化时代,小红书笔记详情API为我们提供了一个全新的视角,帮助我们深入挖掘隐藏的价值。通过这个强大的工具,我们可以解锁新视角,发现潜在的市场机会和用户需求,从而创造更大的商业价值。
|
机器学习/深度学习 人工智能 文字识别
从地图到手机通讯到ChatGPT,你想要的免费 API 都给你整理好了
在今天的科技世界中,API(Application Programming Interface)已经成为现代应用程序不可或缺的一部分。它们提供了许多强大的功能,让开发人员可以轻松地集成其他应用程序的功能,从而快速构建出色的应用程序。
248 0
从地图到手机通讯到ChatGPT,你想要的免费 API 都给你整理好了
|
人工智能 网络协议
新必应(New Bing)申请出错终极方案
随着ChatGPT的爆火,微软推出了AI驱动的新必应(New Bing),新必应大大提升了Bing的体验和效率,一时间吸引力众多申请和试用。 然而很多想要加入新必应候补名单时,却总是报出错了,请重试。
4333 1
新必应(New Bing)申请出错终极方案
|
存储 小程序 JavaScript
借助云开发实现小程序朋友圈的发布与展示
借助云开发实现小程序朋友圈的发布与展示
119 0
|
Web App开发 编解码 移动开发
探秘移动端网页调用摄像头的两种方式
PC 端网页调用摄像头的场景想必大家并不陌生,打开一个网址,开启摄像头开始笔试/视频聊天/直播等。 而在移动端网页调用摄像头的场景你见得多吗?我想答案应该是不多吧(在下见识浅薄)。
|
数据采集 API Python
Python爬虫之百度API调用
上次爬取了糗事百科的用户地址,也画了一个段子手分布的地图,今天就讲讲思路,其实也就是如何让地址换为经纬度,因为个人BDP免费版是需要经纬度字段的,今天就调用百度API获取经纬度信息。
1479 0
下一篇
无影云桌面