New to Telerik UI for BlazorStart a free 30-day trial

Show Diagram Shape Text Below Image

Updated on Sep 23, 2025

Environment

ProductDiagram for Blazor

Description

This KB answers the following questions:

  • How to show the text label of a Diagram Shape below the image? By default, the text overlays the image, making it hard to read.
  • Can the Shape text be positioned under the image without using visual functions with JavaScript?
  • How to display and position the text in a Diagram Shape below the image?

Solution

To rearrange the text labels and images in the Blazor Diagram Shapes, use the Visual parameter of the <DiagramShapeDefaults> or <DiagramShape> tag. This will either affect all Shapes or a specific Shape. The associated JavaScript function may position the image and text with x and y properties, but usually, the better option is to use a Layout primitive as in the example below.

Arrange Diagram Shape image and text one below the other

<TelerikDiagram>
    <DiagramConnectionDefaults Type="@DiagramConnectionType.Cascading" />
    <DiagramLayout Type="@DiagramLayoutType.Tree" />
    <DiagramShapeDefaults Visual="imageShapeVisual">
        <DiagramShapeDefaultsContent Color="black" FontSize="16" />
    </DiagramShapeDefaults>

    <DiagramShapes>
        @foreach (DiagramShapeModel diagramShape in DiagramData)
        {
            <DiagramShape @key="@diagramShape" Id="@diagramShape.Id" DataItem="@diagramShape" />
        }
    </DiagramShapes>

    <DiagramConnections>
        @foreach (DiagramShapeModel diagramShape in DiagramData)
        {
            if (!string.IsNullOrEmpty(diagramShape.ParentId))
            {
                <DiagramConnection @key="@diagramShape" FromId="@diagramShape.ParentId" ToId="@diagramShape.Id" />
            }
        }
    </DiagramConnections>
</TelerikDiagram>

@* Move JavaScript code to a separate JS file *@
<script suppress-error="BL9992">
    function imageShapeVisual(context) {
        let diagramNS = TelerikBlazor.DiagramCommon;

        let shapeGroup = new diagramNS.Group();

        let shapeRectangle = new diagramNS.Rectangle({
            width: context.width,
            height: context.height,
            stroke: {
                color: "transparent"
            }
        });
        shapeGroup.append(shapeRectangle);

        let layoutSpacing = 6;
        // Make sure the layout content can fit, otherwise you will get unexpected results.
        let imageDimension = context.height - context.content.fontSize * 1.5;
        let imageTextRect = new diagramNS.Rect(0, 0, context.width, context.height);

        let imageTextLayout = new diagramNS.Layout(imageTextRect, {
            alignContent: "center",
            alignItems: "center",
            justifyContent: "center",
            orientation: "vertical",
            spacing: layoutSpacing
        });
        shapeGroup.append(imageTextLayout);

        let image = new diagramNS.Image({
            source: context.dataItem.Source,
            width: imageDimension,
            height: imageDimension
        });
        let title = new diagramNS.TextBlock({
            text: context.dataItem.Title,
            color: context.color
        });

        imageTextLayout.append(image);
        imageTextLayout.append(title);
        imageTextLayout.reflow();

        return shapeGroup;
    }
</script>

@code {
    private List<DiagramShapeModel> DiagramData { get; set; } = new()
    {
        new DiagramShapeModel() { Id = "shape-1", Title = "Shape 1 Title" },
        new DiagramShapeModel() { Id = "shape-2", ParentId = "shape-1", Title = "Shape 2 Title" },
        new DiagramShapeModel() { Id = "shape-3", ParentId = "shape-1", Title = "Shape 3 Title" },
    };

    public class DiagramShapeModel
    {
        public string Id { get; set; } = string.Empty;
        public string ParentId { get; set; } = string.Empty;
        public string Title { get; set; } = "Default Shape Title";
        public string Source { get; set; } = Base64SvgImage;
    }

    private const string Base64SvgImage = "";
}

See Also