Dodatki programu VSTO
Po rozszerzeniu aplikacja pakietu Office licacji firmy Microsoft przez utworzenie dodatku VSTO napiszesz kod bezpośrednio względem ThisAddIn
klasy w projekcie. Za pomocą tej klasy można wykonywać zadania, takie jak uzyskiwanie dostępu do modelu obiektów aplikacji hosta pakietu Microsoft Office, dostosowywanie interfejsu użytkownika aplikacji oraz uwidacznianie obiektów w dodatku VSTO do innych rozwiązań pakietu Office.
Dotyczy: informacje w tym temacie dotyczą projektów dodatków VSTO. Aby uzyskać więcej informacji, zobacz Funkcje dostępne przez aplikacja pakietu Office lication i typ projektu.
Niektóre aspekty pisania kodu w projektach dodatków VSTO różnią się od innych typów projektów w programie Visual Studio. Wiele z tych różnic wynika ze sposobu, w jaki modele obiektów pakietu Office są widoczne dla kodu zarządzanego. Aby uzyskać więcej informacji, zobacz Pisanie kodu w rozwiązaniach pakietu Office.
Aby uzyskać ogólne informacje na temat dodatków VSTO i innych typów rozwiązań, które można utworzyć przy użyciu narzędzi deweloperskich pakietu Office w programie Visual Studio, zobacz Omówienie programowania rozwiązań pakietu Office (VSTO).
Użyj klasy ThisAddIn
Możesz rozpocząć pisanie kodu dodatku VSTO w ThisAddIn
klasie . Program Visual Studio automatycznie generuje tę klasę w pliku code ThisAddIn.vb (w Visual Basic) lub ThisAddIn.cs (w języku C#) w projekcie dodatku VSTO. Środowisko uruchomieniowe Visual Studio Tools dla pakietu Office automatycznie tworzy wystąpienie tej klasy, gdy aplikacja Microsoft aplikacja pakietu Office lication ładuje dodatek VSTO.
W klasie istnieją dwa domyślne programy obsługi zdarzeń ThisAddIn
. Aby uruchomić kod po załadowaniu dodatku VSTO, dodaj kod do programu obsługi zdarzeń ThisAddIn_Startup
. Aby uruchomić kod tuż przed zwolnieniem dodatku VSTO, dodaj kod do programu obsługi zdarzeń ThisAddIn_Shutdown
. Aby uzyskać więcej informacji na temat tych programów obsługi zdarzeń, zobacz Zdarzenia w projektach pakietu Office.
Uwaga
W programie Outlook domyślnie ThisAddIn_Shutdown
program obsługi zdarzeń nie zawsze jest wywoływany, gdy dodatek VSTO zostanie zwolniony. Aby uzyskać więcej informacji, zobacz Zdarzenia w projektach pakietu Office.
Uzyskiwanie dostępu do modelu obiektów aplikacji hosta
Aby uzyskać dostęp do modelu obiektów aplikacji hosta, użyj Application
pola ThisAddIn
klasy . To pole zwraca obiekt reprezentujący bieżące wystąpienie aplikacji hosta. W poniższej tabeli wymieniono typ wartości zwracanej dla Application
pola w każdym projekcie dodatku VSTO.
Aplikacja hosta | Zwracany typ wartości |
---|---|
Microsoft Office Excel | Application |
Microsoft Office InfoPath | Application |
Microsoft Office Outlook | Application |
Microsoft Office PowerPoint | Aplikacja |
Microsoft Office Project | Microsoft.Office.Interop.MSProject.Application |
Microsoft Office Visio | Microsoft.Office.Interop.Visio.Application |
Microsoft Office Word | Application |
Poniższy przykład kodu pokazuje, jak użyć Application
pola do utworzenia nowego skoroszytu w dodatku VSTO dla programu Microsoft Office Excel. Ten przykład ma zostać uruchomiony z ThisAddIn
klasy .
Aby wykonać to samo spoza ThisAddIn
klasy, użyj Globals
obiektu , aby uzyskać dostęp do ThisAddIn
klasy. Aby uzyskać więcej informacji na temat Globals
obiektu, zobacz Globalny dostęp do obiektów w projektach pakietu Office.
Excel.Workbook newWorkbook = Globals.ThisAddIn.Application.Workbooks.Add(System.Type.Missing);
Aby uzyskać więcej informacji na temat modeli obiektów określonych aplikacja pakietu Office lications firmy Microsoft, zobacz następujące tematy:
Uzyskiwanie dostępu do dokumentu po uruchomieniu aplikacja pakietu Office licacji
Nie wszystkie aplikacje pakietu Office 2010 automatycznie otwierają dokument podczas ich uruchamiania, a żadna z aplikacji pakietu Office 2013 nie otwiera dokumentu po ich uruchomieniu. W związku z tym nie dodawaj kodu w procedurze ThisAdd-In_Startup
obsługi zdarzeń, jeśli kod wymaga otwarcia dokumentu. Zamiast tego dodaj ten kod do zdarzenia, które aplikacja pakietu Office lication zgłasza, gdy użytkownik tworzy lub otwiera dokument. Dzięki temu można zagwarantować, że dokument jest otwarty, zanim kod wykona na nim operacje.
Poniższy przykład kodu współpracuje z dokumentem w programie Word tylko wtedy, gdy użytkownik utworzy dokument lub otworzy istniejący dokument.
private void ThisAddIn_Startup(object sender, System.EventArgs e)
{
this.Application.DocumentOpen +=
new Word.ApplicationEvents4_DocumentOpenEventHandler(WorkWithDocument);
((Word.ApplicationEvents4_Event)this.Application).NewDocument +=
new Word.ApplicationEvents4_NewDocumentEventHandler(WorkWithDocument);
}
private void WorkWithDocument(Microsoft.Office.Interop.Word.Document Doc)
{
try
{
Word.Range rng = Doc.Range(0, 0);
rng.Text = "New Text";
rng.Select();
}
catch (Exception ex)
{
// Handle exception if for some reason the document is not available.
}
}
Ta liczba elementów członkowskich usługiAddIn do użycia w innych zadaniach
W poniższej tabeli opisano inne typowe zadania i pokazano, których elementów członkowskich ThisAddIn
klasy można użyć do wykonywania zadań.
Zadanie | Członek do użycia |
---|---|
Uruchom kod, aby zainicjować dodatek VSTO po załadowaniu dodatku VSTO. | Dodaj kod do ThisAddIn_Startup metody . Jest to domyślna procedura obsługi zdarzeń dla Startup zdarzenia. Aby uzyskać więcej informacji, zobacz Zdarzenia w projektach pakietu Office. |
Uruchom kod, aby wyczyścić zasoby używane przez dodatek VSTO przed zwolnieniem dodatku VSTO. | Dodaj kod do ThisAddIn_Shutdown metody . Jest to domyślna procedura obsługi zdarzeń dla Shutdown zdarzenia. Aby uzyskać więcej informacji, zobacz Zdarzenia w projektach pakietu Office. Uwaga: w programie Outlook domyślnie ThisAddIn_Shutdown program obsługi zdarzeń nie zawsze jest wywoływany, gdy dodatek VSTO zostanie zwolniony. Aby uzyskać więcej informacji, zobacz Zdarzenia w projektach pakietu Office. |
Wyświetlanie niestandardowego okienka zadań. | CustomTaskPanes Użyj pola . Aby uzyskać więcej informacji, zobacz Niestandardowe okienka zadań. |
Uwidaczniaj obiekty w dodatku VSTO do innych rozwiązań pakietu Microsoft Office. | Zastąpij metodę RequestComAddInAutomationService . Aby uzyskać więcej informacji, zobacz Call code in VSTO Add-ins from other Office solutions (Wywoływanie kodu w dodatku VSTO z innych rozwiązań pakietu Office). |
Dostosowywanie funkcji w systemie Microsoft Office przez zaimplementowanie interfejsu rozszerzalności. | Zastąpi metodę RequestService , aby zwrócić wystąpienie klasy, która implementuje interfejs. Aby uzyskać więcej informacji, zobacz Dostosowywanie funkcji interfejsu użytkownika przy użyciu interfejsów rozszerzalności. Uwaga: aby dostosować interfejs użytkownika wstążki, możesz również zastąpić metodę CreateRibbonExtensibilityObject . |
Omówienie projektu klasy ThisAddIn
W projektach przeznaczonych dla programu .NET Framework 4 AddIn jest interfejs. Klasa ThisAddIn
pochodzi z AddInBase klasy . Ta klasa bazowa przekierowuje wszystkie wywołania do jego składowych do wewnętrznej implementacji interfejsu AddIn w środowisku uruchomieniowym Visual Studio Tools dla pakietu Office .
W projektach dodatków VSTO dla programu Outlook ThisAddIn
klasa pochodzi z Microsoft.Office.Tools.Outlook.OutlookAddIn
klasy w projektach przeznaczonych dla programu .NET Framework 3.5 i z OutlookAddInBase projektów przeznaczonych dla programu .NET Framework 4. Te klasy podstawowe zapewniają dodatkowe funkcje do obsługi regionów formularzy. Aby uzyskać więcej informacji na temat regionów formularzy, zobacz Tworzenie regionów formularzy programu Outlook.
Dostosowywanie interfejsu użytkownika aplikacja pakietu Office lications firmy Microsoft
Możesz programowo dostosować interfejs użytkownika aplikacja pakietu Office lications firmy Microsoft przy użyciu dodatku VSTO. Można na przykład dostosować wstążkę, wyświetlić niestandardowe okienko zadań lub utworzyć niestandardowy region formularza w programie Outlook. Aby uzyskać więcej informacji, zobacz Dostosowywanie interfejsu użytkownika pakietu Office.
Program Visual Studio udostępnia projektantów i klasy, których można użyć do tworzenia niestandardowych okienek zadań, dostosowań wstążki i regionów formularzy programu Outlook. Ci projektanci i klasy ułatwiają proces dostosowywania tych funkcji. Aby uzyskać więcej informacji, zobacz Niestandardowe okienka zadań, Projektant wstążki i Tworzenie regionów formularzy programu Outlook.
Jeśli chcesz dostosować jedną z tych funkcji w sposób, który nie jest obsługiwany przez klasy i projektantów, możesz również dostosować te funkcje, implementując interfejs rozszerzalności w dodatku VSTO. Aby uzyskać więcej informacji, zobacz Dostosowywanie funkcji interfejsu użytkownika przy użyciu interfejsów rozszerzalności.
Ponadto można zmodyfikować interfejs użytkownika dokumentów programu Word i skoroszytów programu Excel, generując elementy hosta, które rozszerzają zachowanie dokumentów i skoroszytów. Dzięki temu można dodawać kontrolki zarządzane do dokumentów i arkuszy. Aby uzyskać więcej informacji, zobacz Rozszerzanie dokumentów programu Word i skoroszytów programu Excel w dodatku VSTO w czasie wykonywania.
Wywoływanie kodu w dodatku VSTO z innych rozwiązań
Możesz uwidocznić obiekty w dodatku VSTO do innych rozwiązań, w tym innych rozwiązań pakietu Office. Jest to przydatne, jeśli dodatek VSTO udostępnia usługę, której chcesz użyć innych rozwiązań. Jeśli na przykład masz dodatek VSTO dla programu Microsoft Office Excel, który wykonuje obliczenia na danych finansowych z usługi internetowej, inne rozwiązania mogą wykonywać te obliczenia, wywołując dodatek VSTO programu Excel w czasie wykonywania.
Aby uzyskać więcej informacji, zobacz Call code in VSTO Add-ins from other Office solutions (Wywoływanie kodu w dodatku VSTO z innych rozwiązań pakietu Office).
Powiązana zawartość
- Opracowywanie rozwiązań pakietu Office
- Rozszerzanie dokumentów programu Word i skoroszytów programu Excel w dodatku VSTO w czasie wykonywania
- Wywoływanie kodu w dodatku VSTO z innych rozwiązań pakietu Office
- Przewodnik: wywoływanie kodu w dodatku VSTO z języka VBA
- Dostosowywanie funkcji interfejsu użytkownika przy użyciu interfejsów rozszerzalności
- Porady: tworzenie projektów pakietu Office w programie Visual Studio
- Architektura dodatków narzędzi VSTO
- Pisanie kodu w rozwiązaniach pakietu Office