`
cloudtech
  • 浏览: 4600738 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
文章分类
社区版块
存档分类
最新评论

WebGIS设计与实现原理

 
阅读更多
WebGIS设计与实现原理
褫其华衮,示人本相系列之一
2006-2-18
cheungmine
1 什么是WebGIS
我的定义是:在internet领域内,向WWW服务器请求地图数据或与之相关的操作,从而获得地图并呈现给最终用户的过程。几点共识是:客户端不必安装任何插件(当然必要的浏览器和XML支持是少不了的);服务端动态生成地图(强调这一点,是因为这样的Webgis引擎才符合工业标准。否则只能称为带有地图图片的网站)。符合上述定义的Webgis的优点是显而易见的:
1)地图由服务器动态按需生成,发送给客户端只是最终生成的图片(我的经验是png格式为好),对客户端的要求降到最低。
2)利用服务器的中心控制、监视和审计,保障了数据的安全和实现的一致性。
3)方便部署的特征,使升级和扩展都异常简单。
因此,我希望以后在谈论Webgis的时候,再也不要听到Plugin、ActiveX、Applet之类的字眼。
2 Webgis技术原理
说了一大堆,就要谈到核心实现了。别以为我在这里胡吹海侃,我确实是真的把自己的体会和经验(教训)无偿的奉献给莘莘学子。我的体会是:
1)一种技术,如果太过复杂,就称不上是好技术。比如质能方程E=MC­­*C其简单和优美。所以,我以为宇宙的定律就是简单的规则,当然,多数我们还没发现。
2)一种实现,如果要写一大堆的代码,仍然不是一种好的实现。就比如夸一个人长的美,说一千道一万,不如就2个字:好看。
秉承这个原则,下面介绍我的技术:
1)客户端(IE)采用AJAX,直接调用服务端的Services。
2)服务端编写Web Services,响应客户的请求。
原理就这些,为什么我就不说了,如果你不知道,说明你还需要学啊学啊学。
3 Webgis实现
先说服务端的实现。按上面说的,就是写Web Services(Web服务)。可能目前没有比写Web Services更时髦的了。还有人说Google Web API要代替传统的Win32API。其实这完全是2种计算模式,谁也代替不了谁。许多专家就喜欢炒作,把媒体那一套应用到我们这个技术领域,误导消费者。
其实,若不是浏览器大行其道,Webgis算个啥啊。这社会从来就没公平过,好好的C/S不用,非强迫我们在浏览器里搞啊搞的。没办法,就搞吧,看谁搞得过谁?
Web Services有很多语言可写,什么C#、Java、C++等等等等。需要一套称之为Webgis API的东西。设计这样一套API让AJAX调用。怎么设计呢,我会把我的接口公布出来,供大家参考漫骂。
其实最重要的是服务端的地图生成引擎(引擎就是发动机)。我自己实现了一个(带VVT-i的啊),没有的要自己实现,或者买个现成的(比如MapObjects)。
该说客户端了。AJAX吗,其实就是JavaScript + XMLHttpRequest(微软版本)对象啊。就别用什么Webservices.htc了,虽然是微软写的,还真他妈不好用。我从高人那里抄了一个,改了改,就用上了。看我上篇文章啊,那个是100%的源代码,没错误的啊。
剩下的再说就显得多余了。画个体系结构图吧:
(图象怎么显示不出来??)
WebGIS体系结构图
4 小贴示
看到这里你是不是觉得恶心了,提示就提示干嘛贴示啊。不是有国内北大高人翻译《ATL 技术内幕》非满纸的“控制”。我看了就别扭,国内叫“控件”,这个还比较舒服。翻译的就别提多牵强了。
1)服务端要以多线程(IIS进程)服务请求。
2)地图引擎加载数据,要能够静态和动态2种模式载入。
3)绝对不要想着传矢量的数据,传图片最好,哪怕未来网络带宽提高100倍。
4)写的要绝对健壮,不然把IIS搞瘫了。
5)记得在服务端保持客户状态啊。
5 附录:Webgis WebServices 接口和方法
也许一不小心成了标准呢?其实就是想让读者在做这方面的设计时,有个参考,反面典型也好。我把修改数据方面的API去掉了,太危险了,还是不说出来的好。
// Webgis接口方法说明
// 2006年8月
// ATL Server Webgis Services Created by cheungmine@gmail.com
//////////////////////////////////////////////////////
// 关于MtkWebgisService
//////////////////////////////////////////////////////
// 取得服务相关信息
HRESULT about([out, retval] BSTR *Info);
// 取得服务器日期时间
HRESULT svrtime([out, retval] mtkTime *time);
//////////////////////////////////////////////////////
// 登入与登出, login必须是第1个调用的服务端方法
//////////////////////////////////////////////////////
// 登入系统, 获得用户令牌和全图URL, 以后任何方法调用必须给出令牌
HRESULT login([in] BSTR Username, [in] BSTR Password);
// 登出系统, 注销用户令牌
HRESULT logout();
 
//////////////////////////////////////////////////////
// 基本信息
//////////////////////////////////////////////////////
// 当前MTK Canvas版本
HRESULT version([out, retval] BSTR *Ver);
// 取得全部图层信息, 以XML内联返回
HRESULT mapinfo([out, retval] BSTR *xmlInfo);
// 取得全部图层信息, 返回生成的XML的URL
HRESULT mapxml([out, retval] BSTR *xmlURL);
// 取得图层信息, 以XML内联返回
HRESULT layinfo([in] LONG LayerIndex, [out, retval] BSTR *xmlInfo);
// 取得图形属性信息, 以XML内联返回. 若图层索引为>=MTK_TMPLAYER_INDEX, 则在临时层上
HRESULT shpinfo([in] LONG LayerIndex, [in] LONG fromShapeIndex, [in] LONG fetchCount, [out, retval] BSTR *xmlInfo);
// 取得图形属性信息, 返回生成的XML的URL. 若图层索引为>=MTK_TMPLAYER_INDEX, 则在临时层上
HRESULT shpxml([in] LONG LayerIndex, [in] LONG fromShapeIndex, [in] LONG fetchCount, [out, retval] BSTR *xmlURL);
 
//////////////////////////////////////////////////////
// 地图浏览和点查
//////////////////////////////////////////////////////
// 刷新地图, 取地图imgURL
HRESULT refresh([out] DOUBLE* Scale, [out, retval] BSTR *imgURL);
// 地图控制显示比例
HRESULT scale([out] DOUBLE* minScale, [out] DOUBLE* maxScale);
// 按比例显示地图, 不改变当前地图中心位置
HRESULT zoom([in] DOUBLE Scale);
// 指定视图位置放大或缩小地图, 指定放大缩小的百分比
HRESULT zoomat([in] mtkPoint Pos, [in] SHORT Percent);
// 开窗显示地图, 指定视图上的2点
HRESULT zoomext([in] mtkPoint Pos1, [in] mtkPoint Pos2);
// 开窗显示地图, 指定地图上的2点
HRESULT zoomext2([in] mtkPoint Pt1, [in] mtkPoint Pt2);
// 移动地图, 指定视图上的2点
HRESULT move([in] mtkPoint fromPos, [in] mtkPoint toPos);
// 选中图形对象, 指定视图上的点. 返回对象的sid负值和所在的图层索引和对象信息
HRESULT identify([in] mtkPoint Pos, [out] LONG* _sid, [out] LONG* layId, [out, retval] BSTR* shpInfo);
// 设置图层状态属性, 指定层的索引和状态名称, 状态值
HRESULT setlayer([in] LONG LayerIndex, [in] mtkEnumLayerState State, [in] bool bVal);
// 以指定视图上的点为中心, 定位地图
HRESULT centerat([in] mtkPoint Pos);
// 以指定地图坐标点为中心, 定位地图
HRESULT centerat2([in] mtkPoint Pt);
// 地图翻页, 指定方向Up,Down,Right,Left和页面重叠百分率0%~100%"
HRESULT flip([in] mtkEnumFlip Direction, [in] SHORT Overlap);
// 清除选中的对象
HRESULT clear();
//////////////////////////////////////////////////////
// 地图测量, 视图上的点串
//////////////////////////////////////////////////////
// 地图测量, 返回距离, 面积和地图单位
HRESULT measure([in] mtkPoints PathPoints, [out] DOUBLE* Length, [out] DOUBLE* Area, [out] BSTR* Unit);
// 地图测量, 返回距离, 面积和地图单位
HRESULT measure2([in] BSTR PathString, [out] DOUBLE* Length, [out] DOUBLE* Area, [out] BSTR* Unit);
 
//////////////////////////////////////////////////////
// 坐标变换: 视图(view)与数据(data)之间的正反坐标变换
//////////////////////////////////////////////////////
// 取得地图当前数据坐标范围
HRESULT extent([out] DOUBLE* MinX, [out] DOUBLE* MinY, [out] DOUBLE* MaxX, [out] DOUBLE* MaxY);
// 视图点变换到数据坐标点
HRESULT vp2dp([in] LONG VX, [in] LONG VY, [out] DOUBLE* DX, [out] DOUBLE* DY);
// 数据坐标点变换到视图点
HRESULT dp2vp([in] DOUBLE DX, [in] DOUBLE DY, [out] LONG* VX, [out] LONG* VY);
// 视图点串变换到数据坐标点串
HRESULT vs2ds([in] BSTR VS, [out, retval] BSTR* DS);
// 数据坐标点串变换到视图点串
HRESULT ds2vs([in] BSTR DS, [out, retval] BSTR* VS);
//////////////////////////////////////////////////////
// 空间查询与分析
//////////////////////////////////////////////////////
// 重置过滤器. 清除所有以前设置的过滤器
HRESULT resetFilters();
// 设置过滤器, 可以多次调用此方法以设置多个过滤器, 只要服务端支持多过滤. 返回过滤器总数
HRESULT addFilter([in] mtkFilter Filter, [out, retval] LONG* Count);
// 根据条件查找图形对象, 返回查询到的对象数. 查询结果图层为临时层, 索引为i+MTK_TMPLAYER_INDEX
HRESULT findShapes([in] LONG LayerIndex, [in] BSTR SqlClause, [in] bool UseFilters, [out, retval] LONG* Count);
// 生成缓冲区图形, 返回目标图形sid. 此操作都在跟踪层中
HRESULT bufferShape([in] LONG sid, [in] DOUBLE Distance, [out, retval] LONG* sidDst);
// 将非跟踪层中的图形数据保存到跟踪层中, 返回图形sid
HRESULT trackShape([in] LONG LayerIndex, [in] LONG ShapeIndex, [out, retval] LONG* sid);
//////////////////////////////////////////////////////
// 图形编辑
//////////////////////////////////////////////////////
// 创建新图形对象, 返回图形对象的ID
HRESULT createShape([in] mtkEnumGeometry GType, [out, retval] LONG* sid);
// 向新图形对象中增加视图上的点, 象素坐标
HRESULT addPt([in] LONG sid, [in] mtkPoint Pos);
// 向新图形对象中增加点, 地图坐标
HRESULT addPt2([in] LONG sid, [in] mtkPoint Pt);
// 向图形对象中增加单一属性, 指明列索引0-based, 列值
HRESULT setCol([in] LONG sid, [in] SHORT colId, [in] BSTR colVal);
// 清除指定sid的图形. 绘制的图形都保存在跟踪层中. sid=0全部删除
HRESULT clearShape([in] LONG sid);
分享到:
评论

相关推荐

    基于ARCIMS的环保WebGIS的设计与实现

    结合JavaBean-JSP-Servlet的MVC设计模式,实现了基于Java技术的WebGIS系统开发—果树病虫害信息发布系统。它是根据WebGIS软件平台ArcIMS4.0的工作原理和体系结构,确定了基于Java连接器ArclMS客户端的开发方案,...

    WebGIS项目开发实战(源代码及工程文件)

    基于WebGIS主流平台ArcGIS和OpenGIS,深入浅出地介绍了WebGIS开发的原理与项目实践

    基于WebGIS的电子地图设计与实现.kdh

    这是详细介绍webgis原理,网络地理信息系统的平台搭建,然后在此基础上进行电子地图的设计和实现,对个人认识webgis有很好的帮助。

    WebGIS与WSN的林区火险监测系统设计

    以林区火险灾害预警为背景,应用无线传感器网络(WSN)与网络地理信息系统(WebGIS)技术,设计了一套能够实时对林区火险监测并预警的分布式监测系统,旨在实现火险信息的实时采集、传输、管理、分析和发布等功能。...

    WEBGIS快速地理投影计算

    摘要 由于客户端的功能限制,直接在WEBGIS客户端实现复杂的投影坐标系到地理坐标系的转换是不现实的 。文章 利用线性逼近的原理,通过设计一个三角网格插值的办法,极大简化了客户端的计算复杂性。服务器负责计算...

    基于MapXtreme的校园WebGIS系统研究

    万维网地理信息系统(WebGIS)是当前GIS的一个重要发展方向,其基于Internet的信息共享能力使之成为GIS的一场革命。文中通过研究MapXtreme的工作原理和WebGIS平台的特性,最终设计并实现了校园WebGIS。

    vue3+vite+openlayers6实现绘制扇形及环形组件代码

    内容概要:通过带着读者手写...阅读建议:此资源以开发绘制扇形及环形学习其原理地图容器,不仅是代码编写实现也更注重内容上的需求分析和方案设计,所以在学习的过程要结合这些内容一起来实践,并调试对应的代码。

    基于WebGIS的病虫害防治系统 (2008年)

    设计了基于WebGIS的DIPS系统的体系结构,阐述了构件模型管理子系统的结构原理与维护方法。提出了适合WebGIS系统的通用接口标准,并设计出接口构件模型。给出病虫害防治系统中智能决策推理模块的设计思路和实现方法。...

    gisApp:校园雕塑位置及浏览路线查询的一个GIS系统,调用了百度地图API

    通过对WEBGIS的实现原理和方法的论述与研究,运用百度API、js、json等技术在自己的计算机上编写了一个基于浏览器的系统——校园雕塑位置信息查询。经过雕塑数据信息收集、数据整理,系统分析与设计以及项目代码实现...

    2009.6.19—30举办3S研讨会暨Google Earth与Google Map等仿真建模与共享及ARCGIS与遥感高级程序员培训班

    6、DEM的原理与数据采集及应用及ARCCIS9-3D分析及其显示,空间建模以及实例操作与分析(以ARCCIS在资源环境与城市规划中的应用为例介绍) 主讲人:GIS硕士、南京路川公司专业技术开发工程师(空调机房) 7、以ARCCIS...

    XX系统方案设计.doc

    ASP.NET技术的设计目的是使编写基于WEB的应用程序更加容易的和快捷 的同时,保证这些应用程序能够与各种浏览器和开发工具共同工作。同时,要求该软件 系统能够通过各个单位设置的网关、代理服务器和防火墙等障碍,...

    一个牛人提供的GIS源码(很好)

    一个牛人提供的GIS源码(很好 ...浅谈WEBGIS运用栅格地图实现原理[更新:Google Maps带来的新型WebGIS设计模式] http://www.cnblogs.com/Tangf/archive/2006/01/14/317327.html 校园WebGIS开发与实践(论文部分) http://...

    基于网络的扎龙湿地地理信息系统* (2005年)

    从搜索和分析湿地信息入手,综合运用地理信息系统技术...重点研究了分布式环境下WebGIS 的实现原理、方法,利用统一建模语言(UML) 进行详细分析和设计,给出了一个基于分布式的WebGIS 原型系统的具体思路和解决方案。

    希赛软考学院系统分析师考试辅导与培训_新技术应用资料

    5 测试先行与传统测试的比较.................................................14 5.1 测试先行优于传统测试................................................14 5.2 现有的测试先行方法的不足......................

Global site tag (gtag.js) - Google Analytics