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

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

?? clslabelengine.cls

?? gis地圖 --- --- --文字1
?? CLS
?? 第 1 頁 / 共 2 頁
字號:
VERSION 1.0 CLASS
BEGIN
  MultiUse = -1  'True
  Persistable = 0  'NotPersistable
  DataBindingBehavior = 0  'vbNone
  DataSourceBehavior  = 0  'vbNone
  MTSTransactionMode  = 0  'NotAnMTSObject
END
Attribute VB_Name = "Label3DEngine"
Attribute VB_GlobalNameSpace = False
Attribute VB_Creatable = True
Attribute VB_PredeclaredId = False
Attribute VB_Exposed = True

' Copyright 1995-2004 ESRI

' All rights reserved under the copyright laws of the United States.

' You may freely redistribute and use this sample code, with or without modification.

' Disclaimer: THE SAMPLE CODE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED 
' WARRANTIES, INCLUDING THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 
' FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL ESRI OR 
' CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, 
' OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 
' SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 
' INTERRUPTION) SUSTAINED BY YOU OR A THIRD PARTY, HOWEVER CAUSED AND ON ANY 
' THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT ARISING IN ANY 
' WAY OUT OF THE USE OF THIS SAMPLE CODE, EVEN IF ADVISED OF THE POSSIBILITY OF 
' SUCH DAMAGE.

' For additional information contact: Environmental Systems Research Institute, Inc.

' Attn: Contracts Dept.

' 380 New York Street

' Redlands, California, U.S.A. 92373 

' Email: contracts@esri.com

Option Explicit

Private m_Events As clsSGEvents     '   event handler for labelling
Public m_pScene As IScene          '   scene reference we get init with
Const m_cnDefaultColor = vbRed      '   default color RGB

Enum eLabelDocType
   eLabelDocTypeIndividual = 1
   eLabelDocTypeLayers = 2
End Enum





Public Function MoveLabelsToSurface(GroupIndex, sSurfaceLayerIndex, nzOffset As Double, Optional bRefreshViewers As Boolean) As String
On Error GoTo MoveLabelsToSurface_ERR

Dim pSurface As ISurface
Dim pG As LabelGroup
Dim pT As IDDDText
Dim nFactor As Double

    Debug.Assert 0
    
    If m_pScene Is Nothing Then Exit Function
    
    Set pSurface = GetSurfaceFromLayer(sSurfaceLayerIndex)
    If pSurface Is Nothing Then
      MoveLabelsToSurface = "Surface Layer at Index: " & sSurfaceLayerIndex & " not found."
      Exit Function
    End If
    
    Set pG = Me.LabelGroup(GroupIndex)
    If pG Is Nothing Then
      MoveLabelsToSurface = "Label Group at Index: " & GroupIndex & " not found."
      Exit Function
    End If
            
    nFactor = m_pScene.exaggerationFactor
            
    For Each pT In pG.Labels
        pT.Origin.z = (pSurface.z(pT.Origin.X, pT.Origin.Y) * nFactor) + nzOffset
    Next
    
    If bRefreshViewers Then
        m_pScene.SceneGraph.RefreshViewers
    End If
    
    Exit Function
    
MoveLabelsToSurface_ERR:
    Debug.Assert 0
    Debug.Print "MoveLabelsToSurface_ERR: " & Err.Description
    Resume Next
    
End Function
'
'   given a layername or index return the ISurface from it;
'   optionally return the name of the layer
Public Function GetSurfaceFromLayer(sLayer, Optional ByRef sOutName As String) As ISurface

Dim pLayer As ILayer
Dim pTin As ITin
Dim pRLayer As IRasterLayer
Dim pTLayer As ITinLayer
Dim pSurf As IRasterSurface
Dim pBands As IRasterBandCollection
Dim sName As String

On Error GoTo GetSurfaceFromLayer_ERR

'   get the layer:
    Set pLayer = GetLayer(sLayer)

    If pLayer Is Nothing Then Exit Function

    If TypeOf pLayer Is IRasterLayer Then

        Set pRLayer = pLayer

        Dim p3DProp As I3DProperties
        Dim pLE As ILayerExtensions
        Set pLE = pLayer
        
        Dim i As Integer
        
    '   look for 3D properties of layer:
        For i = 0 To pLE.ExtensionCount - 1
            If TypeOf pLE.Extension(i) Is I3DProperties Then
                Set p3DProp = pLE.Extension(i)
                Exit For
            End If
        Next


    '   look first for base surface of layer:
        Set pSurf = p3DProp.BaseSurface
        
    '   if not found, try first band of raster:
        If pSurf Is Nothing Then

            If Not pRLayer.raster Is Nothing Then
                Set pSurf = New RasterSurface
                Set pBands = pRLayer.raster
                pSurf.RasterBand = pBands.Item(0)
                sName = pLayer.name

            End If
        Else
        '   track the name of the layer if requested:
            sName = pLayer.name
            If Not p3DProp.BaseName Is Nothing Then
                sName = sName & " <" & p3DProp.BaseName.NameString & ">"
            Else
                sName = sName & " <surface?>"
            End If
        End If
        
        Set GetSurfaceFromLayer = pSurf
        
    ElseIf TypeOf pLayer Is ITinLayer Then
    '   get the surface off the tin layer:
        Set pTLayer = pLayer
        Set GetSurfaceFromLayer = pTLayer.Dataset
        sName = pTLayer.name
    Else
    
    End If

'   set return name if requested:
    If Not IsMissing(sOutName) Then sOutName = sName
    
    Exit Function
    
GetSurfaceFromLayer_ERR:
    Debug.Print "GetSurfaceFromLayer_ERR: " & vbCrLf & Err.Description
    Debug.Assert 0
    
End Function

'   pass in a location, a message, and some optional params
'   and insert a new label in either the default, found, or newly created group
'
Public Sub AddLabelDirect(Where As IPoint, sMessage As String, Optional GroupName As String, Optional sType As String, _
    Optional nFont As Double = 20, _
    Optional pFontcolor As IRgbColor, _
    Optional sFontName As String = "ARIAL", _
    Optional bVisible As Boolean, _
    Optional nxRot As Double = 90, _
    Optional nyRot As Double = 0, _
    Optional nZRot As Double = 0, _
    Optional nXScale As Double = 100, _
    Optional nYScale As Double = 100, _
    Optional nZScale As Double = 20, _
    Optional nMinDispDist As Double = -1, _
    Optional bBillBoarding As Boolean)

On Error GoTo AddLabelDirect_ERR

    Dim pDDD As IDDDText
    Dim pColor As IRgbColor
    
'   create new label:
    Set pDDD = New DDDText
    
'   create necessary defaults:
    If Not pFontcolor Is Nothing Then
        Set pColor = pFontcolor
    Else
        Set pColor = New RgbColor
        pColor.RGB = m_cnDefaultColor
    End If
    
'   initialize class:
    With pDDD
        .Initialize sMessage, Where, nFont, nXScale, nYScale, nZScale, pColor, nxRot, _
        nyRot, nZRot, sFontName, sType, bBillBoarding, nMinDispDist
        .Enabled = True
    End With
    
'   put in proper label group:
    Dim pLabelGroup As New LabelGroup
    If Len(Trim(GroupName)) > 1 Then
    '   if groupname was supplied, look for it in collection:
    
        Dim i As Integer
        Dim iIndex As Integer
        Dim p As New LabelGroup
        iIndex = -1
        For i = 0 To g_colLabelGroup.Count - 1
            Set p = g_colLabelGroup.Item(i + 1)
            If UCase(p.name) = UCase(GroupName) Then
                iIndex = i
                Exit For
            End If
        Next

        If iIndex < 0 Then
            Set pLabelGroup = CreateBasicLabelGroup(GroupName)
        Else
            Set pLabelGroup = g_colLabelGroup.Item(iIndex + 1)
        End If
        
        
    Else
    '   add to default group:
        If g_colLabelGroup.Count = 0 Then
            CreateDefaultLabelGroup 'guarantees first item
        End If
        Set pLabelGroup = g_colLabelGroup.Item(1)
    End If
    
    
    pLabelGroup.AddLabelDirect pDDD
    
    Exit Sub
    
AddLabelDirect_ERR:
    Debug.Assert 0
    Debug.Print "AddLabelDirect_ERR: " & Err.Description
    Resume Next
    

End Sub


'   pass in a reference to the scene:
'
Public Sub Init(theScene As IScene)
    
On Error GoTo Init_ERR

    If m_Events Is Nothing Then Set m_Events = New clsSGEvents
    Set m_Events.m_pSG = theScene.SceneGraph
    Set m_pScene = theScene
    
    Exit Sub
    
Init_ERR:
    Debug.Assert 0
    Debug.Print "Init_ERR: " & Err.Description
    
    
End Sub

Public Function LabelGroups() As Collection
On Error Resume Next
'   return the actual collection:
    Set LabelGroups = g_colLabelGroup
End Function

Private Sub Class_Initialize()
'   create new label group collection; add the default:

    Set g_colLabelGroup = New Collection
    CreateDefaultLabelGroup
    
End Sub



Private Sub CreateDefaultLabelGroup()
    
On Error GoTo CreateDefaultLabelGroup_ERR

    Dim pDefault As New LabelGroup
    pDefault.name = "<graphics layer>"
    pDefault.LabelItem = "<default>"
    pDefault.Visible = False
    pDefault.CanAddLabels = True
    pDefault.ExtentNeedsInit = True
    
    With pDefault
        .Billboarding = False
        .FontName = "Arial"
        
        Dim pC As IColor
        Set pC = New RgbColor
        pC.RGB = m_cnDefaultColor
        Set .Fontcolor = pC
        
        .m_nXRotMin = 0
        .m_nXRotMax = 360
        
        .m_nYRotMin = 0
        .m_nYRotMax = 360
        
        .m_nZRotMin = 0
        .m_nZRotMax = 360
        
        .m_nXOffMax = 5000
        .m_nYOffMax = 5000
        .m_nZOffMax = 5000
        
        .m_nXOffMin = -5000
        .m_nYOffMin = -5000
        .m_nZOffMin = -5000
        
        .m_nXScale = 100
        .m_nYScale = 100
        .m_nZScale = 20
        
        .FontSize = 20
        
    End With
    g_colLabelGroup.Add pDefault
    
    Exit Sub
    
CreateDefaultLabelGroup_ERR:
    Debug.Assert 0
    Debug.Print "CreateDefaultLabelGroup_ERR: " & Err.Description
    Resume Next
    
End Sub
Private Function CreateBasicLabelGroup(sName As String) As LabelGroup
    
On Error GoTo CreateBasicLabelGroup_ERR

    Dim pDefault As New LabelGroup
    pDefault.name = sName
    pDefault.LabelItem = "<default>"
    pDefault.Visible = True
    pDefault.CanAddLabels = True
    
    With pDefault
        .Billboarding = False
        .FontName = "Arial"
        Dim pC As IColor
        Set pC = New RgbColor
        pC.RGB = m_cnDefaultColor
        Set .Fontcolor = pC
        
        .m_nXRotMin = 0
        .m_nXRotMax = 360
        
        .m_nYRotMin = 0
        .m_nYRotMax = 360
        
        .m_nZRotMin = 0
        .m_nZRotMax = 360
        
        .m_nXOffMax = g_colLabelGroup.Item(1).m_nXOffMax
        .m_nYOffMax = g_colLabelGroup.Item(1).m_nYOffMax
        .m_nZOffMax = g_colLabelGroup.Item(1).m_nZOffMax
        
        .m_nXOffMin = g_colLabelGroup.Item(1).m_nXOffMax
        .m_nYOffMin = g_colLabelGroup.Item(1).m_nYOffMax
        .m_nZOffMin = g_colLabelGroup.Item(1).m_nZOffMax
        
        .m_nXScale = 100
        .m_nYScale = 100
        .m_nZScale = 20

        .FontSize = 20


    End With
    g_colLabelGroup.Add pDefault
    Set CreateBasicLabelGroup = pDefault
    Exit Function
    
CreateBasicLabelGroup_ERR:
    Debug.Assert 0
    Debug.Print "CreateDefaultLabelGroup_ERR: " & Err.Description
    Resume Next
    
End Function


Public Sub InitFeatureLayerLabels(pFeatureLayer As IFeatureLayer, pFeatureFilter As IQueryFilter, _
sLabelItem As String, _
Optional bNoChangeSettings As Boolean, Optional nFontSize As Double = 20, _
Optional pFontcolor As IRgbColor, Optional sFontName As String = "ARIAL", _
Optional nxRot As Double = 90, Optional nyRot As Double = 0, Optional nZRot As Double = 0, _
Optional nXScale, Optional nYScale, Optional nZScale, _
Optional bBillBoarding As Boolean)

On Error GoTo InitFeatureLayerLabels_ERR

'   ensure label group exists, pass parameters:
    Dim i As Integer
    Dim iIndex As Integer
    Dim pGroup As LabelGroup
    
    If pFeatureLayer Is Nothing Then Exit Sub
    
    iIndex = -1
    For i = 0 To g_colLabelGroup.Count - 1
        Set pGroup = g_colLabelGroup.Item(i + 1)
        If UCase(pGroup.name) = UCase(pFeatureLayer.name) Then
            iIndex = i
            Exit For
        End If
    Next
    
    Dim pLabelGroup As LabelGroup
    If iIndex < 0 Then
        'was not found:
        'create new:
        Set pLabelGroup = New LabelGroup
        pLabelGroup.name = pFeatureLayer.name
        g_colLabelGroup.Add pLabelGroup
    Else
        Set pLabelGroup = g_colLabelGroup(iIndex + 1)
    End If
        
    
    Dim pFeatureCursor As IFeatureCursor
    Set pFeatureCursor = pFeatureLayer.Search(pFeatureFilter, True)
    

'   get color to pass:
    Dim pColor As IRgbColor
    If pFontcolor Is Nothing Then
        Set pColor = New RgbColor
        pColor.RGB = m_cnDefaultColor
    Else
        Set pColor = pFontcolor
    End If
    
    Dim xD As Double, yD As Double, zD As Double
    Dim xOffMin As Double, yOffMin As Double, xOffMax As Double, yOffMax As Double
    Dim zOffMin As Double, zOffMax As Double

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产高清成人在线| 91精品国产一区二区人妖| 在线观看国产日韩| 亚洲欧洲一区二区在线播放| 国产一区久久久| 国产亚洲va综合人人澡精品| 国产乱淫av一区二区三区| 国产精品麻豆欧美日韩ww| 99国产精品国产精品久久| 夜夜爽夜夜爽精品视频| 欧美日韩国产区一| 黄网站免费久久| 亚洲猫色日本管| 日韩一区二区免费高清| 不卡的av网站| 亚洲综合丁香婷婷六月香| 久久久久久久性| 欧美三级视频在线播放| 色哟哟在线观看一区二区三区| 国产中文字幕一区| 亚洲成人av电影| 久久久99久久精品欧美| 国产午夜精品一区二区三区视频 | 麻豆91精品91久久久的内涵| 久久天堂av综合合色蜜桃网| 免费一级片91| 亚洲你懂的在线视频| 国产精品欧美经典| 五月激情丁香一区二区三区| 久久久久久久网| 中文字幕av资源一区| 精品国产乱码久久| 欧美色综合久久| 91丝袜美女网| 国产成人午夜精品5599| aaa亚洲精品一二三区| 国产成人免费视频网站高清观看视频| 午夜影视日本亚洲欧洲精品| 天天操天天综合网| 国产在线不卡一卡二卡三卡四卡| 紧缚奴在线一区二区三区| 欧美日韩精品一区二区三区蜜桃 | 国产二区国产一区在线观看| 成人av电影在线观看| 欧美最新大片在线看 | 亚洲欧美激情小说另类| 亚洲成av人片一区二区| 国内精品伊人久久久久av影院| 国产成人av自拍| 欧美日韩精品综合在线| 久久婷婷久久一区二区三区| 亚洲精品视频一区| 欧美国产精品专区| 亚洲chinese男男1069| 国产精品996| 欧美日韩精品福利| 欧美激情在线免费观看| 日韩有码一区二区三区| 亚洲一区自拍偷拍| 国产乱人伦精品一区二区在线观看| av网站免费线看精品| 日韩一区二区免费电影| 蜜桃av一区二区三区电影| 污片在线观看一区二区| 成人99免费视频| 日韩一区二区影院| 亚洲精品国产品国语在线app| 天天综合天天做天天综合| 成人深夜福利app| 成人一二三区视频| 日韩欧美一区二区视频| 67194成人在线观看| 欧美一区二区啪啪| 一区二区三区日韩精品视频| 国产乱码精品一区二区三| 欧美日韩aaa| 亚洲视频一区在线| 亚洲国产精品欧美一二99| 三级不卡在线观看| 色婷婷久久久久swag精品| 国产偷国产偷精品高清尤物| 日本麻豆一区二区三区视频| 国产一区二区中文字幕| 3d成人h动漫网站入口| 亚洲另类春色校园小说| 成人免费视频app| 久久久午夜电影| 青草av.久久免费一区| 欧美主播一区二区三区| 亚洲欧美综合另类在线卡通| 国产精品系列在线观看| 精品少妇一区二区三区| 中文字幕免费不卡在线| 毛片基地黄久久久久久天堂| 欧美精品视频www在线观看| 精品久久久久香蕉网| 天堂资源在线中文精品| 欧美午夜片在线观看| 亚洲精品免费一二三区| 色先锋久久av资源部| 亚洲欧洲美洲综合色网| www.日韩大片| 一区免费观看视频| 91麻豆国产自产在线观看| 国产精品国产精品国产专区不片| 中文字幕亚洲一区二区av在线 | 福利一区在线观看| 欧美日韩一区二区电影| 亚洲永久免费av| 在线观看亚洲专区| 亚洲一二三四在线观看| 在线亚洲一区观看| 国产亚洲美州欧州综合国| 狠狠色狠狠色合久久伊人| 精品久久久久99| 国产一级精品在线| www久久精品| 丁香六月久久综合狠狠色| 欧美激情一区在线| 波多野结衣视频一区| 国产精品福利电影一区二区三区四区| 激情综合网最新| 日本一区二区成人| 色哟哟一区二区三区| 一区二区激情小说| 91麻豆精品国产91久久久使用方法| 成人国产电影网| 欧美裸体bbwbbwbbw| 日本不卡视频在线| 久久综合国产精品| 成人一区二区三区在线观看| 国产精品不卡在线观看| 在线亚洲欧美专区二区| 午夜精品在线视频一区| 欧美tk—视频vk| 懂色中文一区二区在线播放| 亚洲欧洲综合另类| 欧美一级淫片007| 国产乱对白刺激视频不卡| 最新高清无码专区| 91麻豆精品国产91久久久更新时间| 日韩中文字幕一区二区三区| 精品免费国产一区二区三区四区| 国内精品自线一区二区三区视频| 国产精品色呦呦| 欧美日韩在线精品一区二区三区激情| 亚洲五码中文字幕| 26uuu精品一区二区| 99视频国产精品| 日韩av一区二| 国产精品进线69影院| 制服视频三区第一页精品| 国产一区不卡在线| 一片黄亚洲嫩模| 久久久久久夜精品精品免费| 91女厕偷拍女厕偷拍高清| 蜜桃av一区二区| 亚洲免费av在线| 精品国产精品网麻豆系列 | 在线播放中文一区| 高清不卡一区二区在线| 天天射综合影视| 亚洲欧洲av一区二区三区久久| 欧美日韩成人一区| 丰满少妇久久久久久久| 日韩成人av影视| 亚洲三级在线看| 日韩欧美不卡在线观看视频| 91免费国产视频网站| 国产在线视频一区二区| 亚洲a一区二区| 亚洲欧美综合另类在线卡通| 日韩精品资源二区在线| 色天天综合色天天久久| 国产传媒久久文化传媒| 日韩不卡一二三区| 一级日本不卡的影视| 中文字幕精品一区| 日韩欧美激情在线| 欧美日韩在线精品一区二区三区激情| 久久99久久99精品免视看婷婷 | 亚洲欧美另类在线| 337p日本欧洲亚洲大胆色噜噜| 欧美在线免费观看亚洲| www.亚洲精品| 成人精品一区二区三区四区| 久久99国产精品免费网站| 亚洲成av人片观看| 亚洲精品你懂的| 亚洲人成网站影音先锋播放| 日韩欧美亚洲一区二区| 欧美日韩精品福利| 日本乱人伦一区| 99re热视频这里只精品| 成人国产精品免费观看| 成人综合在线网站| 国产精品99久久不卡二区| 国产中文字幕精品| 激情av综合网| 日韩和欧美一区二区三区|