AE实现Geoprocessing Fit to Display

 

<script type="text/javascript"> </script><script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>

将Mapcontrol作为参数

Public Sub FittoDisplay(pMapControl As Object)

     Dim pMapCon As IMapControl2
     Set pMapCon = pMapControl  

    Dim pMap As IMap
    Dim pActiveView As IActiveView

    Set pMap = pMapCon.Map
    Set pActiveView = pMap

    Dim pLayer As ILayer
    Dim pRasterLayer As IRasterLayer
    Dim pRaster As IRaster


    Set pLayer = pMap.Layer(0)  '设Layer(0)为栅格图层
    If TypeOf pLayer Is IRasterLayer Then
        Set pRasterLayer = pLayer
        Set pRaster = pRasterLayer.Raster


        ' Set raster property
        Dim pRasProp As IRasterProps
        Set pRasProp = pRaster
        
        

        Dim pPoint As IPoint
        Set pPoint = New Point
       
        Dim pSrcPoints As IPointCollection
        Dim pTarPoints As IPointCollection
       
        Set pSrcPoints = New Polygon
        Set pTarPoints = New Polygon
       
        pPoint.X = pRasProp.Extent.XMin
        pPoint.Y = pRasProp.Extent.YMin
        pSrcPoints.AddPoint pPoint
       
        pPoint.X = pRasProp.Extent.XMin
        pPoint.Y = pRasProp.Extent.YMax
        pSrcPoints.AddPoint pPoint
       
        pPoint.X = pRasProp.Extent.XMax
        pPoint.Y = pRasProp.Extent.YMax
        pSrcPoints.AddPoint pPoint
       
        pPoint.X = pRasProp.Extent.XMax
        pPoint.Y = pRasProp.Extent.YMin
        pSrcPoints.AddPoint pPoint
       
        pPoint.X = pActiveView.Extent.XMin
        pPoint.Y = pActiveView.Extent.YMin
        pTarPoints.AddPoint pPoint
       
        pPoint.X = pActiveView.Extent.XMin
        pPoint.Y = pActiveView.Extent.YMax
        pTarPoints.AddPoint pPoint
       
        pPoint.X = pActiveView.Extent.XMax
        pPoint.Y = pActiveView.Extent.YMax
        pTarPoints.AddPoint pPoint
       
        pPoint.X = pActiveView.Extent.XMax
        pPoint.Y = pActiveView.Extent.YMin
        pTarPoints.AddPoint pPoint
       
       
       
       
        Dim pRasterGp As IRasterGeometryProc3
        Set pRasterGp = New RasterGeometryProc
       
       
        pRasterGp.Reset pRaster
        pRasterGp.Warp pSrcPoints, pTarPoints, esriGeoTransPolyOrder1, pRaster
       
       
        pActiveView.PartialRefresh esriViewBackground, Nothing, Nothing

    End If
   
End Sub

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值