【Wall】将symbologycontrol中选中的symbol或对象转化为图像(VB.Net源码)

当我们用Symbologycontrol设置某个图层symbol的样式或设置指北针、比例尺的样式时,
我们需要对其进行预览,将这些选中的样式以图片的形式显示在例如PictureBox中,这时我们就需要得到选中对象的Image,
下面是我提供的两种方法
一:是利用AE自带的PreviewItem方法来实现,这种方法普适性好,能适用所有Symbolgycontrol支持的对象,例如(指北针、比例尺、Symbol等)
二:是利用Symbol的Draw函数实现,该方法目前只支持Symbol,可以进行扩充


方法一:
''' <summary>
''' 通过SymbolObject获得image
''' </summary>
''' <param name="pStylegallery">传入的Symbologycontrol中选中的项</param>
''' <param name="pStyleClass">当前类型</param>
''' <param name="pWidth">图像宽度</param>
''' <param name="pHeight">图像高度</param>
''' <returns>得到的Image</returns>
''' <remarks></remarks>
Shared Function GetimageFromSymbolObject(ByVal pStylegallery As IStylegalleryItem,ByVal pStyleClass As esriSymbologyStyleClass,ByVal pWidth As Double,ByVal pHeight As Double) As Image
Dim pSymbology As ISymbologyControl = New SymbologyControl
pSymbology.StyleClass = pStyleClass
pSymbology.GetStyleClass(pSymbology.StyleClass).AddItem(pStylegallery,0)
Dim picture As stdole.IPicturedisp = pSymbology.GetStyleClass(pSymbology.StyleClass).PreviewItem(pStylegallery,pWidth,pHeight)
Dim image As System.Drawing.Image = System.Drawing.Image.FromHbitmap(New system.intPtr(picture.Handle))
Return image
End Function
''' <summary>
''' 通过SymbolObject获得image
''' </summary>
''' <param name="pSymbology">传入的symbologycontrol</param>
''' <param name="pStylegallery">传入的Symbologycontrol中选中的项</param>
''' <param name="pWidth">图像宽度</param>
''' <param name="pHeight">图像高度</param>
''' <returns>得到的Image</returns>
''' <remarks></remarks>
Shared Function GetimageFromSymbolObject(ByVal pSymbology As ISymbologyControl,ByVal pStylegallery As IStylegalleryItem,ByVal pHeight As Double) As Image
Dim picture As stdole.IPicturedisp = pSymbology.GetStyleClass(pSymbology.StyleClass).PreviewItem(pStylegallery,pHeight)
Dim image As System.Drawing.Image = System.Drawing.Image.FromHbitmap(New system.intPtr(picture.Handle))
Return image
End Function
''' <summary>
''' 通过SymbolObject获得image
''' </summary>
''' <param name="pStyleClass">当前的类型</param>
''' <param name="pSymbolObject">传入的对象,比如TextSymbol,northArrow</param>
''' <param name="pWidth">图像宽度</param>
''' <param name="pHeight">图像高度</param>
''' <returns>得到的Image</returns>
''' <remarks></remarks>
Shared Function GetimageFromSymbolObject(ByVal pStyleClass As esriSymbologyStyleClass,ByVal pSymbolObject As Object,ByVal pHeight As Double) As Image
Dim pSymbology As ISymbologyControl = New SymbologyControl
Dim pStylegallery As IStylegalleryItem = New ServerStylegalleryItem
pStylegallery.Name = "当前符号"
pStylegallery.Item = pSymbolObject
pSymbology.GetStyleClass(pStyleClass).AddItem(pStylegallery,0)
Dim picture As stdole.IPicturedisp = pSymbology.GetStyleClass(pStyleClass).PreviewItem(pStylegallery,pHeight)
Dim image As System.Drawing.Image = System.Drawing.Image.FromHbitmap(New system.intPtr(picture.Handle))
Return image
End Function
''' <summary>
''' 通过SymbolObject获得image
''' </summary>
''' <param name="pSymbolObject">传入的对象,比如TextSymbol,northArrow</param>
''' <param name="pWidth">图像宽度</param>
''' <param name="pHeight">图像高度</param>
''' <returns>得到的Image</returns>
''' <remarks></remarks>
Shared Function GetimageFromSymbolObject(ByVal pSymbolObject As Object,ByVal pHeight As Double) As Image
Dim pSymbology As ISymbologyControl = New SymbologyControl
Dim pStylegallery As IStylegalleryItem = New ServerStylegalleryItem
pStylegallery.Name = "当前符号"
pStylegallery.Item = pSymbolObject
Dim pStyleClass As esriSymbologyStyleClass = GetStyleClass(pSymbolObject)
pSymbology.GetStyleClass(pStyleClass).AddItem(pStylegallery,pHeight)
Dim image As System.Drawing.Image = System.Drawing.Image.FromHbitmap(New system.intPtr(picture.Handle))
Return image
End Function

''' <summary>
''' 获得当前对应的styleclass
''' </summary>
''' <param name="pSymbolObject">当前的对象</param>
''' <returns></returns>
''' <remarks></remarks>

Shared Function GetStyleClass(ByVal pSymbolObject As Object) As esriSymbologyStyleClass
If TypeOf pSymbolObject Is ITextSymbol Then
Return esriSymbologyStyleClass.esriStyleClasstextSymbols
ElseIf TypeOf pSymbolObject Is IMarkerSymbol Then
Return esriSymbologyStyleClass.esriStyleClassMarkerSymbols
ElseIf TypeOf pSymbolObject Is ILinesymbol Then
Return esriSymbologyStyleClass.esriStyleClassLinesymbols
ElseIf TypeOf pSymbolObject Is IFillSymbol Then
Return esriSymbologyStyleClass.esriStyleClassFillSymbols
ElseIf TypeOf pSymbolObject Is IScaleText Then
Return esriSymbologyStyleClass.esriStyleClassScaleTexts
ElseIf TypeOf pSymbolObject Is IScaleBar Then
Return esriSymbologyStyleClass.esriStyleClassScaleBars
ElseIf TypeOf pSymbolObject Is InorthArrow Then
Return esriSymbologyStyleClass.esriStyleClassnorthArrows
ElseIf TypeOf pSymbolObject Is IBackground Then
Return esriSymbologyStyleClass.esriStyleClassBackgrounds
ElseIf TypeOf pSymbolObject Is IBorder Then
Return esriSymbologyStyleClass.esriStyleClassBorders
ElseIf TypeOf pSymbolObject Is IShadow Then
Return esriSymbologyStyleClass.esriStyleClassLabels
ElseIf TypeOf pSymbolObject Is ILegend Then
Return esriSymbologyStyleClass.esriStyleClassLegendItems
End If
End Function
当我们用Symbologycontrol设置某个图层symbol的样式或设置指北针、比例尺的样式时,
我们需要对其进行预览,将这些选中的样式以图片的形式显示在例如PictureBox中,这时我们就需要得到选中对象的Image,
下面是我提供的两种方法
一:是利用AE自带的PreviewItem方法来实现,这种方法普适性好,能适用所有Symbolgycontrol支持的对象,例如(指北针、比例尺、Symbol等)
二:是利用Symbol的Draw函数实现,该方法目前只支持Symbol,可以进行扩充


方法一:
''' <summary>
''' 通过SymbolObject获得image
''' </summary>
''' <param name="pStylegallery">传入的Symbologycontrol中选中的项</param>
''' <param name="pStyleClass">当前类型</param>
''' <param name="pWidth">图像宽度</param>
''' <param name="pHeight">图像高度</param>
''' <returns>得到的Image</returns>
''' <remarks></remarks>
Shared Function GetimageFromSymbolObject(ByVal pStylegallery As IStylegalleryItem,pHeight)
Dim image As System.Drawing.Image = System.Drawing.Image.FromHbitmap(New system.intPtr(picture.Handle))
Return image
End Function

''' <summary>
''' 获得当前对应的styleclass
''' </summary>
''' <param name="pSymbolObject">当前的对象</param>
''' <returns></returns>
''' <remarks></remarks>

Shared Function GetStyleClass(ByVal pSymbolObject As Object) As esriSymbologyStyleClass
If TypeOf pSymbolObject Is ITextSymbol Then
Return esriSymbologyStyleClass.esriStyleClasstextSymbols
ElseIf TypeOf pSymbolObject Is IMarkerSymbol Then
Return esriSymbologyStyleClass.esriStyleClassMarkerSymbols
ElseIf TypeOf pSymbolObject Is ILinesymbol Then
Return esriSymbologyStyleClass.esriStyleClassLinesymbols
ElseIf TypeOf pSymbolObject Is IFillSymbol Then
Return esriSymbologyStyleClass.esriStyleClassFillSymbols
ElseIf TypeOf pSymbolObject Is IScaleText Then
Return esriSymbologyStyleClass.esriStyleClassScaleTexts
ElseIf TypeOf pSymbolObject Is IScaleBar Then
Return esriSymbologyStyleClass.esriStyleClassScaleBars
ElseIf TypeOf pSymbolObject Is InorthArrow Then
Return esriSymbologyStyleClass.esriStyleClassnorthArrows
ElseIf TypeOf pSymbolObject Is IBackground Then
Return esriSymbologyStyleClass.esriStyleClassBackgrounds
ElseIf TypeOf pSymbolObject Is IBorder Then
Return esriSymbologyStyleClass.esriStyleClassBorders
ElseIf TypeOf pSymbolObject Is IShadow Then
Return esriSymbologyStyleClass.esriStyleClassLabels
ElseIf TypeOf pSymbolObject Is ILegend Then
Return esriSymbologyStyleClass.esriStyleClassLegendItems
End If
End Function
当我们用Symbologycontrol设置某个图层symbol的样式或设置指北针、比例尺的样式时,
我们需要对其进行预览,将这些选中的样式以图片的形式显示在例如PictureBox中,这时我们就需要得到选中对象的Image,
下面是我提供的两种方法
一:是利用AE自带的PreviewItem方法来实现,这种方法普适性好,能适用所有Symbolgycontrol支持的对象,例如(指北针、比例尺、Symbol等)
二:是利用Symbol的Draw函数实现,该方法目前只支持Symbol,可以进行扩充


方法一:
''' <summary>
''' 通过SymbolObject获得image
''' </summary>
''' <param name="pStylegallery">传入的Symbologycontrol中选中的项</param>
''' <param name="pStyleClass">当前类型</param>
''' <param name="pWidth">图像宽度</param>
''' <param name="pHeight">图像高度</param>
''' <returns>得到的Image</returns>
''' <remarks></remarks>
Shared Function GetimageFromSymbolObject(ByVal pStylegallery As IStylegalleryItem,pHeight)
Dim image As System.Drawing.Image = System.Drawing.Image.FromHbitmap(New system.intPtr(picture.Handle))
Return image
End Function

''' <summary>
''' 获得当前对应的styleclass
''' </summary>
''' <param name="pSymbolObject">当前的对象</param>
''' <returns></returns>
''' <remarks></remarks>

Shared Function GetStyleClass(ByVal pSymbolObject As Object) As esriSymbologyStyleClass
If TypeOf pSymbolObject Is ITextSymbol Then
Return esriSymbologyStyleClass.esriStyleClasstextSymbols
ElseIf TypeOf pSymbolObject Is IMarkerSymbol Then
Return esriSymbologyStyleClass.esriStyleClassMarkerSymbols
ElseIf TypeOf pSymbolObject Is ILinesymbol Then
Return esriSymbologyStyleClass.esriStyleClassLinesymbols
ElseIf TypeOf pSymbolObject Is IFillSymbol Then
Return esriSymbologyStyleClass.esriStyleClassFillSymbols
ElseIf TypeOf pSymbolObject Is IScaleText Then
Return esriSymbologyStyleClass.esriStyleClassScaleTexts
ElseIf TypeOf pSymbolObject Is IScaleBar Then
Return esriSymbologyStyleClass.esriStyleClassScaleBars
ElseIf TypeOf pSymbolObject Is InorthArrow Then
Return esriSymbologyStyleClass.esriStyleClassnorthArrows
ElseIf TypeOf pSymbolObject Is IBackground Then
Return esriSymbologyStyleClass.esriStyleClassBackgrounds
ElseIf TypeOf pSymbolObject Is IBorder Then
Return esriSymbologyStyleClass.esriStyleClassBorders
ElseIf TypeOf pSymbolObject Is IShadow Then
Return esriSymbologyStyleClass.esriStyleClassLabels
ElseIf TypeOf pSymbolObject Is ILegend Then
Return esriSymbologyStyleClass.esriStyleClassLegendItems
End If
End Function

当我们用Symbologycontrol设置某个图层symbol的样式或设置指北针、比例尺的样式时,
我们需要对其进行预览,将这些选中的样式以图片的形式显示在例如PictureBox中,这时我们就需要得到选中对象的Image,
下面是我提供的两种方法
一:是利用AE自带的PreviewItem方法来实现,这种方法普适性好,能适用所有Symbolgycontrol支持的对象,例如(指北针、比例尺、Symbol等)
二:是利用Symbol的Draw函数实现,该方法目前只支持Symbol,可以进行扩充


方法一:
''' <summary>
''' 通过SymbolObject获得image
''' </summary>
''' <param name="pStylegallery">传入的Symbologycontrol中选中的项</param>
''' <param name="pStyleClass">当前类型</param>
''' <param name="pWidth">图像宽度</param>
''' <param name="pHeight">图像高度</param>
''' <returns>得到的Image</returns>
''' <remarks></remarks>
Shared Function GetimageFromSymbolObject(ByVal pStylegallery As IStylegalleryItem,ByVal pHeight As Double) As Image
Dim pSymbology As ISymbologyControl = New SymbologyControl
pSymbology.StyleClass = pStyleClass
pSymbology.GetStyleClass(pSymbology.StyleClass).AddItem(pStylegallery,0)
Dim picture As stdole.IPicturedisp = pSymbology.GetStyleClass(pSymbology.StyleClass).PreviewItem(pStylegallery,pHeight)
Dim image As System.Drawing.Image = System.Drawing.Image.FromHbitmap(New system.intPtr(picture.Handle))
Return image
End Function
''' <summary>
''' 通过SymbolObject获得image
''' </summary>
''' <param name="pSymbology">传入的symbologycontrol</param>
''' <param name="pStylegallery">传入的Symbologycontrol中选中的项</param>
''' <param name="pWidth">图像宽度</param>
''' <param name="pHeight">图像高度</param>
''' <returns>得到的Image</returns>
''' <remarks></remarks>
Shared Function GetimageFromSymbolObject(ByVal pSymbology As ISymbologyControl,ByVal pHeight As Double) As Image
Dim picture As stdole.IPicturedisp = pSymbology.GetStyleClass(pSymbology.StyleClass).PreviewItem(pStylegallery,pHeight)
Dim image As System.Drawing.Image = System.Drawing.Image.FromHbitmap(New system.intPtr(picture.Handle))
Return image
End Function
''' <summary>
''' 通过SymbolObject获得image
''' </summary>
''' <param name="pStyleClass">当前的类型</param>
''' <param name="pSymbolObject">传入的对象,比如TextSymbol,northArrow</param>
''' <param name="pWidth">图像宽度</param>
''' <param name="pHeight">图像高度</param>
''' <returns>得到的Image</returns>
''' <remarks></remarks>
Shared Function GetimageFromSymbolObject(ByVal pStyleClass As esriSymbologyStyleClass,ByVal pHeight As Double) As Image
Dim pSymbology As ISymbologyControl = New SymbologyControl
Dim pStylegallery As IStylegalleryItem = New ServerStylegalleryItem
pStylegallery.Name = "当前符号"
pStylegallery.Item = pSymbolObject
pSymbology.GetStyleClass(pStyleClass).AddItem(pStylegallery,0)
Dim picture As stdole.IPicturedisp = pSymbology.GetStyleClass(pStyleClass).PreviewItem(pStylegallery,pHeight)
Dim image As System.Drawing.Image = System.Drawing.Image.FromHbitmap(New system.intPtr(picture.Handle))
Return image
End Function
''' <summary>
''' 通过SymbolObject获得image
''' </summary>
''' <param name="pSymbolObject">传入的对象,比如TextSymbol,northArrow</param>
''' <param name="pWidth">图像宽度</param>
''' <param name="pHeight">图像高度</param>
''' <returns>得到的Image</returns>
''' <remarks></remarks>
Shared Function GetimageFromSymbolObject(ByVal pSymbolObject As Object,ByVal pHeight As Double) As Image
Dim pSymbology As ISymbologyControl = New SymbologyControl
Dim pStylegallery As IStylegalleryItem = New ServerStylegalleryItem
pStylegallery.Name = "当前符号"
pStylegallery.Item = pSymbolObject
Dim pStyleClass As esriSymbologyStyleClass = GetStyleClass(pSymbolObject)
pSymbology.GetStyleClass(pStyleClass).AddItem(pStylegallery,pHeight)
Dim image As System.Drawing.Image = System.Drawing.Image.FromHbitmap(New system.intPtr(picture.Handle))
Return image
End Function
''' <summary>
''' 获得当前对应的styleclass
''' </summary>
''' <param name="pSymbolObject">当前的对象</param>
''' <returns></returns>
''' <remarks></remarks>
Shared Function GetStyleClass(ByVal pSymbolObject As Object) As esriSymbologyStyleClass
If TypeOf pSymbolObject Is ITextSymbol Then
Return esriSymbologyStyleClass.esriStyleClasstextSymbols
ElseIf TypeOf pSymbolObject Is IMarkerSymbol Then
Return esriSymbologyStyleClass.esriStyleClassMarkerSymbols
ElseIf TypeOf pSymbolObject Is ILinesymbol Then
Return esriSymbologyStyleClass.esriStyleClassLinesymbols
ElseIf TypeOf pSymbolObject Is IFillSymbol Then
Return esriSymbologyStyleClass.esriStyleClassFillSymbols
ElseIf TypeOf pSymbolObject Is IScaleText Then
Return esriSymbologyStyleClass.esriStyleClassScaleTexts
ElseIf TypeOf pSymbolObject Is IScaleBar Then
Return esriSymbologyStyleClass.esriStyleClassScaleBars
ElseIf TypeOf pSymbolObject Is InorthArrow Then
Return esriSymbologyStyleClass.esriStyleClassnorthArrows
ElseIf TypeOf pSymbolObject Is IBackground Then
Return esriSymbologyStyleClass.esriStyleClassBackgrounds
ElseIf TypeOf pSymbolObject Is IBorder Then
Return esriSymbologyStyleClass.esriStyleClassBorders
ElseIf TypeOf pSymbolObject Is IShadow Then
Return esriSymbologyStyleClass.esriStyleClassLabels
ElseIf TypeOf pSymbolObject Is ILegend Then
Return esriSymbologyStyleClass.esriStyleClassLegendItems
End If
End Function
方法二:

''' <summary>
''' 将symbol转成bitmap
''' </summary>
''' <param name="pSymbol">symbol</param>
''' <param name="iwidth">图像宽</param>
''' <param name="iheight">图像高</param>
''' <returns>返回bitmap</returns>
''' <remarks></remarks>
Shared Function SymbolToBitmp(ByVal pSymbol As ISymbol,ByVal iwidth As Integer,ByVal iheight As Integer) As System.Drawing.Bitmap
''根据高宽创建图象
Dim bmp As Drawing.Bitmap = New Drawing.Bitmap(iwidth,iheight)
Dim gImage As Drawing.Graphics = Drawing.Graphics.FromImage(bmp)
gImage.Clear(Drawing.Color.White)

Dim dpi As Double = gImage.DpiX
Dim pEnvelope As IEnvelope = New EnvelopeClass()
pEnvelope.PutCoords(0,bmp.Width,bmp.Height)
Dim deviceRect As New tagRECT
deviceRect.left = 0
deviceRect.right = bmp.Width
deviceRect.top = 0
deviceRect.bottom = bmp.Height
Dim pdisplayTransformation As IdisplayTransformation = New displayTransformationClass
pdisplayTransformation.VisibleBounds = pEnvelope
pdisplayTransformation.Bounds = pEnvelope
pdisplayTransformation.DeviceFrame = deviceRect
pdisplayTransformation.Resolution = dpi

Dim pGeo As IGeometry = CreateSymShape(pSymbol,pEnvelope)
Dim hdc As system.intPtr = New IntPtr()
hdc = gImage.GetHdc()
''将符号的形状绘制到图象中
pSymbol.SetupDC(hdc,pdisplayTransformation)
pSymbol.Draw(pGeo)
pSymbol.ResetDC()
gImage.ReleaseHdc(hdc)
gImage.dispose()
Return bmp
End Function

Shared Function CreateSymShape(ByVal pSymbol As ISymbol,ByVal pEnvelope As IEnvelope) As IGeometry
Dim pGeo As IGeometry = nothing
'' 根据传入的符号以及外包矩形区域返回对应的几何空间实体(点,线、面)
''判断是否为“点”符号
If TypeOf pSymbol Is IMarkerSymbol Then
Dim pMarkerSym As IMarkerSymbol = pSymbol
If pMarkerSym IsNot nothing Then
''为“点”符号则返回IEnvelope的中心点
Dim pArea As IArea = pEnvelope
pGeo = pArea.Centroid
End If
ElseIf TypeOf pSymbol Is ILinesymbol Then
''判断是否为“线”符号
Dim Ilinesym As ILinesymbol = pSymbol
If Ilinesym IsNot nothing Then
''返回45度的对角线
Dim IpLine As Ipolyline
IpLine = New polylineClass()
IpLine.FromPoint = pEnvelope.LowerLeft
IpLine.ToPoint = pEnvelope.UpperRight
pGeo = IpLine
End If
ElseIf TypeOf pSymbol Is IFillSymbol Then
''直接返回一个IEnvelope矩形区域
pGeo = pEnvelope
End If
Return pGeo
End Function

来自:http://bbs.esrichina-bj.cn/ESRI/viewthread.php?tid=39779&highlight=SymbologyControl

相关文章

Format[$] ( expr [ , fmt ] ) format 返回变体型 format$ 强...
VB6或者ASP 格式化时间为 MM/dd/yyyy 格式,竟然没有好的办...
在项目中添加如下代码:新建窗口来显示异常信息。 Namespace...
转了这一篇文章,原来一直想用C#做k3的插件开发,vb没有C#用...
Sub 分列() ‘以空格为分隔符,连续空格只算1个。对所选...
  窗体代码 1 Private Sub Text1_OLEDragDrop(Data As Dat...