官术网_书友最值得收藏!

Initializing a WF program using InArguments

In this task, we will create a WF program that accepts arguments when initialized in the WF host. In WF4, we can use InArguments to define the way data flows into an activity.

How to do it...

  1. Create a workflow project:

    Create a new Workflow Console Application under the Chapter01 solution. Name the project UseInArgument .

  2. Author the WF program:

    Create a workflow as shown in the following screenshot:

    How to do it...
  3. Write code to host the workflow.

    Open the Program.cs file and change the host code as follows:

    using System.Activities;
    using System.Activities.Statements;
    
    namespace UseInArgument {
    class Program {
            static void Main(string[] args) {
                WorkflowInvoker.Invoke(new Workflow1() 
                {
                    FirstName="Andrew",
                    SecondName="Zhu"
                });
            }
        }
    }
  4. Run it:

    Set UseInArgument as StartUp project. Press Ctrl+F5 to build and run the workflow without debugging. The application should run in a console window and print the following message:

    How to do it...

How it works...

Consider the following statement from the code we saw in the preceding section:

FirstName="Andrew"

FirstName is an InArgument type, but how can we assign a string to InArgument without any explicit cast? This is because InArgument is declared with an attribute System.ComponentModel.TypeConverterAttribute(System.Activities.XamlIntegration.InArgumentConverter). The class inheritance is shown in the following diagram:

How it works...

It is the InArgumentConverter that makes assigning a string to an InArgument possible. If we want to know more about TypeConverter, we can check MSDN the reference at http://msdn.microsoft.com/en-us/library/system.componentmodel.typeconverter.aspx

There's more

In WF3/3.5, we can pass values to Workflow wrapped in a Dictionary<T> object. This also applies to WF4.

using System.Activities;
using System.Activities.Statements;
using System.Collections.Generic;

namespace UseInArgument {
    class Program {
        static void Main(string[] args) {
            IDictionary<string, object> inputDictionary = 
                new Dictionary<string, object>() 
            { 
                {"FirstName","Andrew"},
                {"SecondName","Zhu"}
            };
            WorkflowInvoker.Invoke(new Workflow1(), 
                                   inputDictionary);
        }
    }
}

If we are creating workflows using imperative code, we can use InArgument in the following way:

public class WorkflowInCode:Activity {
    public InArgument<string> FirstName { get; set; }
    public InArgument<string> SecondName { get; set; }
    public WorkflowInCode() {
        this.Implementation = () => new Sequence() {
            Activities = {
                new WriteLine(){
                    Text=new InArgument<string>(
                            activityContext=>"My name is "+FirstName.Get(activityContext)
                        )
                },
                new WriteLine(){
                    Text=new InArgument<string>(
                            ActivityContext=>SecondName.Get(ActivityContext)
                        )
                }
            }
        };
    }
}
主站蜘蛛池模板: 双鸭山市| 新干县| 呼玛县| 涞水县| 义马市| 尉犁县| 建始县| 古浪县| 科技| 突泉县| 启东市| 萨嘎县| 昌黎县| 饶河县| 沁源县| 栖霞市| 大丰市| 通州市| 涪陵区| 安龙县| 宁阳县| 昌黎县| 封丘县| 永川市| 富顺县| 兴安盟| 南宁市| 任丘市| 丹江口市| 和政县| 固阳县| 内丘县| 张家港市| 新野县| 连云港市| 木兰县| 民县| 张北县| 宾阳县| 洪洞县| 桑植县|