zoukankan      html  css  js  c++  java
  • 从MapX到MapXtreme2004[2]-图层操作

    Mapx中基本的图层操作还是比较简单的,集中在对Layers和Layer的处理上,对别的没有太多要求。

      在MapXtreme中,要完成类似功能,发生了一点变化,如下:
      1、图层的显示
      在MapXtreme中,图层的显示控制发生了奇怪的变化,有一个IsVisible属性,但它是只读的,不能通过它来改变图层的显示。要控制图层的显示与隐藏,可以通过设置Layer.Enable来控制。
      2、图层的动态添加
      代码如下:
            Catalog _catalog=MapInfo.Engine.Session.Current.Catalog;
            MapInfo.Data.Table _tempTable=null;
            Map _map=MapControl1.Map ;   

            TableInfo ti = TableInfoFactory.CreateTemp("临时"); 
            _tempTable = _catalog.CreateTable(ti);
            _map.Layers.Insert(0, new FeatureLayer(_tempTable));

      可以看出:加图层实际就是加表;Catalog对象统管表的加载以及列举;
      查帮助还可以了解:表信息其实还可以包括表的类型和坐标系。类型是指原生表,文本,access ...
      上面的ti也可以这样取得,但是,上面的表默认是MeMTab,应该是内存中的吧。

            CoordSys cs=_map.GetDisplayCoordSys();
            TableInfo ti = TableInfoFactory.CreateTemp("临时",MapInfo.Data.TableType.Native,cs);

      以上只能算是学习心得,肯定错误百出,但总比什么都没有强,至少能够提供一个思路。至于表如何保存,Mapx中的动画层和标签层在MapxTreme中如何对应,因为暂时不急用,先放着。

            4、根据名称打开图层
                MapInfo.Engine.Session.Current.Catalog.GetTable(TableName)

  • 相关阅读:
    Oracle手工建库
    php如何在某个时间上加一天?一小时? 时间加减
    JavaScript:this是什么?
    ping广播地址会如何(转)
    用CSS3实现文字描边
    vue二十七:vue基础之过滤器
    vue二十六:vue基础之vue生命周期
    vue二十五:vue基础之单个元素过渡和多个元素过渡
    vue二十五:vue基础之slot插槽和具名插槽
    vue二十四:vue基础之动态组件
  • 原文地址:https://www.cnblogs.com/jetz/p/196777.html
Copyright © 2011-2022 走看看