AutoCAD文件(dxf、dwg)发布到 Geoserver作为地图图层

2024-03-02 12:20

本文主要是介绍AutoCAD文件(dxf、dwg)发布到 Geoserver作为地图图层,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

一、Geoserver服务运行

二、dwg文件转dxf

三、dxf转shp

四、shp转文件查看

五、shp文件style设置

六、shp文件导入到Geoserver

七、open Layer 展示

本博客中涉及的操作只适用于,OpenStreetMap数据源,其他数据源需要融汇贯通。

准备环境

一、Geoserver服务运行

java sdk、tomcat、Geoserver

具体配置过程参见:

在windows环境下配置GeoServer

二、dwg文件转dxf

 工具软件:Autodesk AutoCAD 2016

Autodesk AutoCAD 2016插件:Arcgis for AutoCAD

这一步主要的目的是转化格式和坐标。

1.使用AutoCAD打开文件、去掉多余的图层和信息

打开autoCAD文件,整理文件信息

2.加载ArcGIS for AutoCAD调整坐标和文件大小

(1)加载过程及操作参见 

ArcGIS for AutoCAD轻松实现ArcGIS 与 AutoCAD互操作

 (2)分配坐标。这一步很关键,关系到与原有的shp文件是否在同一坐标系。

         本博客采用的坐标系ESPG:900913(来自原有的shp文件,open street map导出的shp文件和osm文件采用的就是这一坐标系)

(3)选择坐标系。

  选择ArcGIS for AutoCAD安装目录 D:\Program Files\ArcGIS for AutoCAD 355\Coordinate Systems\Projected Coordinate Systems\World 下的WGS 1984 Web Mercator.prj   

     坐标说明参见  https://www.cnblogs.com/arxive/p/6103358.html?utm_source=itdadao&utm_medium=referral

(4)选择地图类型,选择world Imagery

(5)地图导入后的效果,如果一开始看不到地图,就缩放地图。此时AutoCAD的坐标原点与之前选择的地理坐标原点重合。(ESPG:900913的坐标原点在非洲西部的大西洋中)

(6)整体显示

(6)平移图形到目标位置,并缩放图形至目标大小。

(7)保存文件为dxf或者dwg格式。

三、dxf或者dwg转shp

 工具:QGIS 3.4.1

(1)导入dxf或者dwg,如果在Project中没有看到Import/Export -> Import Layers from dwg/dxf ,那么跳到(2)为QGIS添加插件  “DXF Importer /DXF2Shp ”

不记得该功能是软件自带,还是插件新增的。

(2)添加插件DXF Importer /DXF2Shp。在plugins|installed 窗口中 搜索安装 该插件

(3)导入配置填写如图,我的图层取名为“EPSG:900913room”.

我导入dwg文件的时候报错,丢掉了一些需要显示的内容,导入dxf时没有报错。

(4)导入以后,软件左下方出现图层。选中新导入的图层并右击,选择“Zoom to Group ”或者“Zoom to Layer”。

显示效果如图,图片中同时显示了Open Street Map 的 gis_osm_roads_free_1.shp 文件作为参照。

 

对比效果

(4)导出为shp文件 右击图层 选择 Export -> Save Feature AS ... 弹出下图对话框

将gruop下的各个图层导出到shp文件

(4)文件

 

四、shp转文件查看

工具:uDig

uDig,不仅是shp文件查看工具跟重要的是,设计渲染样式的工具

 

具体操作参见

如何用uDig美化地图并发布到GeoServer

https://blog.csdn.net/coderwait/article/details/80453162

 

五、shp文件style设置

 同上

六、shp文件导入到Geoserver

具体操作见 如何用uDig美化地图并发布到GeoServer

(1)图层发布时,坐标系选择。

发布完成后显示。

七、Openlayers 展示

(1)显示结果。蓝色的线条为Geoserver服务提供的数据,我在Geoserver中导入了Open steet map的道路(OSM)数据 一并显示出来了,蓝色的小方块是dwg的文件内容

显示效果较差主要是因为图层的style文件没有配置

 

整体效果,open Street map 中 中国的数据没有台湾和藏南

 

(2)OpenLayers3  html 源码。

<!DOCTYPE html>
<html><head><title>Tiled WMS</title><link rel="stylesheet" href="https://openlayers.org/en/v3.20.1/css/ol.css" type="text/css"><!-- The line below is only needed for old environments like Internet Explorer and Android 4.x --><script src="https://cdn.polyfill.io/v2/polyfill.min.js?features=requestAnimationFrame,Element.prototype.classList,URL"></script><script src="https://openlayers.org/en/v3.20.1/build/ol.js"></script></head><body><div id="map" class="map"></div><script>var layers = [//OpenSteetMap地图来源网络new ol.layer.Tile({source: new ol.source.OSM()}),//OpenSteetMap 道路图层new ol.layer.Tile({//extent: [-13884991, 2870341, -7455066, 6338219],source: new ol.source.TileWMS({url: 'http://localhost:8080/geoserver/wms',params: {'LAYERS': 'china:planet_osm_roads_big', 'TILED': true},serverType: 'geoserver'})}),//dxf文件的图层new ol.layer.Tile({//  extent: [-13884991, 2870341, -7455066, 6338219],source: new ol.source.TileWMS({url: 'http://192.168.0.157:8080/geoserver/wms',params: {'LAYERS': 'chinaoutline:lines', 'TILED': true},serverType: 'geoserver'})		  }),new ol.layer.Tile({//  extent: [-13884991, 2870341, -7455066, 6338219],source: new ol.source.TileWMS({url: 'http://192.168.0.157:8080/geoserver/wms',params: {'LAYERS': 'chinaoutline:polylines', 'TILED': true},serverType: 'geoserver'})})];var map = new ol.Map({layers: layers,target: 'map',view: new ol.View({center: [12590580.877,3254259.398 ],//以自己文件的坐标为中心zoom: 10})});</script></body>
</html>

  

 

转载于:https://www.cnblogs.com/lianshanIn17/p/10255694.html

这篇关于AutoCAD文件(dxf、dwg)发布到 Geoserver作为地图图层的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/766103

相关文章

微信公众号脚本-获取热搜自动新建草稿并发布文章

《微信公众号脚本-获取热搜自动新建草稿并发布文章》本来想写一个自动化发布微信公众号的小绿书的脚本,但是微信公众号官网没有小绿书的接口,那就写一个获取热搜微信普通文章的脚本吧,:本文主要介绍微信公众... 目录介绍思路前期准备环境要求获取接口token获取热搜获取热搜数据下载热搜图片给图片加上标题文字上传图片

SpringKafka消息发布之KafkaTemplate与事务支持功能

《SpringKafka消息发布之KafkaTemplate与事务支持功能》通过本文介绍的基本用法、序列化选项、事务支持、错误处理和性能优化技术,开发者可以构建高效可靠的Kafka消息发布系统,事务支... 目录引言一、KafkaTemplate基础二、消息序列化三、事务支持机制四、错误处理与重试五、性能优

新特性抢先看! Ubuntu 25.04 Beta 发布:Linux 6.14 内核

《新特性抢先看!Ubuntu25.04Beta发布:Linux6.14内核》Canonical公司近日发布了Ubuntu25.04Beta版,这一版本被赋予了一个活泼的代号——“Plu... Canonical 昨日(3 月 27 日)放出了 Beta 版 Ubuntu 25.04 系统镜像,代号“Pluc

使用Folium在Python中进行地图可视化的操作指南

《使用Folium在Python中进行地图可视化的操作指南》在数据分析和可视化领域,地图可视化是一项非常重要的技能,它能够帮助我们更直观地理解和展示地理空间数据,Folium是一个基于Python的地... 目录引言一、Folium简介与安装1. Folium简介2. 安装Folium二、基础使用1. 创建

Nginx实现前端灰度发布

《Nginx实现前端灰度发布》灰度发布是一种重要的策略,它允许我们在不影响所有用户的情况下,逐步推出新功能或更新,通过灰度发布,我们可以测试新版本的稳定性和性能,下面就来介绍一下前端灰度发布的使用,感... 目录前言一、基于权重的流量分配二、基于 Cookie 的分流三、基于请求头的分流四、基于请求参数的分

定价129元!支持双频 Wi-Fi 5的华为AX1路由器发布

《定价129元!支持双频Wi-Fi5的华为AX1路由器发布》华为上周推出了其最新的入门级Wi-Fi5路由器——华为路由AX1,建议零售价129元,这款路由器配置如何?详细请看下文介... 华为 Wi-Fi 5 路由 AX1 已正式开售,新品支持双频 1200 兆、配有四个千兆网口、提供可视化智能诊断功能,建

五大特性引领创新! 深度操作系统 deepin 25 Preview预览版发布

《五大特性引领创新!深度操作系统deepin25Preview预览版发布》今日,深度操作系统正式推出deepin25Preview版本,该版本集成了五大核心特性:磐石系统、全新DDE、Tr... 深度操作系统今日发布了 deepin 25 Preview,新版本囊括五大特性:磐石系统、全新 DDE、Tree

Linux Mint Xia 22.1重磅发布: 重要更新一览

《LinuxMintXia22.1重磅发布:重要更新一览》Beta版LinuxMint“Xia”22.1发布,新版本基于Ubuntu24.04,内核版本为Linux6.8,这... linux Mint 22.1「Xia」正式发布啦!这次更新带来了诸多优化和改进,进一步巩固了 Mint 在 Linux 桌面

多模块的springboot项目发布指定模块的脚本方式

《多模块的springboot项目发布指定模块的脚本方式》该文章主要介绍了如何在多模块的SpringBoot项目中发布指定模块的脚本,作者原先的脚本会清理并编译所有模块,导致发布时间过长,通过简化脚本... 目录多模块的springboot项目发布指定模块的脚本1、不计成本地全部发布2、指定模块发布总结多模

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关