Поделиться через


Сохранение динамических элементов управления в документах Office

Обновлен: Июль 2008

Применение

Сведения в данном разделе относятся только к указанным проектам Visual Studio Tools for Office и версиям приложений Microsoft Office.

Проекты уровня документа

  • Excel 2003

  • Excel 2007

  • Word 2003

  • Word 2007

Проекты уровня приложения

  • Excel 2007

  • Word 2007

Дополнительные сведения см. в разделе Доступность функций по типам приложений и проектов.

Элементы управления, добавленные во время выполнения, не сохраняются при сохранении и закрытии документа или книги. Поведение ведущих элементов управления и элементов управления Windows Forms различается. В обоих случаях можно добавить в решение код, который будет пересоздавать элементы управления при повторном открытии документа.

Элементы управления, добавляемые в документ во время выполнения, называются динамическими элементами управления. Дополнительные сведения о динамических элементах управления см. в разделе Добавление элементов управления в документы Office во время выполнения.

Сохранение элементов управления ведущего приложения в документе

Когда документ сохраняется, а затем закрывается, все динамические ведущие элементы управления Windows Forms удаляются из этого документа. Остаются только собственные базовые объекты Office. Например, элемент управления Microsoft.Office.Tools.Excel.ListObject становится элементом Microsoft.Office.Interop.Excel.ListObject. Собственные объекты Office не связаны с событиями ведущих элементов управления и не имеют функции привязки данных, как в случае с ведущими элементами управления.

В следующей таблице перечислены собственные объекты Office, которые остаются в документе, для каждого типа ведущих элементов управления.

Тип ведущего элемента управления

Тип собственного объекта Office

Microsoft.Office.Tools.Excel.Chart

Microsoft.Office.Interop.Excel.Chart

Microsoft.Office.Tools.Excel.ListObject

Microsoft.Office.Interop.Excel.ListObject

Microsoft.Office.Tools.Excel.NamedRange

Microsoft.Office.Interop.Excel.Range

Microsoft.Office.Tools.Word.Bookmark

Microsoft.Office.Interop.Word.Bookmark

Microsoft.Office.Tools.Word.BuildingBlockGalleryContentControl

Microsoft.Office.Tools.Word.ComboBoxContentControl

Microsoft.Office.Tools.Word.ContentControl

Microsoft.Office.Tools.Word.DatePickerContentControl

Microsoft.Office.Tools.Word.DropDownListContentControl

Microsoft.Office.Tools.Word.GroupContentControl

Microsoft.Office.Tools.Word.PictureContentControl

Microsoft.Office.Tools.Word.PlainTextContentControl

Microsoft.Office.Tools.Word.RichTextContentControl

Microsoft.Office.Interop.Word.ContentControl

Повторное создание динамических ведущих элементов управления при открытии документов

Динамический ведущий элемент управления можно воссоздавать на месте существующего собственного элемента управления при каждом открытии документа. Такой способ создания ведущих элементов управления при открытии документа имитирует ожидаемый пользователем процесс.

Чтобы воссоздать ведущий элемент управления для Word или элемент управления для Excel Microsoft.Office.Tools.Excel.NamedRange или Microsoft.Office.Tools.Excel.ListObject, следует использовать метод Add<класса элемента управления> классов Microsoft.Office.Tools.Excel.ControlCollection или Microsoft.Office.Tools.Word.ControlCollection, который содержит параметр для собственного объекта Office.

Например, чтобы создать ведущий элемент управления Microsoft.Office.Tools.Excel.ListObject на основе существующего собственного объекта Microsoft.Office.Interop.Excel.ListObject при открытии документа, следует использовать метод AddListObject(ListObject) и передать ему существующий элемент управления Microsoft.Office.Interop.Excel.ListObject. Следующий пример демонстрирует этот способ в проекте уровня приложения для Excel 2007. Код воссоздает динамический элемент управления Microsoft.Office.Tools.Excel.ListObject на основе существующего объекта Microsoft.Office.Interop.Excel.ListObject с именем MyListObject в классе Sheet1.

Private vstoListObject As Microsoft.Office.Tools.Excel.ListObject
Private Const DISP_E_BADINDEX As Integer = CInt(&H8002000B)

Private Sub Sheet1_Startup(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Startup
    Dim nativeListObject As Excel.ListObject = Nothing

    Try
        nativeListObject = Me.ListObjects("MyListObject")
    Catch ex As System.Runtime.InteropServices.COMException
        ' "MyListObject" does not exist.
        If ex.ErrorCode <> DISP_E_BADINDEX Then
            Throw
        End If
    End Try

    If nativeListObject IsNot Nothing Then
        vstoListObject = Me.Controls.AddListObject(nativeListObject)
    End If
End Sub
private Microsoft.Office.Tools.Excel.ListObject vstoListObject;
private const int DISP_E_BADINDEX = unchecked((int)0x8002000B);

private void Sheet1_Startup(object sender, System.EventArgs e)
{
    Excel.ListObject nativeListObject = null;

    try
    {
        nativeListObject = this.ListObjects.get_Item("MyListObject");
    }
    catch (System.Runtime.InteropServices.COMException ex)
    {
        // "MyListObject" does not exist.
        if (ex.ErrorCode != DISP_E_BADINDEX)
            throw;
    }

    if (nativeListObject != null)
    {
        vstoListObject = this.Controls.AddListObject(nativeListObject);
    }
}

Примеры создания динамических элементов управления в проектах уровня документа см. в разделах Пример динамических элементов управления Excel и Пример Word Dynamic Controls.

Примеры создания динамических элементов управления в проектах уровня приложения см. в разделах Пример динамических элементов управления надстройками Excel и Пример динамических элементов управления в надстройках Word.

Воссоздание Объектов списка в проектах Excel 2003 и Excel 2007 (до пакета обновления 1)

Метод AddListObject(ListObject) ранее не использовался для проектов Excel 2007, разработанных в Visual Studio 2008 с пакетом обновления 1 (SP 1). При использовании проекта Excel 2007 без установленного пакета обновлений 1 (SP1), либо при использовании проекта Excel 2003, воспользоваться этим методом для воссоздания динамического элемента управления Microsoft.Office.Tools.Excel.ListObject нельзя.

Вместо этого следует сначала удалить собственный объект Microsoft.Office.Interop.Excel.ListObject и только затем воссоздавать динамический элемент управления Microsoft.Office.Tools.Excel.ListObject с помощью метода AddListObject(Range, String). Пример кода, демонстрирующий данный способ, см. в разделе Пример динамических элементов управления Excel.

Если сначала не удалить собственный объект Microsoft.Office.Interop.Excel.ListObject, будет вызвано исключение COMException при попытке воссоздать элемент управления Microsoft.Office.Tools.Excel.ListObject, поскольку Excel не поддерживает создание перекрывающихся объектов списка.

Воссоздание графиков

Для воссоздания графика Microsoft.Office.Tools.Excel.Chart сначала следует удалить собственный объект Microsoft.Office.Interop.Excel.Chart, а затем воссоздать график Microsoft.Office.Tools.Excel.Chart с помощью метода AddChart(Range, String) or AddChart(Double, Double, Double, Double, String). Метода Add<класс элемента управления>, который позволит создать новый графикMicrosoft.Office.Tools.Excel.Chart на основе существующего графика Microsoft.Office.Interop.Excel.Chart, не существует.

Если собственный объект Microsoft.Office.Interop.Excel.Chart не будет предварительно удален, следовательно, при повторном создании графикаMicrosoft.Office.Tools.Excel.Chart будет создан второй, дублирующий график.

Сохранение элементов управления Windows Forms в документах

Когда документ сохраняется, а затем закрывается, среда Visual Studio Tools for Office автоматически удаляет все динамически созданные элементы управления Windows Forms из документа. В то же время поведение настроек уровня документа и проектов уровня приложения различается.

В настройках уровня документа элементы управления и их базовые оболочки ActiveX (которые используются для размещения элементов управления в документе) удаляются при следующем открытии документа. Указания на то, что в этом месте были элементы управления, отсутствуют.

В надстройках на уровне приложения элементы управления удаляются, однако оболочки ActiveX остаются в документе. Оболочки ActiveX видимы и при следующем открытии документа. В Excel оболочки ActiveX отображают изображения внешнего вида элементов управления на момент последнего сохранения документа. В Word оболочки ActiveX невидимы до тех пор, пока пользователь не щелкнет на них. В этом случае отображается пунктирная линии, представляющая границу элементов управления. Существует несколько способов удаления оболочек ActiveX. Дополнительные сведения см. в разделе Удаление оболочек ActiveX в надстройке.

Повторное создание элементов управления Windows Forms при открытии документов

При повторном открытии документа можно воссоздавать удаленные элементы управления Windows Forms. Для этого решение должно выполнить следующие задачи:

  1. Хранить данные о размере, местоположении и состоянии элементов управления при сохранении и закрытии документа. В настройке уровня документа эти данные можно сохранить в кэш данных документа. В надстройке уровня приложения эти данные можно сохранить в пользовательской XML-части документа.

  2. Воссоздать элементы управления в событии, которое вызывается при открытии документа. В проектах уровня документа можно сделать это в обработчике событий Sheetn_Startup или ThisDocument_Startup. В проектах уровня приложения это можно сделать в обработчиках событий для событий WorkbookOpen или DocumentOpen.

Примеры создания динамических элементов управления в проектах уровня документа см. в разделах Пример динамических элементов управления Excel и Пример Word Dynamic Controls.

Примеры для проектов уровня приложения см. в разделах Пример динамических элементов управления надстройками Excel и Пример динамических элементов управления в надстройках Word.

Удаление оболочек ActiveX в надстройке

При добавлении динамических элементов управления Windows Forms в документы с помощью надстройки можно избежать появления в документе оболочек ActiveX для элементов управления при повторном открытии документа.

Удаление оболочки ActiveX при открытии документа

Чтобы удалить все оболочки ActiveX, необходимо вызвать метод GetVstoObject объекта Microsoft.Office.Interop.Word.Document или Microsoft.Office.Interop.Excel.Workbook, представляющий вновь открытый документ. Например, чтобы удалить все оболочки ActiveX из документа Word, можно вызвать метод GetVstoObject объекта Document, переданный в обработчик событий для события DocumentOpen.

Данная процедура имеет смысл, если известно, что документ будет открываться только на компьютерах с установленной надстройкой. Если документ будет передаваться другим пользователям, на компьютерах которых не установлена надстройка, рекомендуется вместо этого удалить элементы управления перед закрытием документа.

Следующий пример кода демонстрирует вызов метода GetVstoObject при открытии документа.

Private Sub Application_DocumentOpen_ClearActiveXWrappers( _
    ByVal Doc As Word.Document) Handles Application.DocumentOpen
    Dim vstoDocument As Microsoft.Office.Tools.Word.Document = Doc.GetVstoObject()
End Sub
private void Application_DocumentOpen_ClearActiveXWrappers(Word.Document Doc)
{
    Microsoft.Office.Tools.Word.Document vstoDocument = Doc.GetVstoObject();
}

Хотя метод GetVstoObject используется в основном для создания новых ведущих элементов управления во время выполнения, с помощью данного метода можно также удалить все оболочки ActiveX из документа при первом вызове метода для конкретного документа. Дополнительные сведения об использовании метода GetVstoObject, см. в разделе Расширение документов Word и книг Excel в надстройках уровня приложения во время выполнения.

Обратите внимание, что в случае, если надстройка создает динамические элементы управления при открытии документа, она также вызовет метод GetVstoObject в ходе процесса создания элементов управления. В рамках данного сценария необязательно добавлять отдельный вызов метода GetVstoObject чтобы удалить все оболочки ActiveX.

Удаление динамических элементов управления до закрытия документа

Надстройка может явным образом удалить все динамические элементы управления из документа перед его закрытием. Данная процедура имеет смысл в том случае, если документы заведомо будут передаваться пользователям, на компьютерах которых не установлена надстройка.

Следующий пример кода демонстрирует удаление всех элементов управления Windows Forms из документа Word перед его закрытием.

Private Sub Application_DocumentBeforeClose(ByVal Doc As Word.Document, _
    ByRef Cancel As Boolean) Handles Application.DocumentBeforeClose

    If Doc.HasVstoObject() Then
        Dim vstoDocument As Microsoft.Office.Tools.Word.Document = _
            Doc.GetVstoObject()
        Dim controlsToRemove As System.Collections.ArrayList = _
            New System.Collections.ArrayList()

        ' Get all of the Windows Forms controls.
        For Each control As Object In vstoDocument.Controls
            If TypeOf control Is System.Windows.Forms.Control Then
                controlsToRemove.Add(control)
            End If
        Next

        ' Remove all of the Windows Forms controls from the document.
        For Each control As Object In controlsToRemove
            vstoDocument.Controls.Remove(control)
        Next
    End If
End Sub
void Application_DocumentBeforeClose(Word.Document Doc, ref bool Cancel)
{
    if (Doc.HasVstoObject())
    {
        Microsoft.Office.Tools.Word.Document vstoDocument = Doc.GetVstoObject();
        System.Collections.ArrayList controlsToRemove = 
            new System.Collections.ArrayList();

        // Get all of the Windows Forms controls.
        foreach (object control in vstoDocument.Controls)
        {
            if (control is System.Windows.Forms.Control)
            {
                controlsToRemove.Add(control);
            }
        }

        // Remove all of the Windows Forms controls from the document.
        foreach (object control in controlsToRemove)
        {
            vstoDocument.Controls.Remove(control);
        }
    }
}

См. также

Задачи

Пример динамических элементов управления Excel

Пример Word Dynamic Controls

Пример динамических элементов управления надстройками Excel

Пример динамических элементов управления в надстройках Word

Основные понятия

Добавление элементов управления в документы Office во время выполнения

Вспомогательные методы для элементов управления ведущего приложения

Вспомогательные методы для элементов управления Windows Forms

Журнал изменений

Дата

Журнал

Причина

Июль 2008

Дополнительные сведения о сохранении динамических элементов управления объектом списка в надстройках уровня приложения.

Изменение функции SP1.