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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? mapxapis.~pas

?? 此代碼是關于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;
  {創建表}
  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.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美精品一区二区三区视频| 成人精品鲁一区一区二区| 久久精品亚洲精品国产欧美| 色久综合一二码| 国产九色精品成人porny| 亚洲一二三四区不卡| 亚洲精品一区二区三区99| 欧美亚洲动漫制服丝袜| 国产91精品露脸国语对白| 无吗不卡中文字幕| 亚洲少妇中出一区| 国产农村妇女精品| 日韩欧美一级二级三级久久久| 色香蕉成人二区免费| 国产91精品精华液一区二区三区| 免费成人在线观看视频| 一级做a爱片久久| 国产精品久久久久aaaa| 亚洲精品一区二区精华| 日韩欧美色电影| 欧美精品乱码久久久久久按摩| 91在线精品一区二区三区| 国产成人三级在线观看| 精品无码三级在线观看视频| 天堂影院一区二区| 亚洲一区在线观看网站| 亚洲日本中文字幕区| 亚洲国产成人午夜在线一区| 久久久久国色av免费看影院| 欧美videossexotv100| 欧美日韩1区2区| 欧美精品一二三| 欧美日韩精品一区二区| 欧美视频在线观看一区| 欧美亚洲动漫制服丝袜| 欧美私人免费视频| 欧美美女黄视频| 欧美精品乱码久久久久久 | 91免费看`日韩一区二区| 国产成人精品免费看| 国产精品自产自拍| 国产成人午夜99999| 国产宾馆实践打屁股91| 高清在线成人网| 成人一区二区视频| caoporen国产精品视频| 99精品热视频| 欧美视频一区二区三区在线观看 | 欧美日韩夫妻久久| 欧美日韩激情一区二区三区| 欧美亚洲国产一区二区三区| 欧美高清dvd| 欧美xxxxx牲另类人与| 久久久三级国产网站| 国产亚洲精品久| 成人欧美一区二区三区黑人麻豆| 亚洲桃色在线一区| 亚洲国产欧美另类丝袜| 日韩av中文字幕一区二区| 美女www一区二区| 精品一区二区在线播放| 成人午夜电影小说| 91蝌蚪porny九色| 欧美片网站yy| 久久久午夜精品理论片中文字幕| 国产精品久99| 性做久久久久久久久| 蜜臀av一区二区| av亚洲产国偷v产偷v自拍| 欧美色偷偷大香| 欧美大片拔萝卜| 综合色中文字幕| 日韩影视精彩在线| 国产黄人亚洲片| 在线观看成人免费视频| 日韩欧美国产一区在线观看| 中文字幕免费在线观看视频一区| 亚洲综合自拍偷拍| 美女尤物国产一区| 91麻豆福利精品推荐| 欧美一区二区精美| 亚洲欧美在线高清| 日本成人在线看| eeuss鲁片一区二区三区在线看| 正在播放亚洲一区| 国产精品久久久久aaaa樱花| 日韩电影在线一区二区三区| www.激情成人| 成人av电影免费在线播放| 日韩一区二区三区免费观看| 国产精品理伦片| 美日韩一区二区| 在线观看国产91| 亚洲国产精品成人综合色在线婷婷| 亚洲综合色噜噜狠狠| 国产大陆亚洲精品国产| 欧美精品在线视频| 亚洲欧美日韩小说| 黑人巨大精品欧美黑白配亚洲| 在线亚洲免费视频| 国产日韩一级二级三级| 日本大胆欧美人术艺术动态| 97精品视频在线观看自产线路二| 精品久久久久久亚洲综合网| 亚洲一区二区欧美| 成人中文字幕电影| 精品盗摄一区二区三区| 午夜在线成人av| 一本大道av一区二区在线播放| 精品久久久久久久一区二区蜜臀| 亚洲第一福利视频在线| 粉嫩绯色av一区二区在线观看 | 18欧美亚洲精品| 国产又黄又大久久| 欧美一区二区三区精品| 亚洲尤物在线视频观看| av电影天堂一区二区在线观看| 精品卡一卡二卡三卡四在线| 秋霞成人午夜伦在线观看| 欧美探花视频资源| 亚洲一区二区三区四区的| 成人18精品视频| 欧美激情中文字幕| 国产乱人伦精品一区二区在线观看 | 国产精品国产三级国产三级人妇| 蜜桃一区二区三区在线| 欧美日韩国产一区二区三区地区| 亚洲少妇屁股交4| 99在线视频精品| 国产精品毛片a∨一区二区三区| 国产激情91久久精品导航 | 亚洲一区中文在线| 色老综合老女人久久久| 亚洲欧美综合色| 色伊人久久综合中文字幕| 亚洲人成7777| 欧洲精品中文字幕| 一区二区三区欧美日| 欧美亚洲国产一区在线观看网站| ...av二区三区久久精品| 99热精品国产| 亚洲一区二区三区精品在线| 欧美日韩免费在线视频| 婷婷久久综合九色国产成人| 欧美精品丝袜久久久中文字幕| 五月激情六月综合| 日韩精品一区二| 国产91丝袜在线观看| 国产精品夫妻自拍| 91麻豆6部合集magnet| 亚洲一区二区视频在线| 欧美日韩高清一区| 激情成人午夜视频| 国产欧美综合色| 91美女片黄在线观看91美女| 亚洲美女视频在线观看| 欧美日韩免费观看一区二区三区| 日韩高清国产一区在线| 欧美精品一区男女天堂| 国产suv精品一区二区三区| 亚洲欧美在线视频| 欧美午夜免费电影| 蜜臀久久久久久久| 国产夜色精品一区二区av| 97精品超碰一区二区三区| 亚洲国产另类av| 精品不卡在线视频| 99久免费精品视频在线观看 | 九九热在线视频观看这里只有精品 | 日本乱码高清不卡字幕| 亚洲第一福利视频在线| www激情久久| 日本高清免费不卡视频| 秋霞影院一区二区| 一色屋精品亚洲香蕉网站| 欧美日韩国产片| 国产精品伊人色| 亚洲国产欧美在线| 久久精品欧美一区二区三区麻豆| 欧美在线一二三| 国产乱理伦片在线观看夜一区 | 国产风韵犹存在线视精品| 亚洲精品美国一| 精品精品国产高清a毛片牛牛| 99久久精品情趣| 久久精品国产精品青草| 日韩美女视频一区| 欧美不卡一区二区三区| 色欧美片视频在线观看| 狠狠色综合日日| 亚洲成人动漫精品| 中文一区二区在线观看| 这里是久久伊人| 在线一区二区三区| 国产成人精品免费在线| 蜜臀91精品一区二区三区 | 日韩女优av电影| 91久久精品一区二区二区| 国产经典欧美精品| 蜜桃久久av一区|