エンベロープ範囲で地図を縮小

 2016/9/1 (木)    

'現在のAxMapControlのMap範囲をドラッグ範囲に当てはめてセット
 
'Map範囲取得 
Dim pEnvelope1 As IEnvelope 
pEnvelope1 = AxMapControl1.Extent 
 
'ドラッグ範囲取得 
Dim pEnvelope2 As IEnvelope 
pEnvelope2 = AxMapControl1.TrackRectangle 
 
'縮小率設定 
Dim WidthRatio As Double
WidthRatio = pEnvelope1.Width / pEnvelope2.Width
 
Dim HeightRatio As Double
HeightRatio = pEnvelope1.Height / pEnvelope2.Height 
 
'縮小率に基づいて新規Map範囲を設定(地図の縮小) 
pEnvelope1.Expand WidthRatio, HeightRatio, True
 
'設定した新規Map範囲を現在のMapに設定 
AxMapControl1.Extent = pEnvelope1 

Copyright© WINGFIELD since1981 , 2018 All Rights Reserved.