注册通行证 用户名 密码
  • 文章投稿
  • 博客
  • 论坛
  • 设为首页
  • 加入收藏
jztop.com网络技术
  • 首页
  • | iT新闻
  • | 操作系统
  • | 组网建网
  • | 网络安全
  • | 程序开发
  • | 办公一族
  • | 工具软件
  • | 网页制作
  • | 多媒体制作
  • | 网吧技术
  • | 服务器
  • | 专题教程
Vista | 软件评测 | 系统备份 | 优化 | 进程 | 聊天 | 病毒 | Linux | 黑客 | 防火墙 | 数据库 | Web开发 | Java | Word | 游戏 | 32位开发 | 移动开发
当前位置:首页 > 程序开发 > 数据库 > Oracle > 内容正文

GIS三维地景仿真设计之数字高程模型

发布时间:2006-07-27 09:52:31 来源:天极开发 网友评论 0 条
  引言

  在上一篇文章中建立了OpenGL应用程序框架,为场景的绘制提供了环境支持。要绘制某一区域场地的场景自然需要通过对该区域各点坐标数据的建模来实现。由于这些点的坐标取值描述了该区域的基本地貌特征,因此建模后的场景能够无失真的再现该区域从而达到仿真的目的。但是在实际操作时不可能取该区域的全部点进行建模,无论是数据量还是运算速度都是不允许的。一般的做法是进行网格抽取,可以在该区域纵横方向各每隔1米、10米、100米或是1千米取一个点,以这些点的坐标值来模拟真实场景,网络抽取间隔应以抽取后的网格足够描述原区域地貌特征为准。由于网格间隔固定,因此网格的平面坐标能够很容易的推算出来而无须记录,真正有价值的是各点的高程数据,这种由高程数据组成的均匀间隔网格模型在GIS中通称为数字高程模型(DEM)。本文将就DEM数据的读取和生成进行重点介绍。

  DEM数据结构的定义

  DEM数据并没有统一的标准格式,常用的标准有美国地理DEM数据标准和日本DEM数据标准等多种,这类DEM数据定义的信息较多,而这里只使用了高程数据,如果使用上述格式标准则信息利用率太低。因此,这里将建立自己的DEM数据格式,并以此来存储某一区域的地景特征数据。如果要满足在引言中提到的DEM数据定义标准,至少需要定义网格的长、宽节点数、网格间隔以及各节点的高程数据。其中,各节点的高程数据以整型点阵数据方式存储记录,其余各参数可以作为文件头进行定义。由此可以定义数据结构DEMFILEHEADER来描述DEM文件头,该文件头除了定义上述几个必须字段外,还定义了一些保留字段以备将来扩展使用:

typedef struct tagDEMFILEHEADER{
 // 定义DEM数据的头文件格式
 int map[6]; // 保留
 int iDemY; // DEM格网Y方向上的点数
 int iDemX; // DEM格网X方向上的点数
 float sx; // X方向缩放系数
 float sy; // Y方向缩放系数
 float interval; // DEM格网点的采样间隔
} DEMFILEHEADER;

  DEM数据文件的生成

  DEM数据文件的生成主要包括两部分:文件头的生成和网格数据的生成。如果数据量不大,可以用手工填表的方式将采集到的网格化高程数据写入到DEM数据文件。但在实际使用时,数据量往往是比较巨大的。应当采取某种自动化处理措施使其实用化。这里采取从位图导入高程数据的方式,通过前期处理将通过卫星遥感手段得到的某一地区的高程数据作为图象颜色值而以位图的形式给出,这样一来,只需要读取该位图信息,图象的宽度和高度就是DEM文件的X方向和Y方向的网格节点数,图象颜色值为高程数据,用户只需手工输入根据比例换算而来的网格间隔即可。下面这段代码是实现这部分功能的主要代码:

DemHeader.iDemX = set.m_nXPoint; // 填充文件头
DemHeader.iDemY = set.m_nYPoint;
DemHeader.interval = set.m_nInterval;
// 选择待生成的DEM文件
CFileDialog fileDlg(FALSE, "*.dem", "*.dem", OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT, "地形数据文件(*.dem)|*.dem||", NULL);
if (fileDlg.DoModal() == IDOK) {
 // 申请DEM数据缓冲区
 int* pData = new int[set.m_nWidthBytes * set.m_nYPoint + 100];
 if (set.m_bUseRandom == FALSE) {
  BYTE R, G, B; // 24位图象将真彩数据转换为灰度数据保存
  for (int i = 0; i < set.m_nYPoint; i++) {
   for (int j = 0; j < set.m_nXPoint; j++) {
    B = set.m_pData[i * set.m_nWidthBytes + j * 3];
    G = set.m_pData[i * set.m_nWidthBytes + j * 3 + 1];
    R = set.m_pData[i * set.m_nWidthBytes + j * 3 + 2];
    pData[i * DemHeader.iDemX + j] = (int)((9798.0f * R + 19235.0f * G + 3735.0f * B) / 32768.0f);
   }
  }
 }else{
  for (int i = 0; i < set.m_nXPoint * set.m_nYPoint; i++) // 用随机数填充DEM数据
   pData[i] = (int)(rand() % set.m_nLimit);
 }
 CFile file; // 保存DEM数据到文件
 file.Open(fileDlg.GetPathName(), CFile::modeCreate | CFile::modeReadWrite);
 if (pData != NULL) {
  file.Write((LPSTR)&DemHeader, sizeof(DemHeader));
  file.WriteHuge((LPSTR)pData, DemHeader.iDemX * DemHeader.iDemY * sizeof(int));
 }
 file.Close();
 delete[] pData;
}

  其中, set.m_nXPoint、set.m_nYPoint和set.m_nInterval分别为从图象获取得到的网格节点数和用户输入的网格间隔。这几个参数填充到DEMFILEHEADER 结构对象DemHeader中后将作为DEM文件头保存到新创建的DEM数据。set.m_pData指向的缓冲区保存有以RGB颜色值方式给出的各节点高程数据,经过换算后保存到DEM数据文件。

关于 GIS 三维地景 仿真设计 数字高程模型 的新闻
  • GIS系统三维地景仿真的设计之基础架构
  • 用于编辑注册表的插件工具Registry Explorer
  • 注册表医生(Registry Medic) V3.0注册码
【评论】【收藏本文】【打印】【关闭】
上一篇文章:小型软件的通用界面设计制作指南
下一篇文章:在J2ME/MIDP中实现图像旋转
讨论区
查看
已有 0 位对此新闻感兴趣的网友发表了看法
匿名发表
注册通行证 登陆
图文阅读推荐
Atlas快速入门之实战Atlas
Atlas快速入门之实战Atlas
.net页面间的参数传递简单实例
.net页面间的参数传递简单实例
全站资源
  • 微软官方入门教程19:轻松掌握Vista系统的快
  • 微软2008大冲击,预借Vista SP1力促Vista市
  • 在收件箱中获得 Windows Vista 的最新更新
  • 微软官方Vista入门教程全集19篇(Vista学院
  • Windows Vista 的成功将势不可挡
  • 快快抛弃Vista,拥抱XP SP3!你觉得呢?
  • 浅谈Vista系统关闭虚拟内存与使用内存盘加速
  • 嘿嘿,按下键盘上面的三个键,马上让你的Vi
  • Windows Vista的盗版率只有Windows XP的一半
  • 3DMark和PCMark Vantage新版将只支持Vista系
阅读排行
  • .net页面间的参数传递简单实例
  • VC++与Matlab混合编程之引擎操作详解
  • Oracle数据库数据对象分析
  • Eclipse3.2+Tomcat5.5.17+Oracle9配置
  • Oracle数据库中索引的维护
  • 在Oracle的网络结构中解决连接问题
  • Oracle数据安全面面观
  • Oracle数据库的ORA-00257故障解决过程
  • Oracle数据库备份与恢复的三种方法
  • Oracle与SQL Server在企业应用中的比较
最新技术文档
  • Oracle中使用自治事务保存日志表条目
  • 在Oracle的网络结构中解决连接问题
  • Oracle数据库备份与恢复的三种方法
  • Oracle 9i 数据库WITH查询语法小议
  • Hibernate二级缓存攻略
  • Oracle 的数据库的数据备份与恢复
  • Oracle 10g的安装步骤和注意事项
  • 为AJAX应用程序构建一个错误提交系统
  • Atlas快速入门之实战Atlas
  • 基于AJAX技术提高搜索引擎排名
专题教程
  • 大话G游 专题:手机病毒揭密
  • ARP攻击防范与解决方案 路由故障处理手册
  • Picasa中文版_Picasa教程 专题:清除流氓软件
  • Firefox专题 seo搜索引擎优化专区
  • 重装Windows必知的事情 装机之必备软件大行动
病毒专杀栏
  • 杀毒软件反被病毒杀 连"救命"都不能喊
  • 金山ARP防火墙
  • 还原卡神话破灭“机器狗”病毒来势汹汹
  • cctv经济半小时:你的手机现在安全吗?
  • 新挂马方式开始流行 ARP挂马称雄局域网
  • 木马和病毒清除的通用解法
  • IP地址不再冲突 查找ARP攻击者元凶
  • 教你几招识别和防御Web网页木马
  • 分析:封杀BT只是暂时的止痛药
  • QQ爆危险漏洞,“QQ游戏邀请大盗”邀请你玩病
关于我们 | 诚聘英才 | 联系我们 | 版权声明 | 网站大事 | 网站地图 | 意见建议
CopyRight 2005-2007 Jztop.Com 版权所有 未经许可 请勿转载