デザイナーによって XAML ファイルに追加されたビュー状態の削除
ViewStateCleaningWriter サンプルでは、XamlWriter から派生するクラスを作成する方法を示し、XAML ファイルからビュー ステートを削除します。 Windows ワークフロー デザイナーにより、ビュー状態と呼ばれる情報が XAML ドキュメントに書き込まれます。 ビュー状態とは、レイアウトの配置などデザイン時に必要な情報で、実行時には不要な情報を指します。 ワークフロー デザイナーにより、編集時に XAML ドキュメントにこの情報が挿入されます。 ワークフロー デザイナーにより、mc:Ignorable
属性を持つ XAML ファイルにビュー状態が書き込まれます。そのため、ランタイムによって XAML ファイルが読み込まれるときに、この情報は読み込まれません。 このサンプルでは、XAML ノードの処理中にそのビューステート情報を削除するクラスを作成する方法を示します。
ディスカッション
このサンプルでは、カスタム ライターを作成する方法を示します。
カスタム XAML ライターをビルドするには、XamlWriter を継承するクラスを作成します。 XAML ライターは入れ子になっていることが多いので、通常は "内部" XAML ライターが追跡されます。 この "内部" ライターは XAML ライターの残りのスタックへの参照と考えることができ、これによって複数のエントリ ポイントで処理が実行されるようにし、処理を残りのスタックにデリゲートすることができます。
このサンプルには、重要な項目がいくつかあります。 その 1 つとして、書き込まれる項目がデザイナー名前空間からのものであるかどうかの確認が挙げられます。 これにより、ワークフローでデザイナー名前空間の他の型の使用が排除されることに注意してください。
static Boolean IsDesignerAttachedProperty(XamlMember xamlMember)
{
return xamlMember.IsAttachable &&
xamlMember.PreferredXamlNamespace.Equals(c_sapNamespaceURI, StringComparison.OrdinalIgnoreCase);
}
const String c_sapNamespaceURI = "http://schemas.microsoft.com/netfx/2009/xaml/activities/presentation";
// The next item of interest is the constructor, where the utilization of the inner XAML writer is seen.
public ViewStateCleaningWriter(XamlWriter innerWriter)
{
this.InnerWriter = innerWriter;
this.MemberStack = new Stack<XamlMember>();
}
XamlWriter InnerWriter {get; set; }
Stack<XamlMember> MemberStack {get; set; }
これにより、ノード ストリームの走査中に使用される XAML メンバーのスタックも作成されます。 このサンプルの残りの作業は、主に WriteStartMember
メソッドに含まれています。
public override void WriteStartMember(XamlMember xamlMember)
{
MemberStack.Push(xamlMember);
if (IsDesignerAttachedProperty(xamlMember))
{
m_attachedPropertyDepth++;
}
if (m_attachedPropertyDepth > 0)
{
return;
}
InnerWriter.WriteStartMember(xamlMember);
}
後続のメソッドで、まだビューステート コンテナーに含まれているかどうかがチェックされ、含まれている場合は制御が戻り、ノードはライター スタックに渡されません。
public override void WriteValue(Object value)
{
if (m_attachedPropertyDepth > 0)
{
return;
}
InnerWriter.WriteValue(value);
}
カスタム XAML ライターを使用するには、XAML ライターのスタックでまとめて連結する必要があります。 この使用方法を次のコードに示します。
XmlWriterSettings writerSettings = new XmlWriterSettings { Indent = true };
XmlWriter xmlWriter = XmlWriter.Create(File.OpenWrite(args[1]), writerSettings);
XamlXmlWriter xamlWriter = new XamlXmlWriter(xmlWriter, new XamlSchemaContext());
XamlServices.Save(new ViewStateCleaningWriter(ActivityXamlServices.CreateBuilderWriter(xamlWriter)), ab);
このサンプルを使用するには
Visual Studio を使用して、ViewStateCleaningWriter.sln ソリューション ファイルを開きます。
コマンド プロンプトを開き、ViewStageCleaningWriter.exe がビルドされているディレクトリに移動します。
Workflow1.xaml ファイルに対して ViewStateCleaningWriter.exe を実行します。
実行可能ファイルの構文の例を次に示します。
ViewStateCleaningWriter.exe [input file] [output file]
これにより、XAML ファイルは、すべてのビューステート情報が削除された状態で [出力ファイル] に出力されます。
注意
Sequence ワークフローでは、多数の仮想化のヒントが削除されます。 その結果、デザイナーは次回の読み込み時にレイアウトを再計算します。 このサンプルを Flowchart に対して使用すると、すべての配置情報および線のルーティング情報が削除され、後続のデザイナーへの読み込み時にすべてのアクティビティが画面の左側に積み上げられます。
このサンプルで使用するサンプル XAML ファイルを作成するには
Visual Studio を開きます。
新しいワークフロー コンソール アプリケーションを作成します。
いくつかのアクティビティをキャンバスにドラッグ アンド ドロップします。
ワークフロー XAML ファイルを保存します。
XAML ファイルを調べて、ビューステートの添付プロパティを確認します。
.NET