Udostępnij za pośrednictwem


Porady: programowane tworzenie projektów

Dodatki Visual Studio zostały zaniechane w programie Visual Studio 2013.Dodatki należy uaktualniać do pakietu rozszerzenia VSPackage.Aby uzyskać więcej informacji na temat uaktualniania, zobacz Często zadawane pytania: konwertowanie dodatków na rozszerzenia pakietu VSPackage.

Aby utworzyć projekt, wywołaj GetProjectTemplate, a następnie przekaż ścieżki szablonu zwrócone do AddFromTemplate.

Szablony projektów mają rozszerzenie nazwy pliku .vstemplate i są przechowywane w plikach .zip.Aby uzyskać ścieżkę pliku .vstemplate (w pliku zip), należy użyć GetProjectTemplate, a następnie przekazać go do AddFromTemplate, aby utworzyć projekt (i również rozwiązanie), jeśli nie jest już otwarte.Można wykonać tę operację dowolną liczbę razy, a każdy projekt zostanie dodany do aktualnie otwartego rozwiązania.

Szablony elementów projektu dla wszystkich języków można znaleźć w folderze \Program Files\Microsoft Visual Studio 10.0\Common7\IDE\ProjectTemplates\.Language\.

Można również utworzyć własne niestandardowe szablony 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żkę szablonów w polu Lokalizacja szablonów projektów użytkownika programu Visual Studio.

Niestandardowe szablony projektu wymagają unikatowych nazw plików, które nie wchodzą w konflikt z nazwami plików zdefiniowanymi w 10.0\Common7\IDE\ProjectTemplates\ Program Files\Microsoft Visual StudioLanguage\.

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.

[!UWAGA]

Polecenia menu i okien dialogowych mogą różnić się od tych opisanych w Pomocy, w zależności od ustawień aktywnych lub wydania.Procedury te zostały opracowane z ogólnych ustawień projektowych active.Aby zmienić swoje ustawienia, kliknij Importuj i eksportujustawienia w menu Narzędzia.Aby uzyskać więcej informacji, zobacz Dostosowywanie ustawień środowiska deweloperskiego w Visual Studio.

Tworzenie projektu

Aby programowo utworzyć projekt

  1. Uruchom Visual Studio i utwórz Visual Studio projekt dodatku.

  2. Do klasy dodatku Connect dodaj kod przykładu przedstawiony w dalszej części tego tematu.

  3. Uruchom projekt dodatku i aktywuj w Menedżerze dodatków.

    Aby to zrobić, kliknij przycisk AMenadżer dodatków w menu Narzędzia, a następnie wybierz dodatek.

Przykład

W poniższym przykładzie użyto GetProjectTemplate i AddFromTemplate , aby utworzyć dwie konsolę projektów, jedną Visual Basic i drugą Visual C#, w rozwiązaniu.

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)
    createProjectsFromTemplates(_applicationObject)
End Sub

Sub createProjectsFromTemplates(ByVal dte As DTE2)
    Try
        ' Create a solution with two projects in it, based on project 
        ' templates.
        Dim soln As Solution2 = CType(DTE.Solution, _
        Solution2)
        Dim csTemplatePath As String
        Dim vbTemplatePath As String
        Dim csPrjPath As String = _
        "C:\UserFiles\user1\addins\MyCSProject"
        Dim vbPrjPath As String = _
        "C:\UserFiles\user1\addins\MyVBProject"

        ' Get the project template path for a C# console project.
        ' Console Application is the template name that appears in the 
        ' right pane, "CSharp" is the Language(vstemplate) as seen in 
        ' the registry.
        csTemplatePath = soln.GetProjectTemplate _
        ("ConsoleApplication.zip", "CSharp")
        MsgBox("C# template path: " & csTemplatePath)
        ' Get the project template path for a Visual Basic
        ' console project.
        ' "vbproj: is the DefaultProjectExtension as seen in the 
        ' registry.
        vbTemplatePath = soln.GetProjectTemplate _
        ("ConsoleApplication.zip", "vbproj")
        MsgBox("Visual Basic template path: " & vbTemplatePath)
        ' Create a new C# console project using the template obtained 
        ' above.
        soln.AddFromTemplate(csTemplatePath, csPrjPath, _
          "New CSharp Console Project", False)
        ' Create a new Visual Basic console project using the template
        ' obtained above.
        soln.AddFromTemplate(vbTemplatePath, vbPrjPath, _
          "New Visual Basic Console Project", False)
    Catch ex As System.Exception
        MsgBox("ERROR: " & ex.ToString)
    End Try
End Sub
public void OnConnection(object application, ext_ConnectMode 
  connectMode, object addInInst, ref Array custom)
{
    _applicationObject = (DTE2)application;
    _addInInstance = (AddIn)addInInst;
    createProjectsFromTemplates(_applicationObject);
}

public void createProjectsFromTemplates(DTE2 dte)
{
    try
    {
        // Create a solution with two projects in it, based on project 
        // templates.
        Solution2 soln = (Solution2)dte.Solution;
        string csTemplatePath;
        string vbTemplatePath;
        string csPrjPath = "C:\\UserFiles\\user1\\addins\\MyCSProject";
        string vbPrjPath = "C:\\UserFiles\\user1\\addins\\MyVBProject";
        // Get the project template path for a C# console project.
        // Console Application is the template name that appears in 
        // the right pane. "CSharp" is the Language(vstemplate) as seen 
        // in the registry.
        csTemplatePath = soln.GetProjectTemplate("ConsoleApplication.zip", 
          "CSharp");
        System.Windows.Forms.MessageBox.Show("C# template path: " + 
          csTemplatePath);
        // Get the project template path for a Visual Basic console
        // project.
        // "vbproj: is the DefaultProjectExtension as seen in the 
        // registry.
        vbTemplatePath = soln.GetProjectTemplate("ConsoleApplication.zip", 
          "vbproj");
        System.Windows.Forms.MessageBox.Show("Visual Basic template path: " + 
          vbTemplatePath);
        // Create a new C# console project using the template obtained 
        // above.
        soln.AddFromTemplate(csTemplatePath, csPrjPath, "New CSharp 
          Console Project", false);
        // Create a new Visual Basic console project using the template 
        // obtained above.
        soln.AddFromTemplate(vbTemplatePath, vbPrjPath, "New VB Console 
          Project", false);
    }
    catch (System.Exception ex)
    {
        System.Windows.Forms.MessageBox.Show("ERROR: " + ex.Message);
    }
}

Zobacz też

Zadania

Porady: kompilowanie i uruchamianie kodu modelu obiektów automatyzacji — przykłady

Porady: programowane tworzenie elementów projektu

Koncepcje

Manipulowanie projektami Visual Basic i Visual C#

Manipulowanie projektami Visual C++

Inne zasoby

Kontrolowanie rozwiązania i jego projektów