亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? mapxapis.pas

?? 此代碼是關(guān)于mapgis的在
?? PAS
?? 第 1 頁 / 共 3 頁
字號:
function GetPathsStr(List:TStrings): string;
var
  i:Integer;
begin
  Result:='';
  if List.Count=0 then Exit;
  Result:=List.Strings[0];
  for i:=1 to List.Count-1 do
    Result:=Result+';'+List.Strings[i];
end;

function SetGeoDictionaryFileSearchPath(List:TStrings):Boolean;
var
  Reg: TRegistry;
begin
  Result:=False;
  Reg:=Tregistry.Create;
  try
    Reg.RootKey :=HKEY_LOCAL_MACHINE;
    if Reg.OpenKey ('SOFTWARE\Mapinfo\MapX\5.0', True) then
    begin
      Reg.WriteString('SearchPaths', GetPathsStr(List));
      Result:=True;
    end;
    Reg.CloseKey;
  finally
    Reg.Destroy;
  end;
end;

function ToComFieldType(Value: TMapFieldType):Integer;
begin
  case Value of
    mftString    : Result:=0;
    mftBCD       : Result:=1;
    mftDateTime  : Result:=2;
    mftInteger   : Result:=3;
    mftSmallint  : Result:=4;
    mftFloat     : Result:=5;
    mftBoolean   : Result:=6;
    else           Result:=-1;
  end;
end;

function ToMapFieldType(Value: Integer):TMapFieldType;
begin
  case Value of
    0: Result:=mftString;
    1: Result:=mftBCD;
    2: Result:=mftDateTime;
    3: Result:=mftInteger;
    4: Result:=mftSmallint;
    5: Result:=mftFloat;
    6: Result:=mftBoolean;
    else
       Result:=mftUnknown;
  end;
end;

function ToMapFieldType(Value: TDataType):TMapFieldType;
begin
  case Value of
    ftUnknown:
      Result:=mftUnknown;
    ftString, ftMemo,
    ftFixedChar, ftWideString:
      Result:=mftString;
    ftSmallint:
      Result:=mftSmallint;
    ftInteger, ftAutoInc, ftWord:
      Result:=mftInteger;
    ftBoolean:
      Result:=mftBoolean;
    ftFloat, ftCurrency:
      Result:=mftFloat;
    ftBCD:
      Result:=mftBCD;
    ftDate, ftTime, ftDateTime:
      Result:=mftDateTime;
    else 
      Result:=mftBinary;
  end;
end;

procedure InitRowValuesFromStruct(Rvs:CMapXRowValues; FromFields:CMapXFields;
  ToDs:CMapXDataset);
var
  i:Integer;
  rv:RowValue;
begin
  Rvs.RemoveAll;
  for i:=1 to FromFields.Count do
  begin
    rv:=CoRowValue.Create;
    rv.Dataset:=ToDs;
    rv.Field:=FromFields.Item[i];
    Rvs.Add(rv);
  end;
end;

function CreateRowValuesFromStruct(FromFields:CMapXFields;
  ToDs:CMapXDataset):CMapXRowValues;
begin
  Result:=CoRowValues.Create;
  InitRowValuesFromStruct(Result, FromFields, ToDs);
end;

function GetFeatureRowValues(Ft:Feature; ds:CMapXDataset):CMapXRowValues;
begin
  Result:=ds.RowValues[Ft];
end;

procedure InitRowValuesFromDataSet(rvs: TMapRowValueList; Fds:CMapXFields);
var
  i:Integer;
  aItem:TMapRowValue;
begin
  rvs.Clear;
  for i:=1 to Fds.Count do
  begin
    aItem:=rvs.Add;
    with aItem.FieldInfo do
    begin
      PhyIndex:=i;
      FieldName:=Fds.Item[i].Name;
      FieldType:=ToMapFieldType(Fds.Item[i].TypeEx);
      if FieldType=mftBCD then
      begin
        Prec:=Fds.Item[i].Precision;
        Scale:=Fds.Item[i].Decimals;
      end
      else if FieldType=mftString then
      begin
        Length:=Fds.Item[i].Width;
      end;
    end;
  end;
end;

procedure InitRowValuesFromDataSet(rvs: TMapRowValueList; RomateDS: TADOQuery);
const
  GeoDataFieldName:string='FeatureData';
  GeoTypeFieldName:string='FeatureType';

  function FieldCanLoad(AField:TField):Boolean;
  begin
    Result:=(AnsiCompareText(AField.FieldName, GeoDataFieldName)=0)or
            (AnsiCompareText(AField.FieldName, GeoTypeFieldName)=0);
  end;

var
  i:Integer;
  aItem:TMapRowValue;
begin
  rvs.Clear;
  with RomateDS do
  begin
    for i:=0 to Fields.Count-1 do
    begin
      if FieldCanLoad(Fields[i]) then
      begin
        aItem:=rvs.Add;
        with aItem.FieldInfo do
        begin
          PhyIndex:=i;
          FieldName:=Fields[i].FieldName;
          FieldType:=ToMapFieldType(Fields[i].DataType);
          Length:=Fields[i].Size;
          Prec:=0;
          Scale:=0;
        end;
      end;
    end;
    Close;
  end;
end;

procedure LoadMapFields(Fds:CMapXFields; MapFields: TMapFieldList);
var
  i:Integer;
  aItem:TMapField;
begin
  MapFields.Clear;
  for i:=1 to Fds.Count do
  begin
    aItem:=MapFields.Add;
    with aItem do
    begin
      PhyIndex:=i;
      FieldName:=Fds.Item[i].Name;
      FieldType:=ToMapFieldType(Fds.Item[i].TypeEx);
      if FieldType=mftBCD then
      begin
        Prec:=Fds.Item[i].Precision;
        Scale:=Fds.Item[i].Decimals;
      end
      else if FieldType=mftString then
      begin
        Length:=Fds.Item[i].Width;
      end;
    end;
  end;
end;

procedure LoadMapFields(RomateDS: TADOQuery; MapFields: TMapFieldList);
const
  GeoDataFieldName:string='FeatureData';
  GeoTypeFieldName:string='FeatureType';

  function FieldCanLoad(AField:TField):Boolean;
  begin
    Result:=(AnsiCompareText(AField.FieldName, GeoDataFieldName)<>0)
            and
            (AnsiCompareText(AField.FieldName, GeoTypeFieldName)<>0);
  end;

var
  i:Integer;
begin
  MapFields.Clear;
  with RomateDS do
  begin
    for i:=0 to Fields.Count-1 do
    begin
      if FieldCanLoad(Fields[i]) then
        MapFields.AddAndInit(Fields[i].FieldName,
                             ToMapFieldType(Fields[i].DataType),
                             Fields[i].Size,
                             0,
                             0);
    end;
    Close;
  end;
end;

function GetTypeDefineStr_MSSQL(aItem:TMapField):string;
begin
  case aItem.FieldType of
    mftString   : Result:='char('+IntToStr(aItem.Length)+')';
    mftInteger  : Result:='int';
    mftSmallint : Result:='smallint';
    mftBoolean  : Result:='bit';
    mftFloat    : Result:='float';
    mftBCD      : Result:='decimal('+IntToStr(aItem.Prec)+','+IntToStr(aItem.Scale)+')';
    mftDateTime : Result:='datetime';
    mftBinary   : Result:='image';
  end;
end;

function GetTypeDefineStr(const ADBType:TDBType; aItem:TMapField):string;
begin
  case ADBType of
    dbtStandard    : Result:=GetTypeDefineStr_MSSQL(aItem);
    dbtAccess      : Result:=GetTypeDefineStr_MSSQL(aItem);
    dbtDBF         : Result:=GetTypeDefineStr_MSSQL(aItem);
    dbtOracle      : Result:=GetTypeDefineStr_MSSQL(aItem);
    dbtParadox     : Result:=GetTypeDefineStr_MSSQL(aItem);
    dbtSQLServer   : Result:=GetTypeDefineStr_MSSQL(aItem);
    dbtInformix    : Result:=GetTypeDefineStr_MSSQL(aItem);
    dbtDB2         : Result:=GetTypeDefineStr_MSSQL(aItem);
    dbtInterBase   : Result:=GetTypeDefineStr_MSSQL(aItem);
    dbtSybase      : Result:=GetTypeDefineStr_MSSQL(aItem);
    dbtSQLAnywhere : Result:=GetTypeDefineStr_MSSQL(aItem);
    else 
  end;
end;

procedure CreateRomateTable(RomateDS: TADOQuery; const ADBType:TDBType;
  const TableName: string; MapFields: TMapFieldList);
const
  GeoDataFieldName:string='FeatureData';
  GeoTypeFieldName:string='FeatureType';
var
  i:Integer;
  aItem:TMapField;
  FieldDefineStr:string;
begin
  {增加圖形字段}
  if MapFields.IndexOf(GeoDataFieldName)=-1 then
  begin
    aItem:=MapFields.Insert(0);
    aItem.FieldName:=GeoDataFieldName;
    aItem.FieldType:=mftBinary;
    aItem.Length:=-1;
  end;

  if MapFields.IndexOf(GeoTypeFieldName)=-1 then
  begin
    aItem:=MapFields.Insert(0);
    aItem.FieldName:=GeoTypeFieldName;
    aItem.FieldType:=mftInteger;
    aItem.Length:=-1;
  end;
  {刪除同名表}
  try
    with RomateDS do
    begin
      Close;
      SQL.Text:='drop table '+TableName;
      ExecSQL;
    end;
  except
  end;
  {創(chuàng)建表}
  with RomateDS do
  begin
    Close;
    SQL.Clear;
    SQL.Add('create table '+TableName+' (');
    for i:=0 to MapFields.ItemCount-1 do
    begin
      FieldDefineStr:=MapFields.Items[i].FieldName+' '+
                      GetTypeDefineStr(ADBType, MapFields.Items[i]);
      if i<MapFields.ItemCount-1 then
        FieldDefineStr:=FieldDefineStr+',';
      SQL.Add(FieldDefineStr);
    end;
    SQL.Add(')');
    ExecSQL;
  end;
end;

procedure GetShapeTypes(Fts:Features; List:TStrings);
var
  i:Integer;
  strtype:string;
begin
  List.Clear;
  for i:=1 to Fts.Count do
  begin
    strtype:=IntToStr(Fts.Item[i].type_);
    if List.IndexOf(strtype)=-1 then
      List.Add(strtype);
  end;
end;

function CanRegionToLine(Fts:Features):Boolean;
Var
  i: Integer;
  newtype: TOLEEnum;
  List: TStringList;
begin
  Result:=True;
  if CanCombine(Fts) then Exit;
  List:=TStringList.Create;
  try
    GetShapeTypes(Fts, List);
    for i:=0 to List.Count-1 do
    begin
      newtype:=StrToInt(List.Strings[i]);
      if (newtype<>miFeatureTypeLine)and(newtype<>miFeatureTypeRegion) then
      begin
        Result:=False;
        Exit;
      end;
    end;
  finally
    List.Free;
  end;
end;

function CanCombine(Fts:Features):Boolean;
var
  i:Integer;
  FirstType:TOLEEnum;
begin
  FirstType:=0;
  for i:=1 to Fts.Count do
  begin
    if i=1 then
      FirstType:=Fts.Item[i].type_
    else if Fts.Item[i].type_<>FirstType then
    begin
      Result:=False;
      Exit;
    end;
  end;
  Result:=True;
end;

function CombineSelectedShapes(MapX:TMapXObject; ALyr:Layer):Feature;
Var
  i: Integer;
  myfts : cmapXfeatures;
  newFeature, Style: Variant;
begin
  Result:=nil;
  myfts := ALyr.Selection.Clone;
  if myfts.Count > 1 then //至少選擇兩個圖形//
  begin
    Style := myfts.Item[1].Style;
    newFeature := MapX.FeatureFactory.CombineFeatures(myfts.Item[1], myfts.Item[2]);
    for i := 3 to myfts.Count do
      newFeature := MapX.FeatureFactory.CombineFeatures(newFeature, myfts.Item[i]);
    newFeature.Style := Style;
    newFeature.Style.LineColor:=clBlue;
    newFeature:=ALyr.AddFeature(newFeature, EmptyParam);
    for i := 1 to myfts.Count do
      ALyr.DeleteFeature(ALyr.Selection.Item[i]);
    ALyr.Selection.ClearSelection;
    ALyr.Selection.Add(newFeature);
    Result:=Feature(IDispatch(newFeature));
  end;
end;

function GetNearestLine(Ft:Feature; const mX, mY, mW: Double; var PartIndex,
  PointIndex:Integer; var pt0:TAny2DPoint):Boolean;
var
  i:Integer;
  pts:Points;
  pt:Point;
  Dist, MinDist:Double;
  bFuncRes:Boolean;
  tmp_PtIndex:Integer;
  tmp_pt0:TAny2DPoint;
begin
  Result:=False;
  PartIndex:=0;
  PointIndex:=0;
  MinDist:=0;
  Pt:=CoPoint.Create;
  try
    for i:=1 to Ft.Parts.Count do
    begin
      pts:=ft.Parts.Item[i];
      Pt.Set_(mX, mY);
      bFuncRes:=PointOnPolyLine(mX, mY, mW, pts, tmp_PtIndex, tmp_pt0, Dist);
      if bFuncRes then
      begin
        Result:=True;
        if PartIndex=0 then
        begin
          MinDist:=Dist;
          PartIndex:=i;
          PointIndex:=tmp_PtIndex;
          pt0:=tmp_pt0;
        end
        else if Dist<MinDist then
        begin
          MinDist:=Dist;
          PartIndex:=i;
          PointIndex:=tmp_PtIndex;
          pt0:=tmp_pt0;
        end;
      end;
    end;
  finally
    Pt:=nil;
  end;
end;

function GetMethodGlobalAddress(Obj: TObject; const MethodName:string;
  var PMethod:TMethod):Boolean;
begin
  PMethod.Data := Pointer(Obj);
  PMethod.Code := Obj.MethodAddress(MethodName);
  Result:=Assigned(PMethod.Code);
end;

end.

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产欧美一区二区在线| 日韩欧美综合一区| 粗大黑人巨茎大战欧美成人| 国产乱子伦视频一区二区三区 | 久久精品久久精品| 日韩精品欧美精品| 六月丁香综合在线视频| 久久福利视频一区二区| 国产成人aaaa| 91免费看片在线观看| 欧美在线999| 7777精品伊人久久久大香线蕉经典版下载 | 日韩一级视频免费观看在线| 91精品福利在线一区二区三区| 91精品国产综合久久久久久| 69精品人人人人| 亚洲精品在线电影| 国产精品色眯眯| 午夜成人在线视频| 国产在线精品一区二区夜色 | av午夜精品一区二区三区| 91蜜桃免费观看视频| 欧美日韩一区二区三区四区| 精品裸体舞一区二区三区| 国产日产欧产精品推荐色| 综合在线观看色| 五月天一区二区| 国产盗摄视频一区二区三区| 精品婷婷伊人一区三区三| 欧美精品一区二区三区高清aⅴ | 久久免费国产精品| 亚洲综合色成人| 国产一区二区在线观看视频| 日本二三区不卡| 久久精品欧美一区二区三区麻豆| 亚洲激情校园春色| 国产福利精品一区| 欧美精品第1页| 亚洲欧洲日韩av| 国产在线麻豆精品观看| 欧美三区免费完整视频在线观看| 精品国产免费人成在线观看| 一区二区三区久久| 国产99久久久国产精品| 欧美一区二区视频在线观看| 国产欧美久久久精品影院| 奇米色一区二区| 精品视频1区2区| 亚洲人精品一区| 丁香五精品蜜臀久久久久99网站| 日韩三级电影网址| 午夜电影久久久| 欧美亚洲综合另类| 亚洲啪啪综合av一区二区三区| 国产河南妇女毛片精品久久久| 91精品福利在线一区二区三区| 夜夜嗨av一区二区三区| 99精品视频在线观看| 国产三级欧美三级| 国产在线不卡一区| 精品国产123| 久久99国产精品免费网站| 91精品婷婷国产综合久久竹菊| 一区二区三区国产豹纹内裤在线 | 色8久久人人97超碰香蕉987| 欧美激情一区二区三区| 国产夫妻精品视频| 久久这里都是精品| 麻豆精品一二三| 日韩欧美国产高清| 久久超级碰视频| 日韩精品一区二区三区swag | 国产成人啪免费观看软件| 久久综合久久综合亚洲| 久久黄色级2电影| 精品国产免费视频| 国产99精品视频| 日韩伦理av电影| 91成人免费电影| 亚洲va欧美va人人爽| 制服视频三区第一页精品| 日韩国产欧美三级| 日韩欧美中文字幕制服| 激情六月婷婷久久| 国产欧美久久久精品影院| 91视频com| 日韩不卡在线观看日韩不卡视频| 日韩欧美激情一区| 成人免费毛片aaaaa**| 亚洲视频在线一区观看| 欧美无乱码久久久免费午夜一区 | 欧美精品一区二区三区一线天视频| 久久精品国产色蜜蜜麻豆| 欧美激情中文字幕| 欧美视频在线一区| 精品一区二区三区久久久| 国产精品美女久久久久久久久久久 | 中文字幕乱码一区二区免费| 国产麻豆视频一区| 综合色中文字幕| 欧美一级高清大全免费观看| 国产成人精品免费| 亚洲乱码精品一二三四区日韩在线 | 99麻豆久久久国产精品免费| 亚洲精品免费在线播放| 777亚洲妇女| 成人激情图片网| 午夜精品福利一区二区蜜股av| 久久久天堂av| 欧美精品v国产精品v日韩精品| 国产一区二区网址| 亚洲综合在线观看视频| 26uuu国产日韩综合| 在线观看视频一区二区| 国产精一品亚洲二区在线视频| 一个色在线综合| 国产三级欧美三级日产三级99 | 激情亚洲综合在线| 一区二区三区资源| 久久精品亚洲麻豆av一区二区| 欧美亚洲国产bt| gogogo免费视频观看亚洲一| 日本欧美一区二区| 亚洲国产视频一区| 欧美高清在线视频| 久久综合久久鬼色中文字| 精品视频在线免费| 91年精品国产| 成人国产精品免费| 国产99精品在线观看| 久久99精品国产.久久久久久| 午夜不卡av在线| 亚洲v中文字幕| 亚洲韩国一区二区三区| 亚洲欧洲中文日韩久久av乱码| 久久久精品国产免大香伊| 日韩欧美一级片| 欧美精品日韩一本| 欧美日韩国产综合一区二区| 91亚洲精品乱码久久久久久蜜桃| 懂色av一区二区三区免费看| 国产成人av电影在线播放| 久久99国内精品| 精品无码三级在线观看视频| 欧美96一区二区免费视频| 日韩二区三区在线观看| 午夜伊人狠狠久久| 日日夜夜精品视频天天综合网| 亚洲午夜在线电影| 亚洲国产精品久久艾草纯爱| 亚洲一二三四在线| 偷窥国产亚洲免费视频| 亚洲成人动漫在线观看| 天堂精品中文字幕在线| 日韩国产欧美视频| 激情文学综合插| 东方欧美亚洲色图在线| 91看片淫黄大片一级| 欧日韩精品视频| 3atv一区二区三区| 欧美videossexotv100| 久久夜色精品一区| 欧美高清在线视频| 亚洲最新视频在线播放| 天天av天天翘天天综合网| 日韩电影在线观看一区| 美女一区二区视频| 成人免费三级在线| 在线精品视频一区二区三四| 欧美久久久一区| 久久免费电影网| 亚洲男帅同性gay1069| 婷婷久久综合九色综合伊人色| 蜜桃视频一区二区| av动漫一区二区| 日韩一级免费观看| 亚洲国产高清在线观看视频| 亚洲精品视频免费看| 男人的j进女人的j一区| 成人一区二区三区在线观看| 在线观看日韩高清av| 久久亚洲影视婷婷| 亚洲精品成人悠悠色影视| 久久se精品一区精品二区| 91在线看国产| 精品久久99ma| 午夜天堂影视香蕉久久| 丁香六月综合激情| 日韩天堂在线观看| 一区二区三区四区不卡视频| 狠狠色狠狠色综合日日91app| 97久久超碰精品国产| 日韩精品一区二区三区视频播放 | 国产精品久久午夜| 日本一区中文字幕| 91极品视觉盛宴| 国产午夜久久久久| 蜜桃视频一区二区三区| 欧美午夜精品一区| 国产精品乱人伦|