About the Dynamic display animated zoom Sample
[C#]
AnimatedZoomInTool.cs
using System;
using System.Drawing;
using System.Runtime.InteropServices;
using ESRI.ArcGIS.ADF.BaseClasses;
using ESRI.ArcGIS.ADF.CATIDs;
using ESRI.ArcGIS.esriSystem;
using ESRI.ArcGIS.Geometry;
using ESRI.ArcGIS.Display;
using ESRI.ArcGIS.Carto;
using ESRI.ArcGIS.Controls;
using System.Windows.Forms;
namespace DynamicDisplayAnimatedZoom
{
/// <summary>
/// Summary description for AnimatedZoomInTool.
/// </summary>
[Guid("3d5a0143-757b-4069-b4e7-973d24793923")]
[ClassInterface(ClassInterfaceType.None)]
[ProgId("DynamicDisplayAnimatedZoom.AnimatedZoomInTool")]
public sealed class AnimatedZoomInTool : BaseTool
{
#region COM Registration Function(s)
[ComRegisterFunction()]
[ComVisible(false)]
static void RegisterFunction(Type registerType)
{
// Required for ArcGIS Component Category Registrar support
ArcGISCategoryRegistration(registerType);
}
[ComUnregisterFunction()]
[ComVisible(false)]
static void UnregisterFunction(Type registerType)
{
// Required for ArcGIS Component Category Registrar support
ArcGISCategoryUnregistration(registerType);
}
#region ArcGIS Component Category Registrar generated code
/// <summary>
/// Required method for ArcGIS Component Category registration -
/// Do not modify the contents of this method with the code editor.
/// </summary>
private static void ArcGISCategoryRegistration(Type registerType)
{
string regKey = string.Format("HKEY_CLASSES_ROOT\\CLSID\\{{{0}}}", registerType.GUID);
ControlsCommands.Register(regKey);
}
/// <summary>
/// Required method for ArcGIS Component Category unregistration -
/// Do not modify the contents of this method with the code editor.
/// </summary>
private static void ArcGISCategoryUnregistration(Type registerType)
{
string regKey = string.Format("HKEY_CLASSES_ROOT\\CLSID\\{{{0}}}", registerType.GUID);
ControlsCommands.Unregister(regKey);
}
#endregion
#endregion
#region class members
private IHookHelper m_hookHelper = null;
private bool m_bIsAnimating = false;
private bool m_bZoomOut = false;
private double m_dStepCount = 0;
private int m_nTotalSteps = 0;
private IPoint m_Center = new PointClass();
private WKSEnvelope m_wksStep = new WKSEnvelope();
private IDynamicMapEvents_Event m_dynamicMapEvents = null;
private const double c_dMinimumDelta = 0.01;
private const double c_dSmoothFactor = 200000.0;
private const double c_dMinimumSmoothZoom = 0.1;
#endregion
public AnimatedZoomInTool()
{
base.m_category = ".NET Samples";
base.m_caption = "Animated Zoom In";
base.m_message = "Zoom in with animation";
base.m_toolTip = "Animated Zoom In";
base.m_name = "DynamicDisplayAnimatedZoom_AnimatedZoomInTool";
try
{
string bitmapResourceName = GetType().Name + ".bmp";
base.m_bitmap = new Bitmap(GetType(), bitmapResourceName);
base.m_cursor = new System.Windows.Forms.Cursor(GetType(), GetType().Name + ".cur");
}
catch (Exception ex)
{
System.Diagnostics.Trace.WriteLine(ex.Message, "Invalid Bitmap");
}
}
#region Overriden Class Methods
/// <summary>
/// Occurs when this tool is created
/// </summary>
/// <param name="hook">Instance of the application</param>
public override void OnCreate(object hook)
{
if (null == hook)
return;
try
{
m_hookHelper = new HookHelperClass();
m_hookHelper.Hook = hook;
if (null == m_hookHelper.ActiveView)
m_hookHelper = null;
}
catch
{
m_hookHelper = null;
}
}
/// <summary>
/// The enabled state of this command, determines whether the command is usable.
/// </summary>
public override bool Enabled
{
get
{
if (null == m_hookHelper)
return false;
IDynamicMap dynamicMap = m_hookHelper.FocusMap as IDynamicMap;
bool bIsDynamicMapEnabled = dynamicMap.DynamicMapEnabled;
if (false == bIsDynamicMapEnabled)
{
m_bIsAnimating = false;
m_dStepCount = 0;
m_nTotalSteps = 0;
m_dynamicMapEvents = null;
}
return bIsDynamicMapEnabled;
}
}
/// <summary>
/// Occurs when this tool is clicked
/// </summary>
public override void OnClick()
{
IDynamicMap dynamicMap = m_hookHelper.FocusMap as IDynamicMap;
if (false == dynamicMap.DynamicMapEnabled)
return;
m_dynamicMapEvents = null;
m_dynamicMapEvents = m_hookHelper.FocusMap as IDynamicMapEvents_Event;
m_dynamicMapEvents.DynamicMapStarted += new IDynamicMapEvents_DynamicMapStartedEventHandler(DynamicMapEvents_DynamicMapStarted);
m_bIsAnimating = false;
m_dStepCount = 0;
m_nTotalSteps = 0;
}
public override void OnMouseDown(int Button, int Shift, int X, int Y)
{
// Zoom on the focus map based on user drawn rectangle
m_bZoomOut = Shift == 1;
IActiveView activeView = m_hookHelper.FocusMap as IActiveView;
IRubberBand rubberBand = new RubberEnvelopeClass();
// This method intercepts the Mouse events from here
IEnvelope zoomBounds = rubberBand.TrackNew(activeView.ScreenDisplay, null) as IEnvelope;
if (null == zoomBounds)
return;
WKSEnvelope wksZoomBounds;
zoomBounds.QueryWKSCoords(out wksZoomBounds);
IEnvelope fittedBounds = activeView.ScreenDisplay.DisplayTransformation.FittedBounds;
WKSEnvelope wksFittedBounds;
fittedBounds.QueryWKSCoords(out wksFittedBounds);
if (true == m_bZoomOut)
{
double dXScale = fittedBounds.Width * fittedBounds.Width / zoomBounds.Width;
double dYScale = fittedBounds.Height * fittedBounds.Height / zoomBounds.Height;
wksZoomBounds.XMin = fittedBounds.XMin - dXScale;
wksZoomBounds.YMin = fittedBounds.YMin - dYScale;
wksZoomBounds.XMax = fittedBounds.XMax + dXScale;
wksZoomBounds.YMax = fittedBounds.YMax + dYScale;
}
m_wksStep.XMax = 1;
m_wksStep.YMax = 1;
m_wksStep.XMin = 1;
m_wksStep.YMin = 1;
m_nTotalSteps = 0;
// Calculate how fast the zoom will go by changing the step size
while ((System.Math.Abs(m_wksStep.XMax) > c_dMinimumDelta) ||
(System.Math.Abs(m_wksStep.YMax) > c_dMinimumDelta) ||
(System.Math.Abs(m_wksStep.XMin) > c_dMinimumDelta) ||
(System.Math.Abs(m_wksStep.YMin) > c_dMinimumDelta))
{
m_nTotalSteps++;
// calculate the step size
// step size is the difference between the zoom bounds and the fitted bounds
m_wksStep.XMin = (wksZoomBounds.XMin - wksFittedBounds.XMin) / m_nTotalSteps;
m_wksStep.YMin = (wksZoomBounds.YMin - wksFittedBounds.YMin) / m_nTotalSteps;
m_wksStep.XMax = (wksZoomBounds.XMax - wksFittedBounds.XMax) / m_nTotalSteps;
m_wksStep.YMax = (wksZoomBounds.YMax - wksFittedBounds.YMax) / m_nTotalSteps;
}
m_bIsAnimating = true;
m_dStepCount = 0;
}
public override bool Deactivate()
{
m_bIsAnimating = false;
m_dStepCount = 0;
m_nTotalSteps = 0;
if (null == m_hookHelper)
return false;
IDynamicMap dynamicMap = m_hookHelper.FocusMap as IDynamicMap;
if (false == dynamicMap.DynamicMapEnabled)
return true;
m_dynamicMapEvents = m_hookHelper.FocusMap as IDynamicMapEvents_Event;
m_dynamicMapEvents.DynamicMapStarted -= new IDynamicMapEvents_DynamicMapStartedEventHandler(DynamicMapEvents_DynamicMapStarted);
return true;
}
#endregion
#region Dynamic Map Events
void DynamicMapEvents_DynamicMapStarted(IDisplay Display, IDynamicDisplay dynamicDisplay)
{
if (false == m_bIsAnimating)
{
m_dStepCount = 0;
m_nTotalSteps = 0;
return;
}
if (m_dStepCount >= m_nTotalSteps)
{
m_bIsAnimating = false;
m_dStepCount = 0;
m_nTotalSteps = 0;
return;
}
// Increase the bounds by the step amount
IActiveView activeView = m_hookHelper.FocusMap as IActiveView;
IEnvelope newVisibleBounds = activeView.ScreenDisplay.DisplayTransformation.FittedBounds;
// Smooth the zooming. Faster at higher scales, slower at lower
double dSmoothZooom = activeView.FocusMap.MapScale / c_dSmoothFactor;
if (dSmoothZooom < c_dMinimumSmoothZoom)
dSmoothZooom = c_dMinimumSmoothZoom;
newVisibleBounds.XMin = newVisibleBounds.XMin + (m_wksStep.XMin * dSmoothZooom);
newVisibleBounds.YMin = newVisibleBounds.YMin + (m_wksStep.YMin * dSmoothZooom);
newVisibleBounds.XMax = newVisibleBounds.XMax + (m_wksStep.XMax * dSmoothZooom);
newVisibleBounds.YMax = newVisibleBounds.YMax + (m_wksStep.YMax * dSmoothZooom);
activeView.ScreenDisplay.DisplayTransformation.VisibleBounds = newVisibleBounds;
m_dStepCount = m_dStepCount + dSmoothZooom;
}
#endregion
}
}
[Visual Basic .NET]
AnimatedZoomInTool.vb
Imports Microsoft.VisualBasic
Imports System
Imports System.Drawing
Imports System.Runtime.InteropServices
Imports ESRI.ArcGIS.ADF.BaseClasses
Imports ESRI.ArcGIS.ADF.CATIDs
Imports ESRI.ArcGIS.esriSystem
Imports ESRI.ArcGIS.Geometry
Imports ESRI.ArcGIS.Display
Imports ESRI.ArcGIS.Carto
Imports ESRI.ArcGIS.Controls
Imports System.Windows.Forms
''' <summary>
''' Summary description for AnimatedZoomInTool.
''' </summary>
<Guid("3d5a0143-757b-4069-b4e7-973d24793923"), ClassInterface(ClassInterfaceType.None), ProgId("AnimatedZoomInTool")> _
Public NotInheritable Class AnimatedZoomInTool : Inherits BaseTool
#Region "COM Registration Function(s)"
<ComRegisterFunction(), ComVisible(False)> _
Private Shared Sub RegisterFunction(ByVal registerType As Type)
' Required for ArcGIS Component Category Registrar support
ArcGISCategoryRegistration(registerType)
End Sub
<ComUnregisterFunction(), ComVisible(False)> _
Private Shared Sub UnregisterFunction(ByVal registerType As Type)
' Required for ArcGIS Component Category Registrar support
ArcGISCategoryUnregistration(registerType)
End Sub
#Region "ArcGIS Component Category Registrar generated code"
''' <summary>
''' Required method for ArcGIS Component Category registration -
''' Do not modify the contents of this method with the code editor.
''' </summary>
Private Shared Sub ArcGISCategoryRegistration(ByVal registerType As Type)
Dim regKey As String = String.Format("HKEY_CLASSES_ROOT\CLSID\{{{0}}}", registerType.GUID)
ControlsCommands.Register(regKey)
End Sub
''' <summary>
''' Required method for ArcGIS Component Category unregistration -
''' Do not modify the contents of this method with the code editor.
''' </summary>
Private Shared Sub ArcGISCategoryUnregistration(ByVal registerType As Type)
Dim regKey As String = String.Format("HKEY_CLASSES_ROOT\CLSID\{{{0}}}", registerType.GUID)
ControlsCommands.Unregister(regKey)
End Sub
#End Region
#End Region
#Region "class members"
Private m_hookHelper As IHookHelper = Nothing
Private m_bIsAnimating As Boolean = False
Private m_bZoomOut As Boolean = False
Private m_dStepCount As Double = 0
Private m_nTotalSteps As Integer = 0
Private m_Center As IPoint = New PointClass()
Private m_wksStep As WKSEnvelope = New WKSEnvelope()
Private m_dynamicMapEvents As IDynamicMapEvents_Event = Nothing
Private Const c_dMinimumDelta As Double = 0.01
Private Const c_dSmoothFactor As Double = 200000.0
Private Const c_dMinimumSmoothZoom As Double = 0.1
#End Region
Public Sub New()
MyBase.m_category = ".NET Samples"
MyBase.m_caption = "Animated Zoom In"
MyBase.m_message = "Zoom in with animation"
MyBase.m_toolTip = "Animated Zoom In"
MyBase.m_name = "AnimatedZoomInTool"
Try
Dim bitmapResourceName As String = Me.GetType().Name & ".bmp"
MyBase.m_bitmap = New Bitmap(Me.GetType(), bitmapResourceName)
MyBase.m_cursor = New System.Windows.Forms.Cursor(Me.GetType(), Me.GetType().Name & ".cur")
Catch ex As Exception
System.Diagnostics.Trace.WriteLine(ex.Message, "Invalid Bitmap")
End Try
End Sub
#Region "Overridden Class Methods"
''' <summary>
''' Occurs when this tool is created
''' </summary>
''' <param name="hook">Instance of the application</param>
Public Overrides Sub OnCreate(ByVal hook As Object)
If Nothing Is hook Then
Return
End If
Try
m_hookHelper = New HookHelperClass()
m_hookHelper.Hook = hook
If Nothing Is m_hookHelper.ActiveView Then
m_hookHelper = Nothing
End If
Catch
m_hookHelper = Nothing
End Try
End Sub
''' <summary>
''' The enabled state of this command, determines whether the command is usable.
''' </summary>
Public Overrides ReadOnly Property Enabled() As Boolean
Get
If Nothing Is m_hookHelper Then
Return False
End If
Dim dynamicMap As IDynamicMap = TryCast(m_hookHelper.FocusMap, IDynamicMap)
Dim bIsDynamicMapEnabled As Boolean = dynamicMap.DynamicMapEnabled
If False = bIsDynamicMapEnabled Then
m_bIsAnimating = False
m_dStepCount = 0
m_nTotalSteps = 0
m_dynamicMapEvents = Nothing
End If
Return bIsDynamicMapEnabled
End Get
End Property
''' <summary>
''' Occurs when this tool is clicked
''' </summary>
Public Overrides Sub OnClick()
Dim dynamicMap As IDynamicMap = TryCast(m_hookHelper.FocusMap, IDynamicMap)
If False = dynamicMap.DynamicMapEnabled Then
Return
End If
m_dynamicMapEvents = Nothing
m_dynamicMapEvents = TryCast(m_hookHelper.FocusMap, IDynamicMapEvents_Event)
AddHandler m_dynamicMapEvents.DynamicMapStarted, AddressOf DynamicMapEvents_DynamicMapStarted
m_bIsAnimating = False
m_dStepCount = 0
m_nTotalSteps = 0
End Sub
Public Overrides Sub OnMouseDown(ByVal Button As Integer, ByVal Shift As Integer, ByVal X As Integer, ByVal Y As Integer)
' Zoom on the focus map based on user drawn rectangle
m_bZoomOut = Shift = 1
Dim activeView As IActiveView = TryCast(m_hookHelper.FocusMap, IActiveView)
Dim rubberBand As IRubberBand = New RubberEnvelopeClass()
' This method intercepts the Mouse events from here
Dim zoomBounds As IEnvelope = TryCast(rubberBand.TrackNew(activeView.ScreenDisplay, Nothing), IEnvelope)
If Nothing Is zoomBounds Then
Return
End If
Dim wksZoomBounds As WKSEnvelope
zoomBounds.QueryWKSCoords(wksZoomBounds)
Dim fittedBounds As IEnvelope = activeView.ScreenDisplay.DisplayTransformation.FittedBounds
Dim wksFittedBounds As WKSEnvelope
fittedBounds.QueryWKSCoords(wksFittedBounds)
If True = m_bZoomOut Then
Dim dXScale As Double = fittedBounds.Width * fittedBounds.Width / zoomBounds.Width
Dim dYScale As Double = fittedBounds.Height * fittedBounds.Height / zoomBounds.Height
wksZoomBounds.XMin = fittedBounds.XMin - dXScale
wksZoomBounds.YMin = fittedBounds.YMin - dYScale
wksZoomBounds.XMax = fittedBounds.XMax + dXScale
wksZoomBounds.YMax = fittedBounds.YMax + dYScale
End If
m_wksStep.XMax = 1
m_wksStep.YMax = 1
m_wksStep.XMin = 1
m_wksStep.YMin = 1
m_nTotalSteps = 0
' Calculate how fast the zoom will go by changing the step size
Do While (System.Math.Abs(m_wksStep.XMax) > c_dMinimumDelta) OrElse (System.Math.Abs(m_wksStep.YMax) > c_dMinimumDelta) OrElse (System.Math.Abs(m_wksStep.XMin) > c_dMinimumDelta) OrElse (System.Math.Abs(m_wksStep.YMin) > c_dMinimumDelta)
m_nTotalSteps += 1
' calculate the step size
' step size is the difference between the zoom bounds and the fitted bounds
m_wksStep.XMin = (wksZoomBounds.XMin - wksFittedBounds.XMin) / m_nTotalSteps
m_wksStep.YMin = (wksZoomBounds.YMin - wksFittedBounds.YMin) / m_nTotalSteps
m_wksStep.XMax = (wksZoomBounds.XMax - wksFittedBounds.XMax) / m_nTotalSteps
m_wksStep.YMax = (wksZoomBounds.YMax - wksFittedBounds.YMax) / m_nTotalSteps
Loop
m_bIsAnimating = True
m_dStepCount = 0
End Sub
Public Overrides Function Deactivate() As Boolean
m_bIsAnimating = False
m_dStepCount = 0
m_nTotalSteps = 0
If Nothing Is m_hookHelper Then
Return False
End If
Dim dynamicMap As IDynamicMap = TryCast(m_hookHelper.FocusMap, IDynamicMap)
If False = dynamicMap.DynamicMapEnabled Then
Return True
End If
m_dynamicMapEvents = TryCast(m_hookHelper.FocusMap, IDynamicMapEvents_Event)
RemoveHandler m_dynamicMapEvents.DynamicMapStarted, AddressOf DynamicMapEvents_DynamicMapStarted
Return True
End Function
#End Region
#Region "Dynamic Map Events"
Private Sub DynamicMapEvents_DynamicMapStarted(ByVal Display As IDisplay, ByVal dynamicDisplay As IDynamicDisplay)
If False = m_bIsAnimating Then
m_dStepCount = 0
m_nTotalSteps = 0
Return
End If
If m_dStepCount >= m_nTotalSteps Then
m_bIsAnimating = False
m_dStepCount = 0
m_nTotalSteps = 0
Return
End If
' Increase the bounds by the step amount
Dim activeView As IActiveView = TryCast(m_hookHelper.FocusMap, IActiveView)
Dim newVisibleBounds As IEnvelope = activeView.ScreenDisplay.DisplayTransformation.FittedBounds
' Smooth the zooming. Faster at higher scales, slower at lower
Dim dSmoothZooom As Double = activeView.FocusMap.MapScale / c_dSmoothFactor
If dSmoothZooom < c_dMinimumSmoothZoom Then
dSmoothZooom = c_dMinimumSmoothZoom
End If
newVisibleBounds.XMin = newVisibleBounds.XMin + (m_wksStep.XMin * dSmoothZooom)
newVisibleBounds.YMin = newVisibleBounds.YMin + (m_wksStep.YMin * dSmoothZooom)
newVisibleBounds.XMax = newVisibleBounds.XMax + (m_wksStep.XMax * dSmoothZooom)
newVisibleBounds.YMax = newVisibleBounds.YMax + (m_wksStep.YMax * dSmoothZooom)
activeView.ScreenDisplay.DisplayTransformation.VisibleBounds = newVisibleBounds
m_dStepCount = m_dStepCount + dSmoothZooom
End Sub
#End Region
End Class