Zadanie 3. Tworzenie okienka PropertyGrid i przybornika
W tym zadaniu utworzysz okienka Przybornik i WłaściwośćGrid i dodasz je do ponownie hostowanego przepływu pracy systemu Windows Projektant.
Aby uzyskać odwołanie, kod, który powinien znajdować się w pliku MainWindow.xaml.cs po wykonaniu trzech zadań w rehostingu przepływu pracy Projektant serii tematów, znajduje się na końcu tego tematu.
Aby utworzyć przybornik i dodać go do siatki
Otwórz projekt HostingApplication uzyskany zgodnie z procedurą opisaną w temacie Task 2: Host the Workflow Projektant (Hostowanie Projektant przepływu pracy).
W okienku Eksplorator rozwiązań kliknij prawym przyciskiem myszy plik MainWindow.xaml i wybierz pozycję Wyświetl kod.
Dodaj metodę
GetToolboxControl
doMainWindow
klasy, która tworzy klasę ToolboxControl, dodaje nową kategorię Przybornik do przybornika i przypisuje Assign typy działań i Sequence do tej kategorii.private ToolboxControl GetToolboxControl() { // Create the ToolBoxControl. var ctrl = new ToolboxControl(); // Create a category. var category = new ToolboxCategory("category1"); // Create Toolbox items. var tool1 = new ToolboxItemWrapper("System.Activities.Statements.Assign", typeof(Assign).Assembly.FullName, null, "Assign"); var tool2 = new ToolboxItemWrapper("System.Activities.Statements.Sequence", typeof(Sequence).Assembly.FullName, null, "Sequence"); // Add the Toolbox items to the category. category.Add(tool1); category.Add(tool2); // Add the category to the ToolBox control. ctrl.Categories.Add(category); return ctrl; }
Dodaj metodę prywatną
AddToolbox
doMainWindow
klasy, która umieszcza przybornik w lewej kolumnie w siatce.private void AddToolBox() { ToolboxControl tc = GetToolboxControl(); Grid.SetColumn(tc, 0); grid1.Children.Add(tc); }
Dodaj wywołanie metody
AddToolBox
w konstruktorzeMainWindow()
klasy, jak pokazano w poniższym kodzie:public MainWindow() { InitializeComponent(); this.RegisterMetadata(); this.AddDesigner(); this.AddToolBox(); }
Naciśnij klawisz F5 , aby skompilować i uruchomić rozwiązanie. Powinien zostać wyświetlony przybornik zawierający Assign działania i Sequence .
Aby utworzyć właściwośćGrid
W okienku Eksplorator rozwiązań kliknij prawym przyciskiem myszy plik MainWindow.xaml i wybierz pozycję Wyświetl kod.
Dodaj metodę
AddPropertyInspector
do klasy,MainWindow
aby umieścić okienko PropertyGrid w najbardziej prawej kolumnie w siatce:private void AddPropertyInspector() { Grid.SetColumn(wd.PropertyInspectorView, 2); grid1.Children.Add(wd.PropertyInspectorView); }
Dodaj wywołanie metody
AddPropertyInspector
w konstruktorzeMainWindow()
klasy, jak pokazano w poniższym kodzie:public MainWindow() { InitializeComponent(); this.RegisterMetadata(); this.AddDesigner(); this.AddToolBox(); this.AddPropertyInspector(); }
Naciśnij klawisz F5 , aby skompilować i uruchomić rozwiązanie. Wszystkie okienka Przybornik, kanwa projektu przepływu pracy i WłaściwościGrid powinny być wyświetlane, a podczas przeciągania Assign działania lub Sequence działania na kanwę projektu siatka właściwości powinna być aktualizowana w zależności od wyróżnionego działania.
Przykład
Plik MainWindow.xaml.cs powinien teraz zawierać następujący kod:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;
// dlls added.
using System.Activities;
using System.Activities.Core.Presentation;
using System.Activities.Presentation;
using System.Activities.Presentation.Metadata;
using System.Activities.Presentation.Toolbox;
using System.Activities.Statements;
using System.ComponentModel;
namespace HostingApplication
{
/// <summary>
/// Interaction logic for MainWindow.xaml
/// </summary>
public partial class MainWindow : Window
{
private WorkflowDesigner wd;
public MainWindow()
{
InitializeComponent();
RegisterMetadata();
AddDesigner();
this.AddToolBox();
this.AddPropertyInspector();
}
private void AddDesigner()
{
// Create an instance of WorkflowDesigner class.
this.wd = new WorkflowDesigner();
// Place the designer canvas in the middle column of the grid.
Grid.SetColumn(this.wd.View, 1);
// Load a new Sequence as default.
this.wd.Load(new Sequence());
// Add the designer canvas to the grid.
grid1.Children.Add(this.wd.View);
}
private void RegisterMetadata()
{
var dm = new DesignerMetadata();
dm.Register();
}
private ToolboxControl GetToolboxControl()
{
// Create the ToolBoxControl.
var ctrl = new ToolboxControl();
// Create a category.
var category = new ToolboxCategory("category1");
// Create Toolbox items.
var tool1 =
new ToolboxItemWrapper("System.Activities.Statements.Assign",
typeof(Assign).Assembly.FullName, null, "Assign");
var tool2 = new ToolboxItemWrapper("System.Activities.Statements.Sequence",
typeof(Sequence).Assembly.FullName, null, "Sequence");
// Add the Toolbox items to the category.
category.Add(tool1);
category.Add(tool2);
// Add the category to the ToolBox control.
ctrl.Categories.Add(category);
return ctrl;
}
private void AddToolBox()
{
ToolboxControl tc = GetToolboxControl();
Grid.SetColumn(tc, 0);
grid1.Children.Add(tc);
}
private void AddPropertyInspector()
{
Grid.SetColumn(wd.PropertyInspectorView, 2);
grid1.Children.Add(wd.PropertyInspectorView);
}
}
}