Hi Team,
I'm using the Blazor diagram with custom images as shape type. But for a better visibility I would like to show the text below the image. By default, the text overlays the image, making it hard to read.
Is there an easy way to achieve this without using visual functions with javascript?
Thank you very much in advance!
1 Answer, 1 is accepted
0
Hi Alexander,
Indeed, you need a visual function for the Diagram Shape. Here is some code for inspiration:
https://blazorrepl.telerik.com/wfajbAPP00dfyLX349
<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>
<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;
// if the content in the layout cannot fit, 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 = "";
}
Regards,
Dimo
Progress Telerik
Love the Telerik and Kendo UI products and believe more people should try them? Invite a fellow developer to become a Progress customer and each of you can get a $50 Amazon gift voucher.