Metoda Solution3.GetProjectItemTemplates —
Zwraca kolekcję szablonów element projektu dla określonego projektu.
Przestrzeń nazw: EnvDTE90
Zestaw: EnvDTE90 (w EnvDTE90.dll)
'Deklaracja
Function GetProjectItemTemplates ( _
Language As String, _
CustomDataSignature As String _
) As Templates
Templates GetProjectItemTemplates(
string Language,
string CustomDataSignature
)
Templates^ GetProjectItemTemplates(
String^ Language,
String^ CustomDataSignature
)
abstract GetProjectItemTemplates :
Language:string *
CustomDataSignature:string -> Templates
function GetProjectItemTemplates(
Language : String,
CustomDataSignature : String
) : Templates
Language
Typ: StringJęzyk używany do zapisywania szablonu elementu projektu.
CustomDataSignature
Typ: StringPodpis wszystkie metadane skojarzone z szablonem elementu projektu.
Typ: EnvDTE90.Templates
Kolekcja szablonów zawierających nazwy wszystkich szablonów elementu projektu.
Szablony projektów są przechowywane jako pliki zip.Ta metoda prosi o podanie nazwy i języka projektu i zwraca ścieżkę do szablonu.
Parametry GetProjectItemTemplate mogą być dostarczane na wiele różnych sposobów, jak pokazano poniżej:
Przenieś identyfikator GUID dla Visual Basic projektu wirtualnego na urządzenie inteligentne jako parametr Language i nazwę pliku zip jako TemplateName.
GetProjectItemTemplate("NETCFv2-Class.zip", "{3114F5B0-E435-4bc5-A03D-168E20D9BF83}");
Przenieś identyfikator GUID dla Visual Basic projektu wirtualnego na urządzenie inteligentne jako parametr Language i ciąg "Class" jako TemplateName.Ciąg "Class" pochodzi z hierarchii folderów i jest określany jako ciąg interfejsu użytkownika (UI).Inne ciągi interfejsu użytkownika to "HTML Page" i "Ekran powitalny".Ciągi interfejsu użytkownika zależne od ustawień regionalnych.Wykorzystanie nazwy pliku zip jest najbezpieczniejszym sposobem przekazywania parametru TemplateName.
GetProjectItemTemplate("Class", "{3114F5B0-E435-4bc5-A03D-168E20D9BF83}");
Przekaż w ciągu "VisualBasic" jako parametr Language i nazwę pliku zip dla parametru TemplateName.To działa, ponieważ NETCFv2 Class.zip jest unikatowy dla inteligentnych urządzeń.
GetProjectItemTemplate("NETCFv2-Class.zip", "VisualBasic/SmartDevice-NETCFv2");
Można również utworzyć niestandardowe szablony dla elementów projektu.Aby określić katalog, w którym będą przechowywane szablony, kliknij przycisk Opcje w menu Narzędzia.W lewym okienku okna dialogowego Opcje, kliknij przycisk Projekty i rozwiązania.Wpisz ścieżki szablonów w polach lokalizacji szablonów elementów użytkownika programu Visual Studio.Zamiast tego można zaakceptować lokalizację domyślną.
Szablony niestandardowe wymagają unikatowych nazw plików, które nie wchodzą w konflikt z nazwami plików określonych w:
<dysk>: \Program Files\Microsoft Visual Studio 9\Common7\IDE\ItemTemplates\Język.
Upewnij się, że używasz długich nazw plików (w przeciwieństwie do 8dot3).Aby uzyskać więcej informacji, zobacz Creating Project and Item Templates.
Więcej informacji na temat uruchamiania tego kodu dodatku: Porady: kompilowanie i uruchamianie kodu modelu obiektów automatyzacji — przykłady.
Public Sub OnConnection(ByVal application As Object, _
ByVal connectMode As ext_ConnectMode, ByVal addInInst As Object, _
ByRef custom As Array) Implements IDTExtensibility2.OnConnection
_applicationObject = CType(application, DTE2)
_addInInstance = CType(addInInst, AddIn)
SolutionExample(_applicationObject)
End Sub
Sub SolutionExample(ByVal dte As DTE2)
' This function creates a solution and adds a Visual C# Console
' project to it.
Try
Dim soln As Solution3 = CType(DTE.Solution, Solution3)
Dim csTemplatePath As String
' This path must exist on your computer.
' Replace <file path> below with an actual path.
Dim csPrjPath As String = "<file path>"
MsgBox("starting")
' Get the project template path for a C# console project.
csTemplatePath = soln.GetProjectTemplate _
("ConsoleApplication.zip", "CSharp")
' Create a new C# Console project using the template obtained
' above.
soln.AddFromTemplate(csTemplatePath, csPrjPath, _
"New CSharp Console Project", False)
MsgBox("done")
Catch ex As System.Exception
MsgBox(ex.ToString)
End Try
End Sub
using System.Windows.Forms;
public void OnConnection(object application,
Extensibility.ext_ConnectMode connectMode, object addInInst,
ref System.Array custom)
{
_applicationObject = (DTE2)application;
_addInInstance = (AddIn)addInInst;
// Pass the applicationObject member variable to the code example.
SolutionExample((DTE2)_applicationObject);
}
public void SolutionExample(DTE2 dte)
{
// This function creates a solution and adds a Visual C# Console
// project to it.
try{
Solution3 soln = (Solution3)_applicationObject.Solution;
String csTemplatePath;
// The file path must exist on your computer.
// Replace <file path> below with an actual path.
String csPrjPath = "<file path>";
"<file path>MessageBox.Show("Starting...");
"<file path>"<file path>csTemplatePath =
soln.GetProjectTemplate("ConsoleApplication.zip", "CSharp");
// Create a new C# Console project using the template obtained
// above.
soln.AddFromTemplate(csTemplatePath, csPrjPath,
"New CSharp Console Project", false);
MessageBox.Show("Done!");
}
catch(SystemException ex)
{
MessageBox.Show("ERROR: " + ex);
}
}
- Pełne zaufanie do bezpośredniego wywołującego. Tego elementu członkowskiego nie można używać w kodzie częściowo zaufanym. Aby uzyskać więcej informacji, zobacz Używanie bibliotek pochodzących z częściowo zaufanego kodu.
Porady: kompilowanie i uruchamianie kodu modelu obiektów automatyzacji — przykłady