GIS 相关知识

本贴最后更新于 1954 天前,其中的信息可能已经时移世易

GIS 的三大应用

第一类是政府应用,“电子政务” 是当今政府加强信息化建设的新方向,是指在现代计算机、网络通信等技术支撑下,政府机构日常办公、信息收集与发布、公共管理等事务在数字化、网络化的环境下进行的国家行政管理形式。GIS 已成为很多政府决策部门工作必备的支撑系统之一,在国家水利、电力、林牧业、地矿、交通、资源环境保护等机构己发挥重要作用。
第二类是企业应用,随着信息时代的到来,企业的组织、运营、管理也逐渐向信息化方向发展,GIS 通过提供可视化地理空间信息服务结合企业管理信息系统,为企业的业务规划、物流等领域提供辅助决策。
第三类是大众应用,WebGIS 的产生为大众提供了获取地理空间信息服务的平台,通过开放的、操作简单的 WebGis 服务,满足大众对地理信息的需求,如:方便人们出行的谷歌、百度地图服务。GIS 三大组成部分

(1)数字化的数据

数字化的数据是信息在计算机中的表现形式,是指要使用计算机软硬件进行图形化显示和空间分析操作的地理空间信息。GIS 中的数据不同于其他信息系统的数据,它具有空间特性,Gis 数据分为空间数据和非空间数据两类.比如 GIS 中的一条数据经度和纬度数据表示该事物的空间位置,属于空间数据,名字和日期数据表示该事物的属性,属于非空间数据,GIS 将空间数据和非空间数据进行结合进行分析、处理。GIS 功能
基本功能应包括:数据输入、数据编辑、数据存储、数据操作、数据分析、数据显示和输出

(1)数据输入:也称数据采集
人工数字化输入 远程遥感的卫星图像和 GPS
(2)数据编辑:随着地图要素的数字化操作,用户需要完成将所有的空间要素关联到其对应的属性数据,清理并改正在数据转换过程中产生的错误.
(3)数据存储:当数据经过数字化、编辑后,数字化的地图数据需要存储在磁盘或其他存储设备上,存储使用的数据模型最常用的包括:栅格格式和矢量格式。两种格式都将原有图数据简化为一种容易存储的通用格式。
(4)数据操作:当数据在系统中存储后,用户就可以对数据进行一系列的操作,GIS 操作通常以一个工具包的形式提供给用户,工具包中包括基本的数据操作和分析功能,如:数据检索、面积周长测量、坐标转换、投影变换、图幅接边等。
(5) 数据分析:Gls 的核心在于其强大的分析能力,如对距离某一事故地点一定范围内各种空间要素的搜索,并对相关的信息进行统计分析,为事故处理提供所需要的信息。

遥感技术、全球定位技术与地理信息系统合称为“3S”技术 OpenGIS
(Open Geodata Interoperation Specification,OGIS-开放的地理数据互操作规范)
是由美国 OGC(OpenGIS 协会,OpenGIS Consortium)提出,主要架构和类库几何基础类库
代表: JTS(Java), GEOS(C++), Shapely(Python)
这类几何基础类库主要实现的是 OpenGIS 的 Simple Feature Access 标准,简单地说他们就是对几何类型(Geometry)进行了一定程度的封装。

以 JTS 为例,它按照 OpenGIS 对于 Geometry 的描述实现了基于 Java 的接口和继承关系,制作好了可以使用的类似 Point、LineString 这样的类。另外这些类库还普遍实现了 OpenGIS 的 DE-9IM 空间位置关系判断和一些常用的计算几何方法(如缓冲(buffer))此类软件是所有 GIS 类库的基础,正如几何是 GIS 的基础之一一样。

数据源实现代表:PostGIS(PostgreSQL),MySQL Spatial
数据源的实现主要是开源数据库的空间扩展。数据库的空间扩展不仅仅在数据表中支持几何类型的存储,而且更提供了 SQL 级别的集合关系判断,例如,可以直接利用 SQL 查询在某个多边形内的点。
PostGIS 是加拿大 Refractions 公司支持的开源项目,它为开源数据库 PostgreSQL 提供了空间支持。PostGIS 安装后,PostgreSQL 中出现一个模版数据库,新建空间数据库时只需以 PostGIS 为模版即可。PostGIS 在 SQL 级别上实现了基本的空间运算功能。另外绝大多数开源 GIS 软件(即使是不严格遵守 OpenGIS 标准的)都支持 PostGIS 数据表的直接载入,读写等功能。毋庸置疑,PostGIS 是 OpenGIS 数据源最佳实现。
目的是促进采用新的技术和商业方式来提高地理信息处理的互操作性(Interoperability),
它致力于消除地理信息应用(如地理信息系统,遥感,土地信息系统,自动制图/设施管理(AM/FM)系统)
之间以及地理应用与其它信息技术应用之间的藩篱,建立一个无“边界”的、分布的、基于构件的地理数据互操作环境

中间件代表:GeoTools(Java)
中间件在系统中扮演连接数据和服务的角色。GeoTools 承担了从各种数据源(如 PostGIS,GML,Shapefile,WFS)读取数据并将数据标准化的工作。Feature 接口就定义在 GeoTools 中,不同数据源的数据读出后被统一成包含一个 Geometry 成员(定义在 JTS 中)的 Feature 接口的实现。这样,进一步的操作只需面向 Feature 即可,
省去了高层软件对于不同数据源的解读过程。另外,GeoTools 还是 OpenGIS 标准的全面实现,其中包括 Filter、坐标转换、GML。

GeoTools 和 JTS 还有 GeoAPI 到底是什么关系?
JTS 是加拿大的 Vivid Solutions 做的一套开放源码的 Java API。它提供了一套空间数据操作的核心算法。为在兼容 OGC 标准的空间对象模型中进行基础的几何操作提供 2D 空间谓词 API。GeoAPI 为 OpenGIS 规范提供一组 Java 接口。Geotools 是一个开源的 Java GIS 工具包,可利用它来开发符合标准的地理信息系统。
Geotools 提供了 OGC(Open Geospatial Consortium)规范的一个实现来作为他们的开发。
简单而言:GeoTools 的目标是致力于开发一个符合规范的 Gis 工具包,既然是工具包,那么就要有很多工具用来对付构建一个完整的地理信息系统时会碰到的问题,常见的问题比如:投影的转换,基准面的设定,空间数据对象的渲染和样式,各种数据源的支持,各种 GIS 文件格式支持,空间数据过滤与搜索。。。。等等的问题。

在开发这些工具的时候,恰好在处理空间数据图形关系的时候,有一个非常好的解决方案,那就是 JTS,JTS 解决了对象与对象之间拓扑关系的判定和计算,并提供很多有用的算法来解决对象的面积,长度。。。等等等的问题。这样而言,JTS 就相当于 GeoTools 中的一个子模块。但因为这个模块本身不是 GeoTools 工程的,所以在 javadoc 中找不到 JTS 的 API,需要到 JTS 官网上面另外下载。至于 GeoAPI 则是 GeoTools 符合标准的模板。它制定了地理信息系统中所有的数据类型应该是什么,投影转换的方式有哪几种诸如此类的规范。这样兼容 GeoAPI 接口的 GeoTools 才是一个符合规范的地理信息系统工具包。

WMS/WFS 服务器
Web Map Service(WMS)根据用户的请求返回相应的地图(包括 PNG,GIF,JEPG 等栅格数据或者 SVG,WEB CGM 矢量数据) 。
代表: GeoServer(Java),MapServer(PHP)
地图服务器扮演向网络中的客户端提供地图服务的角色。这类地图服务器可以接收统一规范的 WMS 和 WFS 请求(request),返回多种格式的数据。这个过程有 WMS/WFS 规范的严格规定,所以,对客户端来说其地图服务器的实现究竟是什么并不会造成太大影响。

GeoServer 是 OpenGIS Web 服务器规范的 J2EE 实现的社区开源项目,利用 GeoServer 可以方便的发布地图数据,允许用户对特征数据进行更新、删除、插入操作,通过 GeoServer 可以比较容易的在用户之间迅速共享空间地理信息。
GeoServer 兼容 WMS 和 WFS 特性;支持 PostGIS 、 Shapefile 、 ArcSDE 、 Oracle 、 VPF 、 MySQL 、 MapInfo ;支持上百种投影;能够将网络地图输出为 jpeg 、 gif 、 png 、 SVG 、 KML 等格式;能够运行在任何基于 J2EE/Servlet 容器之上;嵌入 MapBuilder 支持 AJAX 的地图客户端 OpenLayers;

客户端
代表:OpenLayers/MapBuilder(JavaScript),uDig(Java),QGIS(C++)
客户端分为浏览器和桌面客户端程序两种。以 OpenLayers 为代表的 B/S 系统客户端现在已经非常强大,它可以封装 WMS 请求,在浏览器上实现地图的切片载入功能。另外拖动、缩放都功能也非常完善,可以实现跨浏览器操作。最近的 OpenLayers 版本还支持了矢量编辑功能,可以通过 WFS-t 提交。
而传统的桌面客户端程序功能则更加强大,支持多种包括 WMS 和 WFS 在内的数据源,另外编辑功能、操作性也要比浏览器中的强大。数据格式 ESRI 的 Shapefile 格式
是 GIS 矢量文件格式的事实标准,通常由.shp, .shx, .prj, .dbf 等文件组成。
OpenGIS 的实现软件普遍支持 Shapefile 的读写。Shapefile 在 GeoServer 中可以直接作为数据源,但是这种方式并不被推荐,原因很简单,基于文件的数据源可能造成性能不佳和数据丢失。shape 格式文件最少包含 3 个文件,他们的后缀是:.shp, .dbf, .shx。.shp 存储地理形状和位置信息,.dbf 存储属性信息,.shx 是索引文件。
MapInfo 的.mif/.mid 格式
.MIF 的文件,它主要用来保存空间对象的几何数据;扩展名为.MID 的文件,它主要用来保存与几何数据相对应的属性数据;

GML
GML 是 OpenGIS 的标准规范之一,它基于 xml 描述地理数据。于 Shapefile 相比,xml 更容易读写,易于在网络中以各种形式传播。
同时,xml 还具有可读性,人可以理解和辨识。GeoTools 实现了 GMLDataStore,因此在 GeoServer 中 GML 也可以直接作为数据源(需要下载 GML 扩展)。
同时,GML 的数据源为数据源动态化提供了实现的思路和可能性。

地理应用服务器

Mapinfo MapXtreme
MapObject Autodesk
Map Guide
ArcIMS
Super MapArcGIS Server

MapXtreme 是 MapInfo 公司开发的基于 Internet/ Intranet 的应用服务器,它具有强大的地图化功能,包括绘制专题地图、缓冲区分析、地图编辑、地图目标查找、地图显示、图层控制、空间选择、地理编码、扩展地图库和示例数据等。管理员只要在 Web 服务器上对 MapXtreme 进行编程和管理,用户就能够通过 Web 浏览器访问到地图信息。

工作方式
  MapXtreme 的工作方式总体来说是瘦客户端的工作方式,客户端看到的地图是服务端根据用户请求动态生成的某种格式的图片。MapXtreme 采用的是 B/S 模式三层架构客户端首先向 Web 服务器提交 HTTP 请求,递交 Form 表单,Web 服务器收到该请求后,把地图操作请求提交给地图应用服务,地图应用服务在内部调用 MapXServer 响应用户的操作请求,进行相应的空间分析和处理后,产生新的地图图片,返回给 Web 服务器,Web 服务器再把该图片嵌入到 HTML 页面中并返回到客户端的浏览器上

原文链接:https://blog.csdn.net/cdl2008sky/article/details/7266680

  • GIS
    10 引用 • 23 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • 周末

    星期六到星期天晚,实行五天工作制后,指每周的最后两天。再过几年可能就是三天了。

    14 引用 • 297 回帖
  • NetBeans

    NetBeans 是一个始于 1997 年的 Xelfi 计划,本身是捷克布拉格查理大学的数学及物理学院的学生计划。此计划延伸而成立了一家公司进而发展这个商用版本的 NetBeans IDE,直到 1999 年 Sun 买下此公司。Sun 于次年(2000 年)六月将 NetBeans IDE 开源,直到现在 NetBeans 的社群依然持续增长。

    78 引用 • 102 回帖 • 702 关注
  • Maven

    Maven 是基于项目对象模型(POM)、通过一小段描述信息来管理项目的构建、报告和文档的软件项目管理工具。

    188 引用 • 319 回帖 • 253 关注
  • Thymeleaf

    Thymeleaf 是一款用于渲染 XML/XHTML/HTML5 内容的模板引擎。类似 Velocity、 FreeMarker 等,它也可以轻易的与 Spring 等 Web 框架进行集成作为 Web 应用的模板引擎。与其它模板引擎相比,Thymeleaf 最大的特点是能够直接在浏览器中打开并正确显示模板页面,而不需要启动整个 Web 应用。

    11 引用 • 19 回帖 • 390 关注
  • LeetCode

    LeetCode(力扣)是一个全球极客挚爱的高质量技术成长平台,想要学习和提升专业能力从这里开始,充足技术干货等你来啃,轻松拿下 Dream Offer!

    209 引用 • 72 回帖
  • Solidity

    Solidity 是一种智能合约高级语言,运行在 [以太坊] 虚拟机(EVM)之上。它的语法接近于 JavaScript,是一种面向对象的语言。

    3 引用 • 18 回帖 • 432 关注
  • abitmean

    有点意思就行了

    33 关注
  • Visio
    1 引用 • 2 回帖
  • OpenResty

    OpenResty 是一个基于 NGINX 与 Lua 的高性能 Web 平台,其内部集成了大量精良的 Lua 库、第三方模块以及大多数的依赖项。用于方便地搭建能够处理超高并发、扩展性极高的动态 Web 应用、Web 服务和动态网关。

    17 引用 • 53 关注
  • Ant-Design

    Ant Design 是服务于企业级产品的设计体系,基于确定和自然的设计价值观上的模块化解决方案,让设计者和开发者专注于更好的用户体验。

    17 引用 • 23 回帖
  • V2EX

    V2EX 是创意工作者们的社区。这里目前汇聚了超过 400,000 名主要来自互联网行业、游戏行业和媒体行业的创意工作者。V2EX 希望能够成为创意工作者们的生活和事业的一部分。

    16 引用 • 236 回帖 • 257 关注
  • 正则表达式

    正则表达式(Regular Expression)使用单个字符串来描述、匹配一系列遵循某个句法规则的字符串。

    31 引用 • 94 回帖
  • Hadoop

    Hadoop 是由 Apache 基金会所开发的一个分布式系统基础架构。用户可以在不了解分布式底层细节的情况下,开发分布式程序。充分利用集群的威力进行高速运算和存储。

    90 引用 • 122 回帖 • 620 关注
  • 又拍云

    又拍云是国内领先的 CDN 服务提供商,国家工信部认证通过的“可信云”,乌云众测平台认证的“安全云”,为移动时代的创业者提供新一代的 CDN 加速服务。

    20 引用 • 37 回帖 • 576 关注
  • 创造

    你创造的作品可能会帮助到很多人,如果是开源项目的话就更赞了!

    184 引用 • 1020 回帖
  • ZooKeeper

    ZooKeeper 是一个分布式的,开放源码的分布式应用程序协调服务,是 Google 的 Chubby 一个开源的实现,是 Hadoop 和 HBase 的重要组件。它是一个为分布式应用提供一致性服务的软件,提供的功能包括:配置维护、域名服务、分布式同步、组服务等。

    59 引用 • 29 回帖 • 1 关注
  • Pipe

    Pipe 是一款小而美的开源博客平台。Pipe 有着非常活跃的社区,可将文章作为帖子推送到社区,来自社区的回帖将作为博客评论进行联动(具体细节请浏览 B3log 构思 - 分布式社区网络)。

    这是一种全新的网络社区体验,让热爱记录和分享的你不再感到孤单!

    133 引用 • 1124 回帖 • 108 关注
  • 以太坊

    以太坊(Ethereum)并不是一个机构,而是一款能够在区块链上实现智能合约、开源的底层系统。以太坊是一个平台和一种编程语言 Solidity,使开发人员能够建立和发布下一代去中心化应用。 以太坊可以用来编程、分散、担保和交易任何事物:投票、域名、金融交易所、众筹、公司管理、合同和知识产权等等。

    34 引用 • 367 回帖
  • 智能合约

    智能合约(Smart contract)是一种旨在以信息化方式传播、验证或执行合同的计算机协议。智能合约允许在没有第三方的情况下进行可信交易,这些交易可追踪且不可逆转。智能合约概念于 1994 年由 Nick Szabo 首次提出。

    1 引用 • 11 回帖 • 3 关注
  • 书籍

    宋真宗赵恒曾经说过:“书中自有黄金屋,书中自有颜如玉。”

    78 引用 • 396 回帖 • 1 关注
  • DNSPod

    DNSPod 建立于 2006 年 3 月份,是一款免费智能 DNS 产品。 DNSPod 可以为同时有电信、网通、教育网服务器的网站提供智能的解析,让电信用户访问电信的服务器,网通的用户访问网通的服务器,教育网的用户访问教育网的服务器,达到互联互通的效果。

    6 引用 • 26 回帖 • 529 关注
  • 分享

    有什么新发现就分享给大家吧!

    248 引用 • 1794 回帖 • 1 关注
  • 负能量

    上帝为你关上了一扇门,然后就去睡觉了....努力不一定能成功,但不努力一定很轻松 (° ー °〃)

    89 引用 • 1251 回帖 • 407 关注
  • 七牛云

    七牛云是国内领先的企业级公有云服务商,致力于打造以数据为核心的场景化 PaaS 服务。围绕富媒体场景,七牛先后推出了对象存储,融合 CDN 加速,数据通用处理,内容反垃圾服务,以及直播云服务等。

    29 引用 • 230 回帖 • 128 关注
  • 友情链接

    确认过眼神后的灵魂连接,站在链在!

    24 引用 • 373 回帖 • 1 关注
  • Flume

    Flume 是一套分布式的、可靠的,可用于有效地收集、聚合和搬运大量日志数据的服务架构。

    9 引用 • 6 回帖 • 654 关注
  • Telegram

    Telegram 是一个非盈利性、基于云端的即时消息服务。它提供了支持各大操作系统平台的开源的客户端,也提供了很多强大的 APIs 给开发者创建自己的客户端和机器人。

    5 引用 • 35 回帖