Bookmarks Gallery
BookmarksGallery.cs
// Copyright 2010 ESRI
// 
// All rights reserved under the copyright laws of the United States
// and applicable international laws, treaties, and conventions.
// 
// You may freely redistribute and use this sample code, with or
// without modification, provided you include the original copyright
// notice and use restrictions.
// 
// See the use restrictions.
// 

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;

using ESRI.ArcGISExplorer;
using ESRI.ArcGISExplorer.Mapping;
using ESRI.ArcGISExplorer.Geometry;
using ESRI.ArcGISExplorer.Data;
using ESRI.ArcGISExplorer.Threading;
using ESRI.ArcGISExplorer.Application;

namespace BookmarksGalleryCS
{
  /// <summary>
  /// Implements a custom bookmarks gallery
  /// </summary>
  /// <remarks>
  /// Listens to the DocumentOpened event on the Application and includes
  /// a gallery item for each View in the map. The Views are attached as tags
  /// to the gallery items so the map can be navigated to them when they are clicked.
  /// </remarks>
  public class BookmarksGallery : ESRI.ArcGISExplorer.Application.Gallery
  {
    /// <summary>
    /// Creates a new BookmarksGallery instance
    /// </summary>
    public BookmarksGallery()
    {
      // listen for the document opened event
      ESRI.ArcGISExplorer.Application.Application.DocumentOpened += new EventHandler(Application_DocumentOpened);

      // listen for the map item changed
      ESRI.ArcGISExplorer.Application.Application.MapItemChanged += new EventHandler<MapItemEventArgs>(Application_MapItemChanged);

      // call the event handler in case the gallery is loaded
      // after the document has been opened
      Application_DocumentOpened(null, EventArgs.Empty);
    }

    /// <summary>
    /// Raised when a new map document (.nmf) is opened
    /// </summary>
    void Application_DocumentOpened(object sender, EventArgs e)
    {
      // add the views from the map to the gallery
      PopulateGallery();
    }

    /// <summary>
    /// Raised when an item in the map changes
    /// </summary>
    void Application_MapItemChanged(object sender, MapItemEventArgs e)
    {
      // if the changed item is a view, then re-populate the gallery
      if (e.MapItem is View)
        PopulateGallery();
    }

    /// <summary>
    /// Raised when a gallery item is clicked
    /// </summary>
    /// <param name="item"></param>
    public override void OnClick(GalleryItem item)
    {
      // get the view from the item's tag property and zoom
      // the map to its viewpoint
      View view = item.Tag as View;
      ESRI.ArcGISExplorer.Application.Application.ActiveMapDisplay.ZoomTo(view.Viewpoint);
    }

    /// <summary>
    /// Helper method to clear and populate the gallery items
    /// with the views in the map
    /// </summary>
    private void PopulateGallery()
    {
      Items.Clear();

      // find all the Views in the map and add a gallery item for each one
      Map map = ESRI.ArcGISExplorer.Application.Application.ActiveMapDisplay.Map;
      foreach (View view in map.GetMapItems<View>())
        Items.Add(new GalleryItem(view.Name, Resources.Flag64, view.Name) { Tag = view });
    }
  }
}