从数据库绘制MapX地图

类别:Delphi 点击:0 评论:0 推荐:
从数据库绘制MapX地图 主题:MapX Delphi数据库 地图 Layer Style Font   本文将带你从数据库中取数据在MapX上画出来。 1、在数据库中建立如下的表用于存储坐标: ID            integer     //唯一编号 Name      string      //名称(标签) X             float //地图坐标X Y             float //地图坐标Y 假设这个表命名为XUnit 2、编辑MapX地图,添加一个新的Layer,定义好你希望将来添加图层显示样式,然后设置这个图层不可见、不可编辑,此图层名称假设为“企事业单位”。 3、在你的程序中添加MapX控件,命名为Map1 4、在窗口中添加BDE或者ADO组件并连接到你的数据库,假设你添加了AdoConnection1和ADOTable1并且把他们的相关属性都设好了ADOTable1中应该是上述表中的全部内容。 5添加按钮,并在按钮中添加Click时间代码如下: procedure TForm1.Button1Click(Sender: TObject); var   lyr : layer;//层   fts : feature;//特征   pt : point;//点   mstyle : style;//样式   str : string;//特征标注   x,y : double; begin   lyr := Map1.Layers.CreateLayer('tempAnimate', EmptyParam,1,EmptyParam, EmptyParam);        //在Map1中创建一个Layer   Map1.Layers.AnimationLayer := lyr;//设为当前层     lyr.Editable := true;//可编辑   pt := copoint.Create;   mstyle := costyle.Create;   mstyle := map1.Layers.item('企事业单位').AllFeatures.Item(1).Style;//此处获取在层“企事业单位”中存储的特征样式   lyr.Style := map1.Layers.item('企事业单位').Style;//层的样式   lyr.LabelProperties.Style := map1.Layers.item('企事业单位').LabelProperties.Style;//标签样式   adotable1.First;   while not adotable1.Eof do   begin     X := adotable1.fieldbyname('X').AsFloat ;     y := adotable1.fieldbyname('Y').AsFloat;     str := adotable1.fieldbyname('Name').AsString;     pt.Set_(x,y);     fts := map1.FeatureFactory.CreateSymbol(pt,mstyle);//创建特征     fts.KeyValue := str;//标注     lyr.AddFeature(fts,emptyparam);//将特征添加到层     adotable1.Next;   end;   lyr.AutoLabel := true;//自动标注   lyr.Visible := true;//可见   lyr.ZoomMin := 0;//缩放范围   lyr.ZoomMax := 77; end; 6按照以上步骤我们可以直接将数据库中的数据在地图上表现出来,当然我们只是表现了特征点,并没有表现那些区域等其他东西,其他东西应该也可以,不过我用不到,哈哈。。   E-mail:[email protected] 二○○四年四月十五日

本文地址:http://com.8s8s.com/it/it5094.htm