国学参考
网站地图 高级搜索 RSS订阅
电信 网通 铁通 美国 收藏本站
首页 | 地理资讯 | 地理文摘 | 环境气象 | 学习园地 | 地理百科 | 地域行政 | 地理资源 | geography | 专题 | 地理论坛
当前位置:首页>地理文摘>技术应用>文章内容
mapx经典例程
来源: 作者:国学 发布时间:1970-01-01






读取属性值 自定义范围专题图 查找对象 紧缩表 使用自定义栅格符号 自定义鼠标 打印地图时的参数设置 测距 自动滚屏 图元的拖拽

如何在MapX下读取属性值

有三种方法:
1. 由Layer对象的KeyField属性来设立要读取属性值的字段名。
接着,由Feature对象的keyValue读取此行的属性值。
2. 将图层加入到Datasets, 由Dataset对象的Value(x,y)属性,通过设置行号,列号来获得属性值。
3. 将图层加入到Datasets,之后由RowValues(ftr)获取整行的值。
Dim ds As MapXLib.Dataset, lyr As MapXLib.layer
Dim ftrs As Features
Dim ftr As Feature
Dim rv As RowValue
Dim rvs As RowValues
Dim DsName As String ‘数据集名
Dim DsRows As Long, DsCols As Long
Dim i As Long, j As Long
Set ds = Formmain.Map1.Datasets.Item(DsName)
Set lyr = ds.layer

Set ftrs = lyr.AllFeatures

DsCols = ds.Fields.Count 中_国_地_理_网
DsCols = DsCols 1
DsRows = ftrs.Count
Grid1.Rows = DsRows 1
Grid1.Cols = DsCols

Grid1.Row = 0
For i = 0 To DsCols - 1
Grid1.Col = i
Grid1.Text = ds.Fields.Item(i 1).Name
Next i
Grid1.Col = DsCols - 1
Grid1.Text = Fkey
lyr.BeginAccess miAccessRead

i = 1
For Each ftr In ftrs
Set rvs = ds.RowValues(ftr)
j = 0
For Each rv In rvs
If Not IsNull(rv.Value) Then Grid1.TextArray(i * DsCols j) = Trim(rv.Value)
j = j 1
Next
Grid1.TextArray(i * DsCols j) = ftr.FeatureKey
i = i 1
Next

lyr.EndAccess miAccessEnd

Set ftr = Nothing
Set ftrs = Nothing
Set ds = Nothing
Set rv = Nothing
Set rvs = Nothing
Set lyr = Nothing
注意:BeginAccess,以及EndAccess可以明显的提高属性读取的速度。回页首

自定义范围专题图

mapx 的专题图用户可以进行完全的定制,下面是自定义范围专题图的例子。
Dim ds As New MapXLib.Dataset
Dim thm As New MapXLib.Theme
Set ds = Formmain.Map1.Datasets(ToolBars.Combo2.Text)
中_国_地_理_网

Set thm = ds.Themes.add(0, aa, aa, False)
thm.Legend.Compact = False
thm.AutoRecompute = False
'thm.ComputeTheme = False
thm.DataMax = 700
thm.DataMin = 100
thm.ThemeProperties.AllowEmptyRanges = True
thm.ThemeProperties.NumRanges = 7
thm.ThemeProperties.DistMethod = miCustomRanges
thm.ThemeProperties.RangeCategories(1).Max = 150
thm.ThemeProperties.RangeCategories(1).Min = 50
thm.ThemeProperties.RangeCategories(2).Max = 250
thm.ThemeProperties.RangeCategories(2).Min = 150
thm.ThemeProperties.RangeCategories(3).Max = 350
thm.ThemeProperties.RangeCategories(3).Min = 250
thm.ThemeProperties.RangeCategories(4).Max = 450
thm.ThemeProperties.RangeCategories(4).Min = 350
thm.ThemeProperties.RangeCategories(5).Max = 550
thm.ThemeProperties.RangeCategories(5).Min = 450
thm.ThemeProperties.RangeCategories(6).Max = 650
thm.ThemeProperties.RangeCategories(6).Min = 550
thm.ThemeProperties.RangeCategories(7).Max = 750
thm.ThemeProperties.RangeCategories(7).Min = 650 中_国_地_理_网
'thm.ComputeTheme = True
thm.AutoRecompute = True
thm.Visible = True 回页首

在mapx中查找对象的方法

两种方式:
1. 使用Find对象的Search方法。在mapx3.5中只能作到完全匹配查找,在MapX4.0中SearchEx方法则可以找到多个匹配的记录,其结果由 FindResult.Matches获取。详细请参看有关Find.SearchEx 方法的文档以及示例。
2. 使用Layer 对象的OBJECT.Search (strWhere)方法。其参数为SQL查询的WHERE子句。例如:
Set ftrs = lyr.Search(Character_Name = 北京市) ;
Set ftrs = lyrUSA.Search(TOTPOP > 1000000)
注意:1。字符串外加两个双引号。2。首先将图层加入数据集Datasets 才能使用查询。
模糊查询最方便的方法是使用第二种方法例如
Set ftrs = lyr.Search(Character_Name like %市) ;模糊查询 回页首

在mapx中如何紧缩表

在Mapx4.51下可以使用LayerInfo 的创建带结构的临时表和新表的功能来完成紧缩:
Set lyr = Formmain.Map1.Layers(ToolBars.combo1.Text)
Set ds = Formmain.Map1.Datasets.add(6, lyr)
'获取被紧缩表的路径及表名
filespec = Formmain.Map1.Layers.Item(ToolBars.combo1.Text).filespec chinageog
layername = lyr.Name '将表临时存放于内存
LayerInfo.Type = 6 'miLayerInfoTypeTemp
LayerInfo.AddParameter TableStorageType, MemTable '临时文件保存在磁盘上还是内存。
LayerInfo.AddParameter Name, lyrpack
LayerInfo.AddParameter Fields, ds.Fields
LayerInfo.AddParameter Features, lyr.AllFeatures
Formmain.Map1.Layers.add LayerInfo, LayerPos
Set LayerInfo = Nothing
'从地图窗口删除原表
Formmain.Map1.Datasets.Remove (ds.Name)
Formmain.Map1.Layers.Remove (lyr.Name)
Formmain.Map1.Refresh
Set lyr = Nothing
Set ds = Nothing
Set lyr = Formmain.Map1.Layers(lyrpack)
Set ds = Formmain.Map1.Datasets.add(6, lyr)
'从磁盘删除原表
Kill filespec 回页首

在mapx中如何使用自定义栅格符号

使用自定义符号首先需要设定style.SymbolType 为miSymbolTypeBitmap,然后指定SymbolBitmapName 为栅格图像名即可。
下面的代码演示了如何在delphi中使用自定义的栅格符号

首先调用自定义工具画点
共3页: 上一页 1 [2] [3] 下一页
[收藏] [推荐] [评论(0条)] [返回顶部] [打印本页] [关闭窗口]
用户名: 新注册) 密码: 匿名评论
评论内容:(不能超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规。
§最新评论:
热点文章
·令人震撼!!摄影师眼中的镜头[1
·俺们这里需要购置GPS接收机(大
·1997年世界编程大赛时的参赛作品
·一名Delphi程序员的开发习惯
·海量影像数据库管理系统解决方案
·用java读DXF文件(ReadWorldmap.j
·网民必备之七种武器
·GIS的发展动态
·数字地球
·可视化税务综合管理系统
·报业管理系统中的GIS应用
·“冲击波”、“冲击波克星”病毒
相关文章
·MapInfo上的GIS系统开发
·地图投影的概念
·MapX中的坐标系定义与转换
·我国基本比例尺地形图分幅与编号
·使用Visual
·如何用Delphi进行ArcObjects的应
·水源保护区划界的遥感与GIS技术
·广西电力工业勘察设计研究院简介
·广西电力工业勘察设计研究院数字
·在职硕士、博士生研究信息发布
·IDL语言简介
·N维重构
Copyright © 2006 国学参考  All Rights Reserved Power by:HeadWind