为了账号安全,请及时绑定邮箱和手机立即绑定

ArcGIS紧凑型切片读取与应用1-解析(附源码)

标签:
深度学习

1.前言

     ArcGIS 发布的切片服务分为紧凑型切片和传统的分散型切片以及最新ArcGIS por新增的矢量切片。传统的分散型切片面临的问题是文件个数太多,部署拷贝过程十分的耗时,紧凑型切片是对分散型切片进行压缩处理的。一个.bundle文件可以存上万张切片,有利于部署拷贝,.bundlx文件提供切片索引。本教材分为三个模块依次是

(1)文件解析。

(2)webgis动态加载紧凑型切片。

(3)紧凑型批量转分散型。

下面是对紧凑型切片解析的过程,实现使用的c#代码。

2.解析

    解析过程我是参考github上的一个就node.js实现的开源项目,项目地址:https://github.com/fuzhenn/tiler-arcgis-bundle,现在进入解析过程,在8级切片下面紧凑型文件的切片目录如下。

TIM截图20190225135339

     大家可以发现所有.bundlx切片索引文件大小都是81kb,查阅资料发现每个切片索引都存放着128*128个切片的索引地址。但是并不是每个.bundle文件都有128*128个切片,例如1级切片只有4个图片,其余位置会为空字节表示。解析方式就是通过切片的X,Y,Z作为参数解析出对应的索引文件名称,然后从索引文件读取切片的索引位置,最后切片文件中读取对应字节流,保存成图片即可,流程如下。

TIM截图20190225151354

核心实现代码如下:

1.通过xyz获取文件名称与路径

复制代码

/// <summary>/// 查找切片对应的文件路径/// </summary>/// <param name="root">路径</param>/// <param name="level">切片等级</param>/// <param name="rGroup"></param>/// <param name="cGroup"></param>/// <returns></returns>private string getBundlePath(string root,int level, int rGroup , int cGroup ) {     var bundlesDir = root;     var l = level.ToString();     var lLength = l.Length;     if (lLength < 2)
     {         for (var i = 0; i < 2 - lLength; i++)
         {
             l = "0" + l;
         }
     }
     l = "L" + l;    var r = rGroup.ToString("X");     var rLength = r.Length;     if (rLength < 4)
     {         for (var i = 0; i < 4 - rLength; i++)
         {
             r = "0" + r;
         }
     }
     r = "R" + r;    var c = cGroup.ToString("X");     var cLength = c.Length;     if (cLength < 4)
     {         for (var i = 0; i < 4 - cLength; i++)
         {
             c = "0" + c;
         }
     }
     c = "C" + c;     var bundlePath=string.Format  (@"{0}\_alllayers\{1}\{2}{3}", bundlesDir,
         l, r, c);     return bundlePath;
}

复制代码

2.通过xy获取索引值

复制代码

 int packSize = 128;var rGroup = Convert.ToInt32(packSize * Convert.ToInt32(y / packSize));var cGroup = Convert.ToInt32(packSize * Convert.ToInt32(x / packSize));

context.index = packSize * (x - cGroup) + (y - rGroup);

复制代码

3.通过读取索引文件,根据索引值获取切片索引位置

复制代码

/// <summary>/// 读取切片/// </summary>/// <param name="context"></param>/// <returns></returns>private byte[] readTileFromBundleV1(bundlx context)
{     var bundlxFileName = context.bundlxFileName;     var bundleFileName = context.bundleFileName;     var index = context.index;     using (FileStream file = new FileStream(bundlxFileName, FileMode.Open))
     {         byte[] buffer = new byte [5];         byte[] bufferfile = new byte[file.Length];
         file.Read(bufferfile,0,(int)file.Length);         //读取bundlx文件存储该切片的位置
         buffer = bufferfile.Skip(16 + 5 * index).Take(4).ToArray();         //偏移量
         var offset = BitConverter.ToInt32(buffer,0);        return readTile(bundleFileName, offset);
     }
}

复制代码

4.读取具体切片数据

复制代码

  /// <summary>
        /// 读取切片对应字节        /// </summary>
        /// <param name="bundleFileName"></param>
        /// <param name="offset"></param>
        /// <returns></returns>
        private byte[] readTile(string bundleFileName,int offset)
        {            using (FileStream file = new FileStream(bundleFileName, FileMode.Open))
            {                byte[] buffer = new byte[4];                byte[] bufferfile = new byte[file.Length];
                file.Read(bufferfile, 0, (int)file.Length);                //获取bundle具体切片文件字节数
                buffer = bufferfile.Skip(offset).Take(4).ToArray();                var length = BitConverter.ToInt32(buffer,0);                byte[] tileData = new byte[length];               //根据索引和字节数读出文件位置
                tileData = bufferfile.Skip(offset + 4).Take(length).ToArray();                return tileData;
            }
        }

复制代码

3.成果

将字节流保存成.png图片输出,对应项目image项目,代码已经上传Github,下篇写一下webgis动态加载紧凑型切片。

image

 

百度网盘链接:https://pan.baidu.com/s/1I-Bj3EQSN57pQHvKZ2hBUA   提取码:lliw

github项目地址:https://github.com/HuHongYong/TilerArcgisBundle

作者:ATtuing

出处:http://www.cnblogs.com/ATtuing

本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接。


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消