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

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

?? earthmap.pas

?? 想在DELPHI中應(yīng)用GoogleMap嗎
?? PAS
?? 第 1 頁 / 共 2 頁
字號(hào):
{*******************************************************}
{                                                       }
{       成功助手                                        }
{                                                       }
{       版權(quán)所有 (C) 2008 八九軟件                      }
{       Email: fansheng_hx@163.com                      }
{       Web: www.bajiusoft.com                          }   
{                                                       }
{*******************************************************}



unit EarthMap;

interface

uses
  Windows, SysUtils, Messages, Classes, Controls, GraphicEx, ExtCtrls, HTTPSend,
  SyncObjs, Graphics, Math;

const
  WM_MAP = WM_USER + 1001;
type
  TEarthMap = class;
  TMapZoom = 0..17;

  //代理
  TProxy = record
    Proxy: Boolean;
    Host: string;
    Port: string;
  end;

  //地圖參數(shù)
  PMapParam = ^TMapParam;
  TMapParam = record
    Zoom: Integer;
    x, y: Integer;
  end;

  //下載地圖線程
  TGetThread = class(TThread)
  private
    FEarthMap: TEarthMap;
    //任務(wù)列表
    FTaskList: TList;
    //讀寫任務(wù)列表鎖
    FLock: TCriticalSection;
    //地圖文件存放路徑
    FMapPath: string;
    //獲取地圖的URL
    FMapURL: string;
    //代理服務(wù)器
    FProxy: TProxy;
    //獲取一個(gè)任務(wù)
    function GetTask(var AMapParam: TMapParam): Boolean;
    //從Google服務(wù)器上獲取地圖
    function GetMap(const AZoom, Ax, Ay: Integer; var AFileName: string): Boolean;
    //設(shè)置網(wǎng)絡(luò)代理
    procedure SetProxy(AValue: TProxy);
  public
    constructor Create;
    destructor Destroy; override;
    //增加一個(gè)下載地圖任務(wù)
    procedure AddTask(AZoom, AX, AY: Integer);
    //清除所有下載地圖任務(wù)
    procedure ClearAllTask;
    procedure Execute; override;

    //檢查文件頭是否正確
    function CheckFileHeader(AStream: TStream): Boolean; overload;
    function CheckFileHeader(AFileName: string): Boolean; overload;

    property EarthMap: TEarthMap read FEarthMap write FEarthMap;
    property MapPath: string read FMapPath write FMapPath;
    property MapURL: string read FMapURL write FMapURL;
    property Proxy: TProxy read FProxy write SetProxy;
  end;

  TShowGPS = procedure(Sender: TObject; Longitude, Latitude: Double) of object;
  TMapZoomChange = procedure(Sender: TObject; MapZoom: Integer) of object;
  TEarthMap = class(TWinControl)
  private
    //獲取地圖線程
    FGetThread: TGetThread;
    //畫地圖使用的圖片
    FImage: TImage;
    //在沒有下載地圖文件的情況下的默認(rèn)圖片
    FDefMap: TBitmap;
    //地圖的放大系數(shù)
    FMapZoom: TMapZoom;
    //地圖的范圍
    FMapRect: TRect;
    //地圖和控件窗口的偏移距離
    FMapVector: TPoint;
    //地圖文件存放路徑
    FMapPath: string;
    //獲取地圖的URL
    FMapURL: string;
    //代理服務(wù)器
    FProxy: TProxy;
    //窗口大小
    FWinWidth, FWinHeight: Integer;
    //上一次鼠標(biāo)移動(dòng)的位置
    FOrganMouse: TPoint;
    //顯示地圖經(jīng)緯度
    FOnMapGPS: TShowGPS;
    //地圖放大系數(shù)改變
    FOnMapZoomChange: TMapZoomChange;
    procedure SetMapZoom(AZoom: TMapZoom);
    procedure SetProxy(AProxy: TProxy);
  protected
    //畫單個(gè)的256*256地圖圖片
    procedure DrawOneMap(const AZoom, AX, AY: Integer; var ABmp: TBitmap);
    //改變大小
    procedure WMSize(var AMsg: TWMSize); message WM_SIZE;
    //重載此方法主要是為滾動(dòng)滾軸的時(shí)候只觸發(fā)一次放大、縮小事件
    function DoMouseWheel(Shift: TShiftState; WheelDelta: Integer;
      MousePos: TPoint): Boolean; override;
    //縮小
    function DoMouseWheelDown(Shift: TShiftState; MousePos: TPoint): Boolean; override;
    //放大
    function DoMouseWheelUp(Shift: TShiftState; MousePos: TPoint): Boolean; override;
    //獲取最大地圖塊的大小
    function GetMapCount(AZoom: Integer): Integer;
    //補(bǔ)全整個(gè)屏幕的地圖
    function StrechMap: Boolean;
    //把顯示地圖屏幕鼠標(biāo)轉(zhuǎn)換為地圖坐標(biāo),其實(shí)是鼠標(biāo)在FImage上的坐標(biāo)
    procedure CursorToMap(AMouse: TPoint; var x, y: Integer);
    //畫單張地圖
    procedure WMMap(var AMsg: TMessage); message WM_MAP;
    //鼠標(biāo)位置
    procedure OmImgMouseDown(Sender: TObject; Button: TMouseButton;
      Shift: TShiftState; X, Y: Integer);
    //鼠標(biāo)移動(dòng)
    procedure OnImgMouseMove(Sender: TObject; Shift: TShiftState; X, Y: Integer);

    procedure CMEnter(var Message: TCMEnter); message CM_ENTER;
    procedure CMExit(var Msg: TCMExit); message CM_EXIT;
  public
    constructor Create(AOwner: TComponent); override;
    destructor Destroy;

    //畫地圖
    procedure DrawMap;
  published
    property MapZoom: TMapZoom read FMapZoom write SetMapZoom default 0;
    property Align;
    property BevelEdges;
    property BevelInner;
    property BevelKind;
    property BevelOuter;
    property BevelWidth;
    property Color;
    property OnMapGPS: TShowGPS read FOnMapGPS write FOnMapGPS;
    property OnMapZoomChange: TMapZoomChange read FOnMapZoomChange write FOnMapZoomChange;
    property Proxy: TProxy read FProxy write SetProxy;
  end;

//由放大系數(shù)得到地圖塊數(shù)
function GetMaxMapCount(Zoom: Integer): Integer;
//地圖上的象素轉(zhuǎn)為經(jīng)緯度
procedure PelsToLongLat(Zoom: Integer; xPels, yPels: Integer; var dLongitude, dLatitude: Double);
//經(jīng)緯度轉(zhuǎn)為地圖上的象素,這個(gè)轉(zhuǎn)為的結(jié)果是地圖最下面的點(diǎn)為坐標(biāo)原點(diǎn)
procedure LongLatToPels(Zoom: Integer; dLongitude, dLatitude: Double; var xPels, yPels: Integer);

procedure Register;

implementation


const
  CMapFile = '%d-%d-%d.gif';           //地圖文件存放的文件名命名規(guī)則  Zomm-x-y
  CMapWidth = 256;                 //Google地圖單個(gè)地圖為 256*256 的GIF文件
  CMapHeight = 256;
  CMapURL = 'http://servicetile.mapabc.com/googlechina/maptile?v=cn1&hl=zh-CN&x=%d&y=%d&zoom=%d&s=Galile';
  //CMapURL = ' http://mt3.google.cn/googlechina/maptile?v=cn1&hl=zh-CN&x=%d&y=%d&zoom=%d&s=Galileo';

function GetMaxMapCount(Zoom: Integer): Integer;
begin
  if Zoom <= 0 then
  begin
    Result := 1;
  end
  else
  begin
    Result := 2 shl (Zoom - 1);
  end;
end;

procedure LongLatToPels(Zoom: Integer; dLongitude,
  dLatitude: Double; var xPels, yPels: Integer);
var
  iMapCount: Integer;
  dOnePels: Double;
  function DecToMerc(Latitude: Double): Double;
  begin
    Result := Ln(Tan(Pi/4 + Latitude/2))
  end;
begin
  iMapCount := GetMaxMapCount(Zoom);
  xPels := Floor(256*iMapCount*(dLongitude+180) / 360);
  //得到地圖歸一后緯度所在的坐標(biāo)值
  dOnePels := DecToMerc(dLatitude*Pi/180) / 2 / Pi * 256 + 128;
  yPels := Floor(dOnePels * iMapCount);
end;

procedure PelsToLongLat(Zoom, xPels, yPels: Integer;
  var dLongitude, dLatitude: Double);
var
  iMapCount: Integer;
  function MercToDec(Latitude: Double): Double;
  begin
    Result := (ArcTan(Exp(Latitude))*2) - (Pi/2);
  end;
begin
  iMapCount := GetMaxMapCount(Zoom);
  dLongitude := (360/iMapCount) * (xPels/256) - 180;
  //得到地圖歸一后的坐標(biāo)值
  dLatitude := ((iMapCount - yPels div 256)*256-(yPels mod 256))/iMapCount - 128;
  dLatitude := ((MercToDec(((dLatitude/256)*Pi)*2))*180)/Pi;
end;

procedure Register;
begin
  RegisterComponents('Fan', [TEarthMap]);
end;

{ TGetThread }

procedure TGetThread.AddTask(AZoom, AX, AY: Integer);
var
  MapParam: PMapParam;
begin
  New(MapParam);
  MapParam.Zoom := AZoom;
  MapParam.x := AX;
  MapParam.y := AY;
  FLock.Enter;
  try
    FTaskList.Add(MapParam);
    if Suspended then
      Resume;    //喚醒線程
  finally
    FLock.Leave;
  end;
end;

function TGetThread.CheckFileHeader(AStream: TStream): Boolean;
var
  sHeader: string[4];
  sFileType: string;
  SrcPos: Int64;
begin
  Result := False;
  if (not Assigned(AStream)) or (AStream.Size < 4) then Exit; 
  SrcPos := AStream.Position;
  AStream.Position := 0;
  try
    AStream.Read(sHeader[1], 4);
    sFileType := sHeader[1] + sHeader[2] + sHeader[3];
    if not SameText('GIF', sFileType) then
    begin
      sFileType := sHeader[2] + sHeader[3] + sHeader[4];
      if SameText('PNG', sFileType) then
        Result := True
      else
        Result := False;
    end
    else
      Result := True;
  finally
    AStream.Position := SrcPos;
  end;
end;

function TGetThread.CheckFileHeader(AFileName: string): Boolean;
var
  AStream: TFileStream;
begin
  Result := False;
  AStream := TFileStream.Create(AFileName, fmOpenRead or fmShareDenyWrite);
  try
    Result := CheckFileHeader(AStream);
  finally
    AStream.Free;
  end;
end;

procedure TGetThread.ClearAllTask;
var
  i: Integer;
begin
  FLock.Enter;
  try
    for i := FTaskList.Count - 1 downto 0 do
    begin
      if FTaskList.Items[i] <> nil then
        Dispose(PMapParam(FTaskList.Items[i]));
    end;
    FTaskList.Clear;
  finally
    FLock.Leave;
  end;
end;

constructor TGetThread.Create;
begin
  inherited Create(True);   //先創(chuàng)建一個(gè)掛起的線程
  FTaskList := TList.Create;
  FLock := TCriticalSection.Create;
  FreeOnTerminate := False;
end;

destructor TGetThread.Destroy;
begin
  ClearAllTask;
  FTaskList.Free;
  FLock.Free;
  inherited;
end;

procedure TGetThread.Execute;
var
  MapParam: TMapParam;
  FileName: string;
begin
  inherited;
  repeat
    if GetTask(MapParam) then
    begin
      if GetMap(MapParam.Zoom, MapParam.x, MapParam.y, FileName) then
        PostMessage(FEarthMap.Handle, WM_MAP, Integer(FileName), 0);
    end
    else
      Suspend;
  until Terminated;
end;

function TGetThread.GetMap(const AZoom, Ax, Ay: Integer;
  var AFileName: string): Boolean;
var
  sUrl: string;
  mmStream: TMemoryStream;
  sFilePath: string;
begin
  //Sleep(1000);
  Result := False;
  sFilePath := FMapPath + '\';
  if not DirectoryExists(sFilePath) then
    CreateDir(sFilePath);
  mmStream := TMemoryStream.Create;
  try
    AFileName := Format(CMapFile, [AZoom, Ax, Ay]);
    AFileName := sFilePath + AFileName;
    if not FileExists(AFileName) then
    begin
      sUrl := Format(CMapURL, [Ax, Ay, 17-AZoom]);   //Google中0表示放大到最大,而這里0表示最小
      if FProxy.Proxy then
        HttpGetBinary(sUrl, mmStream, FProxy.Host, FProxy.Port)
      else
        HttpGetBinary(sUrl, mmStream);
      if (mmStream.Size > 0) and CheckFileHeader(mmStream) then
      begin
        mmStream.SaveToFile(AFileName);
      end;
    end;
    Result := True;
  finally
    mmStream.Free;
  end;
end;

function TGetThread.GetTask(var AMapParam: TMapParam): Boolean;
begin
  Result := False;
  FLock.Enter;
  try
    if FTaskList.Count > 0 then
    begin
      AMapParam.Zoom := PMapParam(FTaskList.Items[0]).Zoom;
      AMapParam.x := PMapParam(FTaskList.Items[0]).x;
      AMapParam.y := PMapParam(FTaskList.Items[0]).y;
      Dispose(FTaskList.Items[0]);
      FTaskList.Delete(0);
      Result := True;
    end;
  finally
    FLock.Leave;
  end;
end;

procedure TGetThread.SetProxy(AValue: TProxy);
begin
  FProxy.Proxy := AValue.Proxy;
  FProxy.Host := AValue.Host;
  FProxy.Port := AValue.Port;
end;

{ TEarthMap }

procedure TEarthMap.CMEnter(var Message: TCMEnter);
begin
  inherited;
  SetFocus;
end;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人综合婷婷国产精品久久蜜臀| 久久国产综合精品| 国产一区二区久久| 色成年激情久久综合| 日韩电影免费一区| 久久99久久99| 亚洲激情图片小说视频| 国产精品国产三级国产三级人妇| 久久综合久色欧美综合狠狠| 日韩精品亚洲专区| 亚洲欧美怡红院| 日韩视频一区二区| 亚洲成a人片在线不卡一二三区 | 久久影院午夜论| 欧美日韩国产精品成人| 偷拍一区二区三区四区| 亚洲精品乱码久久久久久久久| 精品国产伦一区二区三区观看体验| 欧美性极品少妇| 成人晚上爱看视频| 成人免费福利片| 激情综合色综合久久综合| 欧美一区二区福利在线| 欧美日韩激情在线| 午夜欧美视频在线观看| 国产精品理论在线观看| 国产精品久久久久影院| 在线观看一区日韩| eeuss国产一区二区三区| 成人午夜在线视频| 久久嫩草精品久久久精品一| 首页欧美精品中文字幕| 91免费看片在线观看| 国产成人精品影视| 中文字幕一区二区三区不卡在线 | 制服丝袜av成人在线看| 色噜噜偷拍精品综合在线| 99久久精品国产导航| 久久99久久久久久久久久久| 久久精品国产77777蜜臀| 蜜桃av一区二区在线观看| 蜜桃av一区二区三区| 免费xxxx性欧美18vr| 三级一区在线视频先锋 | 欧美成人官网二区| 国产网红主播福利一区二区| 久久精品一区四区| 欧美v亚洲v综合ⅴ国产v| 欧美一区二区三区在线看| 亚洲一区视频在线观看视频| 日韩激情一二三区| 欧美aaaaa成人免费观看视频| 亚洲v精品v日韩v欧美v专区| 久久电影国产免费久久电影| 国精产品一区一区三区mba桃花 | 国产精品色哟哟网站| 99久久国产免费看| 亚洲一区二区欧美激情| 首页国产欧美久久| 国产一区三区三区| jiyouzz国产精品久久| 91精品国产综合久久香蕉的特点| 日本一区二区三区电影| 欧美精品一二三区| 精品少妇一区二区三区免费观看 | 中文字幕一区二区视频| 亚洲人成影院在线观看| 欧美一区二区三区小说| 国产无遮挡一区二区三区毛片日本| 日本高清不卡aⅴ免费网站| 成人黄色软件下载| 美日韩一区二区三区| 国产亚洲欧洲997久久综合| 3d动漫精品啪啪一区二区竹菊| 日韩电影在线看| 成人av在线一区二区| 欧美视频一区二区三区| 丝袜诱惑亚洲看片| 国产不卡视频在线播放| 欧美日韩一区国产| 国产亚洲成av人在线观看导航 | 国产精品久久久久aaaa樱花 | 欧美日韩午夜影院| 久久久久久久综合色一本| 久久99在线观看| 一本高清dvd不卡在线观看| 国产亚洲欧美日韩日本| 欧洲在线/亚洲| 国产一区二区在线视频| 日本电影亚洲天堂一区| 天堂久久久久va久久久久| 色哟哟一区二区| 国产成人午夜片在线观看高清观看| 欧美少妇一区二区| 老司机午夜精品| 国产精品美女视频| 在线观看av一区| 欧美亚洲愉拍一区二区| 一本色道久久综合亚洲精品按摩| 一区二区三区91| 一区二区高清在线| 欧美精品久久99| 欧美精品日日鲁夜夜添| 狠狠色伊人亚洲综合成人| 亚洲成人动漫精品| 久久久不卡网国产精品一区| 亚洲不卡av一区二区三区| 久久只精品国产| 欧美激情综合在线| 亚洲欧美中日韩| 国产99久久久久久免费看农村| 日韩欧美一区二区不卡| 欧美高清视频一二三区 | 免费成人美女在线观看| 国产一区二区三区不卡在线观看 | 在线亚洲高清视频| 欧美v日韩v国产v| 亚洲观看高清完整版在线观看| 韩国成人福利片在线播放| 色妞www精品视频| 色婷婷狠狠综合| 精品国产一区二区亚洲人成毛片 | 精品久久久久久无| 中文字幕av一区二区三区高| 亚洲成a人v欧美综合天堂| 国内欧美视频一区二区| 色综合 综合色| 精品国产免费久久| 亚洲一区免费视频| 国产成人免费视频精品含羞草妖精 | 成人免费观看av| 精品视频一区二区不卡| 中文字幕不卡的av| 久久精品久久精品| 欧美在线观看18| 国产女主播一区| 美女视频第一区二区三区免费观看网站| 国产jizzjizz一区二区| 欧美xxxx在线观看| 日韩精品电影一区亚洲| 91行情网站电视在线观看高清版| www国产精品av| 日韩精品亚洲专区| 欧美午夜精品久久久久久超碰| 欧美国产精品v| 韩国一区二区三区| 日韩精品在线网站| 亚洲成av人综合在线观看| 色吊一区二区三区| 中文字幕一区二区三区不卡在线 | 日本欧美一区二区三区乱码| 91搞黄在线观看| 亚洲婷婷国产精品电影人久久| 国产成人超碰人人澡人人澡| 精品伦理精品一区| 蜜桃一区二区三区在线观看| 欧美剧在线免费观看网站| 一区二区三区精品久久久| av一本久道久久综合久久鬼色| 久久久www成人免费无遮挡大片| 奇米在线7777在线精品| 日韩亚洲欧美综合| 美女视频第一区二区三区免费观看网站 | 国产精品乡下勾搭老头1| 精品三级av在线| 麻豆91精品视频| 日韩欧美一二三区| 激情丁香综合五月| 久久这里都是精品| 懂色av一区二区在线播放| 欧美激情中文不卡| 丁香天五香天堂综合| 国产精品美女久久久久久久久| 成人免费视频caoporn| 亚洲欧洲成人精品av97| 91啪九色porn原创视频在线观看| 一区二区三区日韩精品| 欧美专区在线观看一区| 日韩在线观看一区二区| 日韩精品在线看片z| 国产精品亚洲专一区二区三区 | 国产一本一道久久香蕉| 久久综合色8888| 国产精品 欧美精品| 国产精品久久网站| 色伊人久久综合中文字幕| 亚洲va国产天堂va久久en| 日韩欧美亚洲国产另类| 极品少妇xxxx精品少妇| 中文一区二区在线观看| 色婷婷av一区二区三区软件| 婷婷综合五月天| 久久久国产精品午夜一区ai换脸| 99久久精品国产网站| 99久久夜色精品国产网站| 亚洲国产一区视频| 欧美精品一区二区三| 91在线观看地址| 日韩av不卡一区二区| 国产亚洲一区二区三区在线观看|