次の方法で共有


方法 : プログラムからプロジェクトを作成する

Visual Studio アドインは、Visual Studio 2013 では使用されなくなりました。 アドインを VSPackage 拡張機能にアップグレードしてください。 アップグレードの詳細については、「FAQ: アドインを VSPackage 拡張に変換する」を参照してください。

プロジェクトを作成するには、GetProjectTemplate を呼び出し、返されたテンプレート パスを AddFromTemplate に渡します。

プロジェクト テンプレートは、.vstemplate というファイル名拡張子を持ち、.zip ファイルに格納されます。 .zip ファイルに格納された .vstemplate ファイルのパスを取得するには、GetProjectTemplate を使用します。このパスを AddFromTemplate に渡すことによってプロジェクトを作成できます。ソリューションをまだ開いていない場合は、ソリューションを作成することもできます。 この操作は必要に応じて何度でも実行でき、作成された各プロジェクトは現在開いているソリューションに追加されます。

すべての言語のプロジェクト テンプレートは、Program Files\Microsoft Visual Studio 10.0\Common7\IDE\ProjectTemplates\Language\ に格納されています。

カスタムのプロジェクト テンプレートを独自に作成することもできます。 テンプレートを格納するディレクトリを指定するには、[ツール] メニューの [オプション] をクリックします。 [オプション] ダイアログ ボックスの左ペインで、[プロジェクトおよびソリューション] をクリックします。 テンプレートのパスを [Visual Studio ユーザー プロジェクト テンプレートの場所] ボックスに入力します。

カスタム プロジェクト テンプレートには、Program Files\Microsoft Visual Studio 10.0\Common7\IDE\ProjectTemplates\Language\ で定義されているファイル名と競合しない一意のファイル名を付ける必要があります。

8dot3 形式ではなく長いファイル名を使用するようにします。 詳細については、「Creating Project and Item Templates」を参照してください。

注意

実際に画面に表示されるダイアログ ボックスとメニュー コマンドは、アクティブな設定またはエディションによっては、ヘルプの説明と異なる場合があります。ここに記載されている手順は、全般的な開発設定が適用されているものとして記述されています。設定を変更するには、[ツール] メニューの [設定のインポートとエクスポート] をクリックします。詳細については、「Visual Studio での開発設定のカスタマイズ」を参照してください。

Visual C++ プロジェクト

プロジェクトをプログラムから作成するには

  1. Visual Studio を起動し、Visual Studio アドイン プロジェクトを作成します。

  2. アドインの Connect クラスに、後で示すプログラム例を追加します。

  3. アドイン プロジェクトを実行し、[アドイン マネージャー] でアクティブにします。

    これを行うには、[ツール] メニューの [アドイン マネージャー] をクリックし、アドインを選択します。

使用例

次の例は、GetProjectTemplate および AddFromTemplate を使用して、Visual Basic と Visual C# の 2 つのコンソール プロジェクトをソリューションに作成します。

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);
    }
}

参照

処理手順

方法 : オートメーション オブジェクト モデルのコード例をコンパイルおよび実行する

方法 : プログラムからプロジェクト項目を作成する

概念

Visual Basic および Visual C# のプロジェクトの操作

Visual C++ プロジェクトの操作

その他の技術情報

ソリューションとそのプロジェクトの制御