Node in Xamarin.Android Diagram

13 Oct 20223 minutes to read

Nodes are graphical objects used to visually represent the geometrical information, process flow, internal business procedure, or any other kind of data. It represents the functions of a complete system in regards to how it interacts with external entities.

Create node

A node can be created and added to the diagram, either programmatically or interactively. Nodes are stacked on the diagram area from bottom to top.
The following code snippet illustrates how to create the node:

//Initialize Node
Node node = new Node(this);
node.OffsetX = 300;
node.OffsetY = 100;
node.Height = 100;
node.Width = 100;
diagram.AddNode(node);

Node in Xamarin.Android diagram

Create a node with custom path/shape

A node can be created with different custom shapes and paths using SfGraphics.
The following code snippet is used to create the node with custom shape or path.

//Initialize Node
Node node = new Node(this);
node.OffsetX = 300;
node.OffsetY = 100;
node.Height = 100;
node.Width = 100;
//Initialize SfGraphics
SfGraphics graphics = new SfGraphics();
Pen pen = new Pen();
pen.StrokeBrush = new SolidBrush(Android.Graphics.Color.Red);
pen.StrokeWidth = 2;
SolidBrush brush = new SolidBrush(Android.Graphics.Color.Yellow);
brush.FillColor = Android.Graphics.Color.Yellow;
pen.Brush = brush;
graphics.DrawRectangle(pen, new System.Drawing.Rectangle(0, 0, 50, 50));
//Update the SfGraphics to the node
node.UpdateSfGraphics(graphics);

Accessing a node from the diagram instance

You can access node from the diagram instance using the following code snippet:

//Access the node from the diagram instance.
Node node = diagram.Nodes[0];

Remove a node

The following code snippet is used to remove node from the diagram:

//Remove the node from the diagram.
Node node = new Node(this);
diagram.RemoveNode(node);

Customization:

You can customize the entire node with your own customized design using template property.

//Initialize the template
LinearLayout template = new LinearLayout(this);
template.SetBackgroundColor(Color.Green);
template.Layout(0, 0, (int)node.Width, (int)node.Height);
ImageView imageView = new ImageView(this);
imageView.SetImageResource(Resource.Drawable.employee);
imageView.Layout(0, 0, (int)node.Width, (int)node.Height);
template.AddView(imageView);
//Initialize node with template.
Node node = new Node(this) { Width = 120, Height = 40, OffsetX = 300, OffsetY = 60, Template = template };

Constraints

Node constraints allow to enable or disable the following behaviors of node.

  • Drag
  • Resize
  • Rotate
  • AnnotationEditing
  • IsLocked

Example:
The following code illustrates how to disable node dragging:

//Initialize the node with constraints
Node node = new Node(this) { EnableDrag = false, Width = 100, Height = 100, OffsetX = 100, OffsetY = 100};