1、MapX应用讲义一、加载地图数据 1、 TAB 的数据分为两种数据:地图数据(Layers)、属性数据(Datasets)。关系:不可分割的一个数据集的两部分. 2、 数据加载:GST 文件由 GeosetManager40.exe程序生成。在程序使用 gsT文件:Map1.Geoset=Filepath+FileName 3、 问题:GST 文件加载后,只是默认将地图数据加载,属性数据另外需要使用单独的命令进行加载,否则对属性数据的操作全部非法。加载:Map1.Datasets.ADD 属性数据集名称4、 另一种加载方式:使用 LayerInfo 对象,这种方式下加载地图数据源的地图集和属性
2、集均可直接使用。示例: dim LayerInfo as MapXLib.LayerInfo dim Lyr as Mpxlib.layer LayerInfo.Type = miLayerInfoTypeTab 加载表的类型 LayerInfo.AddParameter “FileSpec“, FilePath + LayerName + “.TAB“ 加载表的全路径名 LayerInfo.AddParameter “NAME“, LayerName 地图集的别名 LayerInfo.AddParameter “AutoCreateDataset“, 1 是否加载属性数据集 LayerInf
3、o.AddParameter “datasetname“, LayerName 属性数据集别名 MainMap.Layers.Add LayerInfo 加载到指定的 MapX对象中,立即可直接使用 5、 第三种加载数据方式:GST 文件+ LayerInfo 方式。示例: 使用两个 MapX对象:MainMap、TempMap TempMap.Geoset=GST文件 MainMap.geoset=” TempMap.Refresh For I=1 to TempMap.Layers.Count FileName=TempMap.Layers.Item(I).Filespec 直接引用 La
4、yerInfo方式加载地图数据到 MainMap Next 二、创建地图对象 必要:创建地图对象,必须使用 FeatureFactory对象 1、 创建一个点对象 点对象有一个坐标点(X,Y),点对象变量是 Point类型,点对象的样式(Style)是符号样式。 Dim Pnt AS MapXLib.Point Dim FeaFac AS MapXLib.FeatureFactory Dim Lyr AS MapXLib.Layer Dim Ftr AS MapXLib.Feature Dim NewStyle AS MapXLib.Style 绑定 SET Lyr=MainMap.Layer
5、s.Item(LayerName) SET FeaFac=mainmap.featurefactory 设置点对象样式 With NewStyle .SymbolType = miSymbolTypeBitmap .SymbolBitmapSize = 24 .SymbolBitmapTransparent = False .SymbolBitmapName = “YIEL2-32.BMP“ End With Mainmap.AutoRedraw=False 禁止自动刷新 Lyr.Editable=True 置当前图层为可写状态 创建点对象 pnt.set X1,Y1 添加进当前图层 Set
6、Ftr=FeaFac. CreateSymbol (Pnt,Newstyle) 创建符号 Set Ftr=FeaFac. CreateSymbol (Pnt,MainMap.DefaultStyle) 添加 Lyr.AddFeature Ftr Lyr.Refresh Mainmap.AutoRedraw=True Lyr.Editable=False 释放 SET Pnt = Nothing SET FeaFac = Nothing SET Lyr = Nothing SET Ftr = Nothing 以上代码放在 MapX的 ToolUsed事件下 单独修改某个图元的样式:SET Ftr
7、.Style=NewStyle,再用 Update 即可 2、 创建一个线矩形 Dim Pnts AS MapXLib.Points With NewStyle .LineColor=Rgb(0, 0,255) End With 第一个点 Pnt.Set X1,Y1 Pnts.add Pnt 第二个点 Pnt.Set X2,Y1 Pnts.add Pnt 第三个点 Pnt.Set X2,Y2 Pnts.add Pnt 第四个点 Pnt.Set X1,Y2 Pnts.add Pnt 第五个点 Pnt.Set X1,Y1 Pnts.add Pnt 创建线矩形 SET Ftr=FeaFac.Crea
8、teLine(Pnts,NewStyle) Lyr.AddFeature Ftr Lyr.Refresh 3、 上面创建对象中存在的问题:并未对其数据数据进行赋值 创建对象的同时创建其数据集合 Dim Pnt AS MapXLib.Point Dim FeaFac AS MapXLib.FeatureFactory Dim Lyr AS MapXLib.Layer Dim Ftr AS MapXLib.Feature Dim NewStyle AS MapXLib.Style Dim ds AS MapXLib.Dataset Dim Flds AS MapXLib.Fields 绑定 SET
9、 Lyr=MainMap.Layers.Item(LayerName) SET ds=Lyr.Datasets.Item(1) Set Flds=ds.Fields SET FeaFac=mainmap.featurefactory 设置点对象样式 With NewStyle .SymbolType = miSymbolTypeBitmap .SymbolBitmapSize = 24 .SymbolBitmapTransparent = False .SymbolBitmapName = “YIEL2-32.BMP“ End With Mainmap.AutoRedraw=False 禁止自
10、动刷新 Lyr.Editable=True 置当前图层为可写状态 创建点对象 pnt.set X1,Y1 创建图形 Set Ftr=FeaFac. CreateSymbol (Pnt,Newstyle) 创建符号 Set Ftr=FeaFac. CreateSymbol (Pnt,MainMap.DefaultStyle) 设置属性 For I=1 to Flds.Count Lyr.KeyFields=Flds.Item(i).Name Ftr.KeyValue=ValueStr(I) 这里并没有对字段类型进行判断 Next 另外一种方法:使用 RowValues和 RowValue对象 添
11、加 Lyr.AddFeature Ftr Lyr.Refresh Mainmap.AutoRedraw=True Lyr.Editable=False 释放 SET Pnt = Nothing SET FeaFac = Nothing SET Lyr = Nothing SET Ftr = Nothing SET ds = Nothing SET Flds = Nothing 4、 创建表 (1) 临时表: A、用 MainMap.Layers.CreateLayer方法创建临时表。但这个临时表只有一个字段:GeoName( Char 24)。程序运行过程中该表存放位置为系统临时文件夹下 B、
12、使用 LayerInfo对象创建临时表,可以指定字段。示例: Dim Lyr As MapXLib.Layer Dim LayerInfo As New MapXLib.LayerInfo Dim Flds As New MapXLib.Fields 字段定义 Flds.AddStringField “ID“, 12 Flds.AddStringField “Name“, 50 Flds.AddNumericField “Deptch“, 12, 2 Flds.AddIntegerField “Length“ LayerInfo.Type = miLayerInfoTypeTemp Layer
13、Info.AddParameter “FileSpec“, FileName LayerInfo.AddParameter “NAME“, LayerName LayerInfo.AddParameter “Fields“, Flds Set Lyr = MainMap.Layers.Add(LayerInfo, 1) Set Lyr = Nothing Set LayerInfo = Nothing (2) 创建永久表 Dim Lyr As MapXLib.Layer Dim LayerInfo As New MapXLib.LayerInfo Dim Flds As New MapXLib
14、.Fields Flds.AddStringField “ID“, 12 Flds.AddStringField “Name“, 50 Flds.AddNumericField “Deptch“, 12, 2 Flds.AddIntegerField “Length“ LayerInfo.Type = miLayerInfoTypeNewTable LayerInfo.AddParameter “FileSpec“, FilePath + “ + FileName LayerInfo.AddParameter “NAME“, LayerName LayerInfo.AddParameter “
15、Fields“, Flds Set Lyr = MainMap.Layers.Add(LayerInfo, 1) Set Lyr = Nothing Set LayerInfo = Nothing 5、 创建工具句柄 系统已经定义工具句柄都以整数(包括 16进制)常数存在,句柄号大于 1000和小于 12基本都为系统使用。 A. 定义常数:必须为全局变量 Global Const CreateSymbolTool = 13 创建节点 Global Const CreateLineTool = 15 创建管线 Global Const InfoTipTool = 16 信息工具 Global C
16、onst MoveFeature = 17 移动地图 Global Const ScaleDistanceTool = 18 测量两点间的距离 B. 使用 CreateCustomTool创建新的工具句柄: MainMap.CreateCustomTool CreateSymbolTool, miToolTypePoint, miSymbolCursor MainMap.CreateCustomTool CreateLineTool, miToolTypeLine, miCrossCursor MainMap.CreateCustomTool InfoTipTool, miToolTypePo
17、int, miCrossCursor MainMap.CreateCustomTool MoveFeature, miToolTypeLine, miPanCursor MainMap.CreateCustomTool ScaleDistanceTool, miToolTypeLine, miPanCursor C. 如何使用? 在 Map对象的 ToolUsed事件的 ToolNum参数为当前所激活的工具 使当 前操作指向某行为:MainMap.CurrentTool=工具句柄号,如放大:MainMap.CurrentTool=miZoomInTool,移动图元:MainMap.Curren
18、tTool=MoveFeature 操作具体的工具句柄时,执行该捕捉到的工具句柄的代码: 在 ToolUsed事件中: Select Case ToolNum Case MoveFeature 执行代码 End Select 删除图元:Lyr.DeleteFeature Ftr 三、查询 1、 属性查找。Find、Search 方法:注意的是 Find方法只支持 TAB表文件,不支持空间数据表。 Find :与 FoxPro中 Locate定位命令想类似。 Search:支持 SQL语句。写法:仅指 SQL语句的 WHERE 部分,且 From语句中只能有一个表仅对单表进行操作:Select
19、* from LayerName WHERE ID LIKE “%北京%” 示例: A、查找 Dim Ftrs AS MapXlib.Features 图元集合 SET Ftrs=Lyr.Search(“ID LIKE “%北京%”) For I=1 to Ftrs.Count 执行语句 Next B、高亮显示 Lyr.Selection.Replace Ftrs 将当前查询所得的结果集全部高亮显示(隐含执行:Lyr.ClearSelection语句)加入 selection集合 闪烁:不能用 Selection,否则会对整个屏幕进行整个刷新(抖动)。使用更新 Style的方法进行选定图元的闪
20、烁。 记载图元的老样式:Set Oldsytle=Ftr.Style Lyr.Selection.Add Ftrs 将当前查询所得的结果集添加到已有的结果集中,再全部高亮显示 C、对查询的结果集进行属性修改 示例程序:完成的是 Professional中信息工具功能 Dim ds AS MapXlib.Dataset Dim Flds AS MapXlib.Fields Dim Ftr AS MapXlib.Feature Set Lyr=MainMap.Layers.Item(LayerName) Set ds=Lyr.Datasets.item(1) Set Flds=ds.Fields
21、查找 SET Ftrs=Lyr.Search(“ID LIKE “%北京%”) If Ftrs.count=0 then exit sub 读取属性值 For I=1 to Ftrs.Count Set Ftr=Ftrs.Item(I) For j=1 to Flds.count FldsName(J)=Flds.Item(J).Name 字段列表 Lyr.KeyField=FldsName(J) ValueStr(I,J)=Ftr.KeyValue 值列表 Next Next 修改属性 MainMap.AuyoRedraw=False Lyr.Editable=True For j=1 to
22、 Flds.count Lyr.KeyField= Flds.Item(J).Name Ftrs.Item(j).KeyValue =ValueStr(J) 更新值列表 Ftrs.Item(j).Update True Next Lyr.Refresh Lyr.Editable=False MainMap.AuyoRedraw=True 修改样式 Dim NewStyle AS MapXlib.Style With NewStyle 设置样式 End With MainMap.AuyoRedraw=False Lyr.Editable=True For i=1 to Ftrs.count Se
23、t Ftr =Ftrs.Item(I) SET Ftr.Style=NewStyle 更新样式 Ftr.Update True Next Lyr.Refresh Lyr.Editable=False MainMap.AuyoRedraw=True 2、 空间查找 点查找:SearchAtPoint,结果集为 Features类型 Dim Pnt AS MapXlib.Point Pnt.Set X,Y Set Ftrs=Lyr.SearchAtPoint(Pnt,miSearchResultAll) For I=1 to Ftrs.Count 执行语句 Next 注意:点查找时,一般情况下结果
24、集在一个以上的图层都存在。所以取值时应分别提取 园查找:在临时图层上画一个不保存的圆,然后查找被这个圆所包含的所有图层的图元对象。 Dim Pnt AS MapXlib.Point Dim TempCir AS MapXlib.Feature Dim FeaFac AS MapXLIB.featurefactory Pnt.Set X,Y Set tempcir=FeaFac.CreateCircularRegion(miCircleTypeMap ,Pnt,1, MainMap.MapUnit,) miSearchTypeCentroidWithin :中心点包含 miSearchTypeP
25、artiallyWithin :部分包含 miSearchTypeEntirelyWithin :全部包含 Set Ftrs=Lyr.SearchWithinFeature (TempCir, miSearchTypePartiallyWithin) For I=1 to Ftrs.Count 执行语句 Next SET Pnt =Nothing set TempCir =Nothing set FeaFac =Nothing 3、 相交 判断两个图元是否有交点以及交点坐标信息。 (1)判断是否相交 IF Lyr.IntersectionTest( ftr1, ftr2, miIntersec
26、tFeature ) THEN 交点 END IF (2)获取相交点坐标信息 交点 Dim Ftr AS MapXlib.Feature SET Ftr=MainMap.FeatureFactory. IntersectFeatures(Ftr1,Ftr2) 交点坐标信息 For J=1 to Ftr.parts.item(1).count X1= Ftr.parts.item(1).Item(J).X Y1= Ftr.parts.item(1).Item(J).Y Next 4、 测距 使用 Map对象的 Distance方法。如何测量任意多边形的周长? 使用累加的方法,还要使用图元节点集合
27、。 DistanceValue=0 第一个点 Pnt.Set Ftr.Parts.Item(1).Item(1).X, Ftr.Parts.Item(1).Item(1).Y For j=2 TO Ftr.Parts.Item(1).Count 累加 X1= Ftr.Parts.Item(1).Item(j-1).X Y1= Ftr.Parts.Item(1).Item(j-1).Y X2= Ftr.Parts.Item(1).Item(j).X Y2= Ftr.Parts.Item(1).Item(j).Y DistanceValue = DistanceValue +MainMap.Dis
28、tance(X1, Y1, X2, Y2) Next 多边形周长 Msgbox DistanceValue+” ”+MainMap.MapUnit 四、对象编辑 (1)、对属性的编辑 主要使用 Fields对象。示例: Dim Flds AS MapXlIB.Fields 修改当前图层的每一个字段 For J=1 to Flds.Count Lyr.KeyField= Flds.Item(j).Name 使当前图层指向 J字段 更新当前图元的 J字段值 Ftr.KeyValue=NewValueStr(J) Ftr.Update True 并未写入硬盘 Next Lyr.Refresh 保存修
29、改到硬盘 (2)、移动地图 首先创建一个移动工具句柄 MainMap.CreateCustomTool MoveFeature, miToolTypeLine, miPanCursor 在 Map对象的 ToolUsed事件的 ToolNum参数为当前所激活的工具 捕捉 MoveFeature工具句柄 传过来的参数:X1,Y1,X2,Y2 Select case ToolNum . Case MoveFeature Dim Lyr AS MapXlib.Layer Dim Ftr AS MapXlib.Feature Dim Ftrs AS MapXlib.Features Dim Xe,Ye
30、 AS Double 坐标偏移量 Xe=X2-X1 Ye=Y2-Y1 Set Lyr=Mainmap.Layers.Item(LayerName) Set Ftrs=Lyr.Selection.Clone 将当前图层中选定的集合复制到 Ftrs变量中 MainMap.AutoRedraw=False Lyr.Editable=True For J=1 to Ftrs.Count Set Ftr=Ftrs.Item(J) Ftr.Offset Xe,Ye Ftr.Update True Next Lyr.Refresh Lyr.Editable=False MainMap.AutoRedraw=True