Welcome

首页 / 软件开发 / Delphi / 从数据库绘制MapX地图

从数据库绘制MapX地图2010-10-311、在中建立如下的表用于存储坐标:

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、按照以上步骤我们可以直接将数据库中的数据在地图上表现出来,当然我们只是表现了特征点,并没有表现那些区域等其他东西,。