• 在Delphi下基于MapWinGIS添加和删除图层标注的方法


    unit Form_MainU;
    
    interface
    
    uses
      Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
      Dialogs,MapWinGIS_TLB, DB, Grids, DBGrids, DBTables, OleCtrls, ComCtrls,
      StdCtrls ;
    
    type
      TForm1 = class(TForm)
        Button1: TButton;
        PageControl1: TPageControl;
        TabSheet1: TTabSheet;
        TabSheet2: TTabSheet;
        Map1: TMap;
        Table1: TTable;
        DBGrid1: TDBGrid;
        DataSource1: TDataSource;
        OpenDialog1: TOpenDialog;
        Button2: TButton;
        StatusBar1: TStatusBar;
        Button3: TButton;
        procedure Button1Click(Sender: TObject);
        procedure Map1MouseMove(ASender: TObject; Button, Shift: Smallint; x,
          y: Integer);
        procedure Button2Click(Sender: TObject);
        procedure Button3Click(Sender: TObject);
      private
        { Private declarations }
        AShape:Shapefile;
        MapHanle:integer;
      public
        { Public declarations }
      end;
    
    var
      Form1: TForm1;
    
    implementation
    
    {$R *.dfm}
    
    procedure TForm1.Button1Click(Sender: TObject);
    begin
      self.OpenDialog1.FileName :='*.SHP';
       if self.OpenDialog1.Execute() then
       begin
         AShape:=MapWinGIS_TLB.CoShapefile.Create;
         AShape.Open(self.OpenDialog1.FileName,nil);
         MapHanle:=self.Map1.AddLayer(AShape,true);
         self.Table1.TableName :=ExtractFilePath(self.OpenDialog1.FileName)+'grid.dbf';
         self.Table1.Active:=true;
       end;
    end;
    
    procedure TForm1.Map1MouseMove(ASender: TObject; Button, Shift: Smallint;
      x, y: Integer);
    var
      XX,YY:Double;
    begin
      Self.Map1.PixelToProj(x,y,XX,YY);
      Self.StatusBar1.Panels[0].Text :='X='+formatFloat('#.##',XX);
      Self.StatusBar1.Panels[1].Text :='Y='+formatFloat('#.##',YY);
    end;
    
    procedure TForm1.Button2Click(Sender: TObject);
    var
      i:Integer;
      x,y:Double;
    begin
      for i:=0 to AShape.NumShapes-1 do
      begin
        x:=AShape.Shape[i].Extents.xMin;
        y:=AShape.Shape[i].Extents.yMin;
        Self.Map1.AddLabel(MapHanle,'v',clBlack,x,y,MapWinGIS_TLB.hjCenter);//添加标注
        Self.Map1.Redraw;//图层刷新
      end;
    end;
    
    procedure TForm1.Button3Click(Sender: TObject);
    begin
      self.Map1.ClearLabels(MapHanle);//删除标注
      Self.Map1.Redraw;//刷新
    end;
    
    end.

    MapWinGIS添加标注的速度还是很快的,9万多个标注添加到图层上,等待的时间还是可以忍受的,大概6~9秒钟吧。

  • 相关阅读:
    2.4 自给自足的脚本:位于第一行的#!
    2.3 一个简单的脚本
    2.2 为什么要使用Shell脚本
    JSON 字符串 与 java 对象的转换
    ajax异步提交文件
    jquery选择器
    发现前端框架 bui-min.js
    学习hsf
    Git详解
    java学习材料
  • 原文地址:https://www.cnblogs.com/China3S/p/3527614.html
Copyright © 2020-2023  润新知