私の知る限り、これは InfoPath OOTB を使用して行うことはできないようです。ただし、カスタム開始フォームに関する私の経験のほとんどは、クラスをシリアル化して ActivationData に詰め込む ASP.NET Web フォームを使用していました。
考えられるアプローチは次のとおりです。
XML 解析をカプセル化する
xsd.exe を使用して、infopath フォームのスキーマに基づいてクラスを作成します。
1. XML 解析をカプセル化する
フォーム データをカプセル化し、xml 文字列をコンストラクタのパラメータとして受け取るクラスを作成できます。
Infopath フォーム:
<?xml version="1.0" encoding="UTF-8"?><?mso-infoPathSolution solutionVersion="1.0.0.2" productVersion="12.0.0" PIVersion="1.0.0.0" href="file:///C:\Documents%20and%20Settings\Administrator\My%20Documents\Template1.xsn" name="urn:schemas-microsoft-com:office:infopath:Template1:-myXSD-2005-10-21T21-12-27" ?><?mso-application progid="InfoPath.Document" versionProgid="InfoPath.Document.2"?><my:assetTracking xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xhtml="http://www.w3.org/1999/xhtml" xmlns:my="http://schemas.microsoft.com/office/infopath/2003/myXSD/2005-10-21T21:12:27" xmlns:xd="http://schemas.microsoft.com/office/infopath/2003" xml:lang="en-gb">
<my:employee>
<my:employeeName></my:employeeName>
<my:employeeDepartment></my:employeeDepartment>
</my:employee>
<my:assets>
<my:asset>
<my:assetID></my:assetID>
<my:assetDescription></my:assetDescription>
<my:assetMake></my:assetMake>
<my:assetModel></my:assetModel>
<my:assetSerialNumber></my:assetSerialNumber>
<my:assetAssignedTo></my:assetAssignedTo>
<my:assetDepartment></my:assetDepartment>
<my:assetLocation></my:assetLocation>
<my:assetCategory></my:assetCategory>
<my:assetNotes></my:assetNotes>
</my:asset>
</my:assets>
カスタム フォーム データ クラス
public class FormData
{
public string EmployeeName { get; set; }
public string EmployeeDepartment { get; set; }
public FormData(string formData)
{
XmlDocument document = new XmlDocument();
document.LoadXml(formData);
XmlNamespaceManager namespaceManager = new XmlNamespaceManager(document.NameTable);
namespaceManager.AddNamespace("my", "http://schemas.microsoft.com/office/infopath/2003/myXSD/2007-05-08T04:21:20");
// Initialize member fields
this.EmployeeName = document.SelectSingleNode("/my:employee/my:employeeName", nsmgr).InnerText;
this.EmployeeDepartment = doc.SelectSingleNode("/my:employee/my:employeeDepartment", nsmgr).InnerText;
etc....
}
}
2. xsd.exe の使用
xsd を使用して、ワークフロー フォームで使用されるスキーマに基づくクラスを生成できます。参照:方法: ワークフロー内の関連付けおよび開始フォーム データにアクセスする