以MapXtreme为例说明图片切割算法:
1、定义地图范围、地图视野、输出图片大小。所要切割的地图范围。
int x1 = int.Parse(txtX1.Text);
int x2 = int.Parse(txtX2.Text);
int y1 = int.Parse(txtY1.Text);
int y2 = int.Parse(txtY2.Text);
double startzoom = System.Convert.ToDouble(txtStartZoom.Text);
int mapWidth = int.Parse(txtWidth.Text);
int mapHeight = int.Parse(txtHeight.Text);
2、设置地图视野。
map.Zoom = new MapInfo.Geometry.Distance(startzoom ,MapInfo.Geometry.DistanceUnit.Mile);
3、计算输出图片的边长对应的地理长度。
MapInfo.Geometry.DRect rect = map.Bounds;
double dx = rect.x2 - rect.x1;
double dy = rect.y2 - rect.y1;
4、循环输出当前视野下的地图图片。
MapInfo.Mapping.MapExport mapExport = new MapInfo.Mapping.MapExport(map);
double tmpy = y1;
int row = 0;
while (tmpy < y2)
{
row ++;
double tmpx = x1;
int col = 0;
while(tmpx < x2)
{
col ++;
rect = new MapInfo.Geometry.DRect(tmpx,tmpy,tmpx+dx,tmpy+dy);
map.SetView(rect,map.GetDisplayCoordSys());
MakePic(mapExport,row,col);
tmpx += dx;
}
tmpy += dy;
}
5、MakePic是地图输出函数。
int mapWidth = int.Parse(txtWidth.Text);
int mapHeight = int.Parse(txtHeight.Text);
mapExport.ExportSize = new MapInfo.Mapping.ExportSize(mapWidth, mapHeight);
mapExport.Format = MapInfo.Mapping.ExportFormat.Png;
mapExport.Border = MapInfo.Mapping.ExportBorder.Off;
if(!System.IO.Directory.Exists(txtPicPath.Text + @"/map"))
{
System.IO.Directory.CreateDirectory(txtPicPath.Text + @"/map" );
}
string filename = txtPicPath.Text + @"/map/" + row.ToString() + "-" + col.ToString() + ".PNG";
mapExport.Export(filename);