Delphi

本类阅读TOP10

·分布式网络考试系统原型分析及实现
·游戏外挂设计技术探讨①
·使用HOOK随心监视Windows
·Delphi 水晶报表打包解决
·试题库开发中非文本数据的处理
·如何将几个DBGRID里的内容导入同一个EXCEL表中....的问题
·如何使用Delphi设计强大的服务器程序
·工人线程中关闭窗体的实现
·用DLL方式封装MDI子窗体。
·支持XP下托盘栏气球提示的托盘单元

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
从数据库绘制MapX地图

作者:未知 来源:月光软件站 加入时间:2005-2-28 月光软件站

从数据库绘制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按照以上步骤我们可以直接将数据库中的数据在地图上表现出来,当然我们只是表现了特征点,并没有表现那些区域等其他东西,其他东西应该也可以,不过我用不到,哈哈。。
 
二○○四年四月十五日



相关文章

相关软件