从MapX到MapXtreme2004[7]-对Table、Feature等的理解

一、Table
        2004中,Table还是表,可以来自原始的mapinfo表,也可以来自数据库的二维表、文本等。Table的等价概念是feature集合,如下代码:
        (_tempTable as IFeatureCollection).Clear();
        当然,可以通过枚举器,来逐个访问table的行,如下:
         Selection sl =MapInfo.Engine.Session.Current.Selections.DefaultSelection;
         IResultSetFeatureCollection fc=sl[0];        
         IFeatureEnumerator fn=fc.GetFeatureEnumerator();        //IFeatureCollection也有GetFeatureEnumerator
         ListBox1.Items.Clear();
         while(fn.MoveNext())
            if(fn.Current.Geometry.GetType().ToString()=="MapInfo.Geometry.LegacyText")
                 ListBox1.Items.Add(((MapInfo.Geometry.LegacyText)fn.Current.Geometry).Caption);
        当然,用
                foreach(Feature feature in tb)
        也是毫无问题的,因而,table和结果集是等价的。   
二、Feature
        Feature等价于表中的行。只与行有关,而与具体的图元的类型无关。换言之,Feature只是指图元对应的表行,而与图元的属性无关。
        用Feature.Table可以引用到所属的表。
        用Table.TableInfo可以引用到表的结构信息。
        Feature具有的默认列,一般都包括obj,Mi_key,Mi_Style。obj我个人认为就是Feature对应的几何对象。用Feature.Geometry属性可以引用。
        Feature.Geometry的类型是FeatureGeometry,它是各种具体图元(点线面文字...)的父类,Feature.Geometry属性所对应的,其实是具体的类。(我向这个属性赋点对象,发现没错)。
        对Feature的使用,可以通过CataLog的SearchForFeature来查找,如下
            MapInfo.Engine.Session.Current.Catalog.SearchForFeature("Layer1",MapInfo.Data.SearchInfoFactory.SearchWhere("MI_Key='"+strKey+"'") ) 
        由于ID其实并不唯一,所以,较好的查找对象是MI_Key。同时,Catalog还有其他的查找函数,如SearchNearest等。
        加入Feature时,往往需要指定这些基本的信息,有多种加入方法,参见本系列的[5]。
posted @   jetz  阅读(1205)  评论(3编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 上周热点回顾(3.3-3.9)
· AI 智能体引爆开源社区「GitHub 热点速览」
点击右上角即可分享
微信分享提示