ArcGIS紧凑型切片读取与应用3-紧凑型批量转分散型(附源码)
系列文章目录
ArcGIS紧凑型切片读取与应用2-webgis动态加载紧凑型切片(附源码)
ArcGIS紧凑型切片读取与应用3-紧凑型批量转分散型(附源码)
1.前言
上篇介绍了webgis动态加载解析紧凑型切片的例子,现在我们使用逆向思维实现紧凑型切片转分散型切片,在实际工作中很有用处,紧凑型切片易于拷贝,但读取只有部署到Arcgis Server才行。相比分散型切片很通用可以部署在类似Geoewebcache的地图缓存服务器或者也可以直接部署到web服务器下。
软件核心功能:

(1)支持切片等级范围选择。
(2)支持切图范围的选择,有利于局部数据的更新。
(3)支持多线程解析,充分利用系统资源,加快解析速率。
(4)文件命名格式与Arcgis分散型切片相同。
2.核心代码解析
1.首先要解析将输入的坐标转为切片对应x、y、z值
/// <summary>
/// 通过经纬度获取切片位置
/// </summary>
/// <param name="lat_deg">纬度</param>
/// <param name="lon_deg">经度</param>
/// <param name="zoom">切片等级</param>
private double[] ConvertTile(double lat_deg, double lon_deg, int zoom)
{
double lat_rad = (Math.PI / ) * lat_deg;
double n = Math.Pow(, zoom);
double xtile = Math.Floor((lon_deg + 180.0) / 360.0 * n);
double ytile = Math.Floor((1.0 - Math.Log(Math.Tan(lat_rad) + ( / Math.Cos(lat_rad))) / Math.PI) / 2.0 * n);
return new double[] { xtile, ytile };
}
2.通过左上角坐标和右上角坐标,解析出指定切片等级下的所有紧凑型切片文件
/// <summary>
/// 获取某一切片等级下的文件对象
/// </summary>
/// <param name="level"></param>
/// <param name="xy">【x1,y1,x2,y2】</param>
/// <returns></returns>
private List<BundleModel> GetLevelBundle(int level, int[] xy)
{
List<BundleModel> bundleModelList = new List<BundleModel>();
int minx = ((xy[] + ) / ) * ;
int maxx = ((xy[] + ) / ) * ;
int miny = ((xy[] + ) / ) * ;
int maxy = ((xy[] + ) / ) * ;
int xcount = (maxx - minx) / + ;
int ycount = (maxy - miny) / + ;
for (int x = ; x < xcount; x++)
{
for (int y = ; y < ycount; y++)
{
BundleModel bm = new BundleModel();
bm.StartX = minx + (x) * ;
bm.StartY = miny + (y) * ;
var rGroup = Convert.ToInt32( * Convert.ToInt32(bm.StartX / ));
var cGroup = Convert.ToInt32( * Convert.ToInt32(bm.StartY / ));
var bundleBase = getBundlePath(textBox1.Text, level, rGroup, cGroup);
bm.Level = level;
bm.BundlxDire = bundleBase + ".bundlx";
bm.BundleDire = bundleBase + ".bundle";
bm.BundleName = Path.GetFileNameWithoutExtension(bm.BundleDire);
bundleModelList.Add(bm);
}
}
return bundleModelList;
}
3.多线程切片实现,将文件平均分给不同线程
//将文件平均分给各个线程
int count = bundleModelList.Count() / threadcount;
int yu = bundleModelList.Count() % threadcount; if (count == )
{
for (int i = ; i < bundleModelList.Count; i++)
{
List<BundleModel> model = bundleModelList.Skip(i).Take().ToList();
System.Threading.ThreadPool.QueueUserWorkItem((state) =>
{
foreach (var item in model)
{
ToImg(item);
}
this.BeginInvoke(new Action(() =>
{ }));
}, model);
}
}
else
{
for (int i = ; i < threadcount; i++)
{
List<BundleModel> model = bundleModelList.Skip(i * count).Take(count).ToList();
if (i < yu)
{
model.AddRange(bundleModelList.Skip(threadcount * count + i).Take().ToList());
}
System.Threading.ThreadPool.QueueUserWorkItem((state) =>
{
foreach (var item in model)
{
ToImg(item);
}
this.BeginInvoke(new Action(() =>
{ }));
}, model);
}
}
4.Arcgis散片文件路径格式的生成
string L="L"+ zeroPad(z, );
string C = "C" + zeroPad(x, ,);
string R = "R" + zeroPad(y, ,); //保存路径
string path = textBox2.Text+"\\"+L+"\\"+R+"\\"+C+ ".png"; //文件命名函数 private string zeroPad(int num, int len,int type=)
{
string str = num.ToString();
if (type==)
{
str = num.ToString("X");
}
while (str.Length < len)
{
str = "" + str;
}
return str;
}
解析结果展示

3.结束
开启多线程模式切片的速率比较满意,通过比较简单的代码理解了紧凑型切片的所有的细节,我们现在完全可以实现散片型装紧凑型的文件,有兴趣可以反推一下。所有的源代码已近上传到了GitHub,欢迎大家指教。
百度网盘链接:https://pan.baidu.com/s/1I-Bj3EQSN57pQHvKZ2hBUA 提取码:lliw
github项目地址:https://github.com/HuHongYong/TilerArcgisBundle
作者:ATtuing
出处:http://www.cnblogs.com/ATtuing
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接。
ArcGIS紧凑型切片读取与应用3-紧凑型批量转分散型(附源码)的更多相关文章
- spring应用中多次读取http post方法中的流(附源码)
一.问题简述 先说下为啥有这个需求,在基于spring的web应用中,一般会在controller层获取http方法body中的数据. 方式1: 比如http请求的content-type为appli ...
- arcgis api 4.x for js 图层拓展篇之mapvLayer(附源码下载)
因为在项目开发过程中,使用的arcgis js api版本是4.7,并不能支持客户端渲染热力图,想到arcgis js api 4.x的渲染是基于canvas,故琢磨着是否能借助类似于mapV.ech ...
- ArcGIS紧凑型切片读取与应用1-解析(附源码)
1.前言 ArcGIS 发布的切片服务分为紧凑型切片和传统的分散型切片以及最新ArcGIS por新增的矢量切片.传统的分散型切片面临的问题是文件个数太多,部署拷贝过程十分的耗时,紧凑型切片是对分散型 ...
- ArcGIS紧凑型切片读取与应用2-webgis动态加载紧凑型切片(附源码)
1.前言 上篇主要讲了一下紧凑型切片的的解析逻辑,这一篇主要讲一下使用openlayers动态加载紧凑型切片的web地图服务. 2.代码实现 上篇已经可以通过切片的x.y.z得对应的切片图片,现在使用 ...
- 开源方案搭建可离线的精美矢量切片地图服务-8.mapbox 之sprite大图图标文件生成(附源码)
项目成果展示(所有项目文件都在阿里云的共享云虚拟主机上,访问地图可以会有点慢,请多多包涵). 01:中国地图:http://test.sharegis.cn/mapbox/html/3china.ht ...
- arcgis api 3.x for js 解决 textSymbol 文本换行显示(附源码下载)
前言 关于本篇功能实现用到的 api 涉及类看不懂的,请参照 esri 官网的 arcgis api 3.x for js:esri 官网 api,里面详细的介绍 arcgis api 3.x 各个类 ...
- 读取xml文件转成List<T>对象的两种方法(附源码)
读取xml文件转成List<T>对象的两种方法(附源码) 读取xml文件,是项目中经常要用到的,所以就总结一下,最近项目中用到的读取xml文件并且转成List<T>对象的方法, ...
- ASP.NET程序读取二代身份证(附源码)
原文:ASP.NET程序读取二代身份证(附源码) 一般来说winform应用程序解决这个问题起来时很容易的,web应用程序就麻烦一点了. 这里我说说我的解决思路: 一.你必要有联机型居民身份证阅读器一 ...
- arcgis api 3.x for js 入门开发系列批量叠加 zip 压缩 SHP 图层优化篇(附源码下载)
前言 关于本篇功能实现用到的 api 涉及类看不懂的,请参照 esri 官网的 arcgis api 3.x for js:esri 官网 api,里面详细的介绍 arcgis api 3.x 各个类 ...
随机推荐
- shell工具-sort
sort sort命令是在Linux里非常有用,它将文件进行排序,并将排序结果标准输出 基本语法 sort [选项] [参数] 选项说明 选项 说明 -n 依照数值大小排序 -r 以相反的顺序排序 - ...
- excel冻结窗格
编辑excel时冻结窗格可以大大增加可读性.每个sheet都应该加上. 第一份工作的时候,上司比较严格,还因为这个挨过几次骂.所以这个技巧大家一定要掌握 方法很简单: 选中首行:视图 -- 冻结窗格 ...
- ASP.NET Web API 框架研究 ASP.NET 路由
ASP.NET Web API 如果采用Web Host方式来寄宿,在请求进入Web API 消息处理管道之前,就会用ASP.NET 自身的路由系统根据注册的路由表,解析出当前请求的HttpContr ...
- centos下网口vlan设置
如果要使vlan之间进行通信,我们通常会使用三层交换机或者路由器子接口模式来做.Linux上关于VLAN与Cisco交换机中继连接,也是可以实现其互相之间的通信的. 环境:RHEL 5.2 最小化安装 ...
- spring默认为单例模式
这两天看到一个bug,记录下. 在获取任务的时候,本来任务不是由这个柜员领取的,但是最后跑到那个柜员下面去了. 查看日志,发现两个任务的领取操作很近,日志是穿插着打的. 后来经人指点,说spring初 ...
- xampp 80端口被占用后这么办??解决了
modify port XAMPP: Another web server daemon is already running. 看不懂翻译一下 1. Open the file /opt/lampp ...
- C# 动态创建数据库三(MySQL)
前面有说明使用EF动态新建数据库与表,数据库使用的是SQL SERVER2008的,在使用MYSQL的时候还是有所不同 一.添加 EntityFramework.dll ,System.Data.En ...
- OpenvSwitch端口镜像
OVS上实现端口镜像的基本流程如下: 创建 mirror ,在 mirror 中指定镜像数据源及镜像目的地 将创建的 mirror 应用到 bridge 中 镜像数据源可以通过下面几个选项来指定: s ...
- 【BZOJ3555】 [Ctsc2014]企鹅QQ
BZOJ3555 [Ctsc2014]企鹅QQ Solution 只需要前缀Hash,然后考虑每一段的贡献就好了!!! 代码实现 #include<stdio.h> #include< ...
- 【HDU5730】 Shell Necklace
HDU5730 Shell Necklace 题目大意 已知连续i(1<=i<=n)个贝壳组合成一段项链的方案数a[i],求组合成包含n个贝壳的项链的总方案数. Solution cdq分 ...