VB+MapX
上传用户:anyunliang
上传日期:2022-04-05
资源大小:2856k
文件大小:1k
源码类别:

GIS编程

开发平台:

Visual Basic

  1. 有三种方法:
  2. 1. 由Layer对象的KeyField属性来设立要读取属性值的字段名。
  3. 接着,由Feature对象的keyvalue读取此行的属性值。
  4. 2. 将图层加入到Datasets, 由Dataset对象的value(x,y)属性,通过设置行号,列号来获得属性值。
  5. 3. 将图层加入到Datasets,之后由Rowvalues(ftr)获取整行的值。
  6. Dim ds As MapXLib.Dataset, lyr As MapXLib.layer
  7. Dim ftrs As Features
  8. Dim ftr As Feature
  9. Dim rv As Rowvalue
  10. Dim rvs As Rowvalues
  11. Dim DsName As String ‘数据集名
  12. Dim DsRows As Long, DsCols As Long
  13. Dim i As Long, j As Long
  14. Set ds = Formmain.Map1.Datasets.Item(DsName)
  15. Set lyr = ds.layer
  16. Set ftrs = lyr.AllFeatures
  17. DsCols = ds.Fields.Count
  18. DsCols = DsCols + 1
  19. DsRows = ftrs.Count
  20. Grid1.Rows = DsRows + 1
  21. Grid1.Cols = DsCols
  22. Grid1.Row = 0
  23. For i = 0 To DsCols - 1
  24. Grid1.Col = i
  25. Grid1.Text = ds.Fields.Item(i + 1).Name
  26. Next i
  27. Grid1.Col = DsCols - 1
  28. Grid1.Text = "Fkey"
  29. lyr.BeginAccess miAccessRead
  30. i = 1
  31. For Each ftr In ftrs
  32. Set rvs = ds.Rowvalues(ftr)
  33. j = 0
  34. For Each rv In rvs
  35. If Not IsNull(rv.value) Then Grid1.TextArray(i * DsCols + j) = Trim(rv.value)
  36. j = j + 1
  37. Next
  38. Grid1.TextArray(i * DsCols + j) = ftr.FeatureKey
  39. i = i + 1
  40. Next
  41. lyr.EndAccess miAccessEnd
  42. Set ftr = Nothing
  43. Set ftrs = Nothing
  44. Set ds = Nothing
  45. Set rv = Nothing
  46. Set rvs = Nothing
  47. Set lyr = Nothing