C# sogou地图API应用总结(二)
在地图上添加自己想要的功能模块
具体代码如下
var map;
window.onload = function () {
var myOptions = {
mapControl: false, //关闭默认的控件
mapTypeId: sogou.maps.MapTypeId.ROADMAP
}
map = new sogou.maps.Map(document.getElementById("map_canvas"), myOptions); //初始化地图 var homeControlDiv = document.createElement('DIV'); //创建
homeControlDiv.style.position = "absolute";
homeControlDiv.style.left = "20px";
homeControlDiv.style.top = "5px"; var homeControl = new HomeControl(homeControlDiv, map); //获取控件
map.getContainer().appendChild(homeControlDiv); //将控件添加到地图上 }
function HomeControl(controlDiv, map) { controlDiv.style.padding = '5px'; //测距功能
var goHomeText = document.createElement('DIV');
goHomeText.style.fontFamily = 'Arial,sans-serif';
goHomeText.style.backgroundColor = 'white';
goHomeText.style.cursor = 'pointer';
goHomeText.style.borderStyle = 'solid';
goHomeText.style.borderWidth = '1px';
goHomeText.style.borderColor = 'black';
goHomeText.style.fontSize = '12px';
goHomeText.style.textAlign = 'center';
goHomeText.style.float = 'left';
goHomeText.style.width = "60px";
goHomeText.innerHTML = '<b>测距</b>';
controlDiv.appendChild(goHomeText); //获取坐标
var SetZbText = document.createElement('DIV');
SetZbText.style.fontFamily = 'Arial,sans-serif';
SetZbText.style.backgroundColor = 'white';
SetZbText.style.cursor = 'pointer';
SetZbText.style.borderStyle = 'solid';
SetZbText.style.borderWidth = '1px';
SetZbText.style.borderColor = 'black';
SetZbText.style.fontSize = '12px';
SetZbText.style.textAlign = 'center';
SetZbText.style.float = 'left';
SetZbText.style.width = "60px";
SetZbText.innerHTML = '<b>获取坐标</b>';
controlDiv.appendChild(SetZbText); //清空多余描点
var setHomeText = document.createElement('DIV');
setHomeText.style.fontFamily = 'Arial,sans-serif';
setHomeText.style.backgroundColor = 'white';
setHomeText.style.cursor = 'pointer';
setHomeText.style.borderStyle = 'solid';
setHomeText.style.borderWidth = '1px';
setHomeText.style.borderColor = 'black';
setHomeText.style.fontSize = '12px';
setHomeText.style.textAlign = 'center';
setHomeText.style.float = 'left';
setHomeText.style.width = "60px";
setHomeText.innerHTML = '<b>清空</b>';
controlDiv.appendChild(setHomeText); }
代码效果为
动态为地图添加描点(可后台管理)
var map;
var MapZBs,Listener;
var num;
//获取类的唯一示例
function getInstance(a) {
a.hasOwnProperty("_instance") || (a._instance = new a);
return a._instance
}
window.onload = function () {
var myOptions = {
mapControl: false, //关闭默认的控件
mapTypeId: sogou.maps.MapTypeId.ROADMAP
}
map = new sogou.maps.Map(document.getElementById("map_canvas"), myOptions); //初始化地图 Marks(); //动态添加描点
}
//动态添加描点
function Marks() {
//ajax动态调取后台数据
var marks;
$.ajax({
type: "post",
contentType: "application/json",
url: "Index.aspx/GetMarks",
success: function (data) {
FxData(data.d);
}
})
}
//描点内容分析
function FxData(Data) {
var array = Data.split('|');
var HtmlCon = "";
for (var j = ; j < array.length; j++) {
if (array[j].toString() != "") {
var Yarr = array[j].split('&');
var TypeImages;
switch (Yarr[].toString()) {
case "": TypeImages = "images/b1.png"; break;
case "": TypeImages = "images/o1.png"; break;
case "": TypeImages = "images/r1.png"; break;
case "": TypeImages = "images/z1.png"; break;
}
HtmlCon += '<li id="mark' + (j + ) + '" class=""><h3 class="dining" style="background: url(' + TypeImages + ') no-repeat;background-size: 30px 30px;">' + Yarr[] + '</h3><div class="priceinfo2">' + Yarr[] + '</div></li>';
}
}
document.getElementById('tmd_data').innerHTML = HtmlCon; for (var i = ; i < array.length; i++) {
if (array[i].toString() != "") {
var Yarr = array[i].split('&');
AddMark(Yarr[], Yarr[], Yarr[], Yarr[], Yarr[], Yarr[], i, i);
}
}
}
//生成描点和弹出层
function AddMark(location, location1,Con,Title,ImgType,Images,mark,num) {
var location = new sogou.maps.Point(location, location1); //描点位置
//var location = new sogou.maps.LatLng(location, location1);
var TypeImages = "";
switch (ImgType) {
case "": TypeImages = "images/b1.png"; break;
case "": TypeImages = "images/o1.png"; break;
case "": TypeImages = "images/r1.png"; break;
case "": TypeImages = "images/z1.png"; break;
} mark = new sogou.maps.Marker({
position: location,
title: Title,
map: map,
icon: TypeImages,
isFixed:true//不允许被清除
}); var contentString = '<div class="Tan"><div class="wpic"><img src="data:images/' + Images+
'" /></div>' +
'<p>' + Con + '</p>' +
'</div>';
//创建窗体
var infowindow = new sogou.maps.InfoWindow({
content: contentString
});
var container = document.createElement('div'); //创建div
container.innerHTML = contentString; var tpn = new sogou.maps.ToolPanel();
tpn.setPanel(container);
sogou.maps.event.addDomListener(mark, 'click', function () {
infowindow.open(map, mark);
tpn.setPoint(this.getPosition());//搜索功能
tpn.setCallback(function (a) { infowindow.setContent(a, ) })
});
}
ajax后台代码为
[WebMethod]
public static string GetMarks()
{
string str = "";
DataTable dt = GetData();
foreach (DataRow rows in dt.Rows)
{
str += rows["PointX"].ToString() + "&" + rows["PointY"].ToString() + "&" + rows["Company"].ToString() + "&" + rows["Explain"].ToString();
str += "&" + rows["MarkType"].ToString() + "&" + rows["ComImage"].ToString() + "|";
}
return str;
} private static DataTable GetData()
{
DataTable dt = new DataTable();
string sql = "select * from MapMark";
SqlConnection cnn = new SqlConnection(SqlCon);
using (SqlCommand cmm = new SqlCommand(sql, cnn))
{
using (SqlDataAdapter dapter = new SqlDataAdapter(cmm))
{
dapter.Fill(dt);
}
}
return dt;
}
代码效果为:
C# sogou地图API应用总结(二)的更多相关文章
- C# sogou地图API应用总结
地图的初始化1.添加引用地图的API文件: <script src="http://api.go2map.com/maps/js/api_v2.5.1.js" type=&q ...
- 【高德地图API】从零开始学高德JS API(二)地图控件与插件——测距、圆形编辑器、鼠标工具、地图类型切换、鹰眼鱼骨
原文:[高德地图API]从零开始学高德JS API(二)地图控件与插件——测距.圆形编辑器.鼠标工具.地图类型切换.鹰眼鱼骨 摘要:无论是控件还是插件,都是在一级API接口的基础上,进行二次开发,封装 ...
- 【百度地图API】建立全国银行位置查询系统(二)——怎样为地图添加控件
原文:[百度地图API]建立全国银行位置查询系统(二)--怎样为地图添加控件 <摘要>你将在第二章中学会以下知识: 使用手写代码的利器——notepad++: 如何为地图添加控件——鱼骨. ...
- 百度地图开发者API学习笔记二
一,地图上多个覆盖物(Marker). 当有多个覆盖物时,我们需要获取每个点的信息.如下图,每个Marker的经度都不相同 二,代码: <!DOCTYPE html> <html&g ...
- 百度地图API二:根据标注点坐标范围计算显示缩放级别zoom自适应显示地图
原文:百度地图API二:根据标注点坐标范围计算显示缩放级别zoom自适应显示地图 版权声明:本文为博主原创文章,转载请注明出处. https://blog.csdn.net/liusaint1992/ ...
- Java web与web gis学习笔记(二)——百度地图API调用
系列链接: Java web与web gis学习笔记(一)--Tomcat环境搭建 Java web与web gis学习笔记(二)--百度地图API调用 JavaWeb和WebGIS学习笔记(三)-- ...
- 【地图功能开发系列:二】根据地址名称通过百度地图API查询出坐标
根据地址名称通过百度地图API查询出坐标 百度地图ApiUrl string url = "http://api.map.baidu.com/geocoder?address={0}& ...
- [转] 一个程序猿眼中的国内主流地图api
在网站或者手机应用中,经常用到地图api.在现在这么激烈的竞争下,各地图服务提供的服务基本都趋于一致了.一个公司推出的新服务,其他公司肯定也会很快的跟进.这样,对于开发者来说,地图api的选择就主要参 ...
- 【高德地图API】如何解决坐标转换,坐标偏移?
http://bbs.amap.com/thread-18617-1-1.html#rd?sukey=cbbc36a2500a2e6c2b0b19115118ace519002ff3a52731f13 ...
随机推荐
- 【Android 界面效果13】关于全屏和取消标题栏
------- 源自梦想.永远是你IT事业的好友.只是勇敢地说出我学到! ---------- 去掉标题栏: 第一种:也一般入门的时候经常使用的一种方法 requestWindowFeature(Wi ...
- Oracle基础 物理备份 冷备份和热备份(转)
一.冷备份介绍: 冷备份数据库是将数据库关闭之后备份所有的关键性文件包括数据文件.控制文件.联机REDO LOG文件,将其拷贝到另外的位置.此外冷备份也可以包含对参数文件和口令文件的备份,但是这 ...
- Windows8不联网直接安装.Net 3.5 Framework的方法
把你的系统ISO加载到虚拟光驱或插入系统安装盘,找到X:\sources\sxs路径(X是你的光驱盘符).输入下面命令,盘符以D盘为例DISM /Online /Enable-Feature /Fea ...
- XML DTD验证
XML DTD验证 一.什么是DTD 文档类型定义(DTD:Document Type Definition)可定义合法的XML文档构建模块.它使用一系列合法的元素来定义文档的结构. DTD 可被成行 ...
- 文本替换sed+字段处理cut,join+awk重新编排字段
[1]sed工具(Stream Editor)--流编辑器 sed 本身也是一个管线(管道)命令,可以分析 standard input 的啦! 而且 sed 还可以将数据进行取代.删除.新增.截取特 ...
- Divisibility by Eight (数学)
Divisibility by Eight time limit per test 2 seconds memory limit per test 256 megabytes input standa ...
- LeetCode 337
House Robber III The thief has found himself a new place for his thievery again. There is only one e ...
- freeCodeCamp:Convert HTML Entities
将字符串中的字符 &.<.>." (双引号), 以及 '(单引号)转换为它们对应的 HTML 实体. 现在这个表里找出要转化的符号https://dev.w3.org/h ...
- Android里viewpager切换页面存在页面不相邻的页面被销毁的问题
我之前一直因为viewpager+fragment时,所有页面的状态都会被自动保存 这次自己做了一个添加了5跟fragment的viewpager 测试时发现当从第一个切换到第四个页面时,再回到第一个 ...
- 【Linux C中文函数手册】之 目录操作函数
目录操作函数 1)closedir 关闭目录 相关函数: opendir表头文件: #include<sys/types.h> #include<dirent.h>定义函数: ...