New to Telerik UI for Blazor? Start a free 30-day trial
Show Diagram Shape Text Below Image
Updated on Sep 23, 2025
Environment
Product | Diagram 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 = "";
}