Axes in Circular Gauge Control
19 Dec 202215 minutes to read
By default, gauge will be displayed with an axis. Each axis contains its own ranges, pointers and annotation.
Axis Customization
You can customize the width and color of an axis line by using lineStyle property. Background for an axis can be customized by using background property.
@using Syncfusion.EJ2;
@Html.EJS().CircularGauge("circular2").Axes(axes => axes.LineStyle(ls =>ls.Color("red").Width(2))
.Background("rgba(0, 128, 128, 0.3)").Add()).Render()
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;
using EJ2_Core_Application.Models;
using Newtonsoft.Json;
namespace EJ2_Core_Application.Controllers
{
public class HomeController : Controller
{
public IActionResult Index()
{
return View();
}
}
}
Angles and Direction
Circular gauge axis can sweep from 0 to 360 degrees. By default start angle of an axis is 200 degree and end angle is 160 degree and you can customize this option by using startAngle and endAngle property.
@using Syncfusion.EJ2;
@Html.EJS().CircularGauge("circular").Axes(axes=>axes.StartAngle(270).EndAngle(90).Add()).Render()
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;
using EJ2_Core_Application.Models;
using Newtonsoft.Json;
namespace EJ2_Core_Application.Controllers
{
public class HomeController : Controller
{
public IActionResult Index()
{
return View();
}
}
}
The direction property enables you to render the gauge axis either in ClockWise
or in AntiClockWise
direction.
@using Syncfusion.EJ2;
@Html.EJS().CircularGauge("circular").Axes(axes=>axes.Direction(Syncfusion.EJ2.CircularGauge.GaugeDirection.AntiClockWise).Add()).Render()
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;
using EJ2_Core_Application.Models;
using Newtonsoft.Json;
namespace EJ2_Core_Application.Controllers
{
public class HomeController : Controller
{
public IActionResult Index()
{
return View();
}
}
}
Axis Radius
By default, radius of an axis is calculated based on the available size. You can customize this, by using radius property. It takes value either in percentage
or in pixel
.
In Pixel
You can set the radius of the gauge in pixel as demonstrated below,
@using Syncfusion.EJ2;
@Html.EJS().CircularGauge("circular").Axes(axes=>axes.Radius("150").Add()).Render()
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;
using EJ2_Core_Application.Models;
using Newtonsoft.Json;
namespace EJ2_Core_Application.Controllers
{
public class HomeController : Controller
{
public IActionResult Index()
{
return View();
}
}
}
In Percentage
By setting value in percentage, gauge gets its dimension with respect to its available size. For example, when the radius is ‘50%’, gauge renders to half of the available size.
@using Syncfusion.EJ2;
@Html.EJS().CircularGauge("circular").Axes(axes=>axes.Radius("50%").Add()).Render()
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;
using EJ2_Core_Application.Models;
using Newtonsoft.Json;
namespace EJ2_Core_Application.Controllers
{
public class HomeController : Controller
{
public IActionResult Index()
{
return View();
}
}
}
Ticks
You can customize the height, color and width of major and minor ticks by using majorTicks and minorTicks property. By default, interval for majorTicks
will be calculated automatically and also you can customize the interval for major and minor ticks using interval
property.
@using Syncfusion.EJ2;
@Html.EJS().CircularGauge("circular2").Axes(axes => axes
.MajorTicks(majortick => majortick.Interval(10).Color("red").Height(10).Width(3))
.MinorTicks(minortick =>minortick.Interval(5).Color("green").Height(5).Width(2))
.Add()).Render()
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;
using EJ2_Core_Application.Models;
using Newtonsoft.Json;
namespace EJ2_Core_Application.Controllers
{
public class HomeController : Controller
{
public IActionResult Index()
{
return View();
}
}
}
Tick Position
Both minor and major ticks can be moved by using offset and position property. The offset defines the distance between the axis and ticks. By default, offset value is 0. The position will place the ticks either inside or outside of the axis. By default, ticks will be placed inside
the axis.
@using Syncfusion.EJ2;
@using Syncfusion.EJ2.CircularGauge;
@Html.EJS().CircularGauge("circular2").Axes(axes => axes
.MajorTicks(majortick => majortick.Interval(10).Color("red").Height(10).Width(3).Position(Position.Inside).Offset(5))
.MinorTicks(minortick =>minortick.Interval(10).Color("green").Height(5).Width(2).Position(Position.Inside).Offset(5))
.Add()).Render()
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;
using EJ2_Core_Application.Models;
using Newtonsoft.Json;
namespace EJ2_Core_Application.Controllers
{
public class HomeController : Controller
{
public IActionResult Index()
{
return View();
}
}
}
Labels
Labels of an axis can be customized by using font property in labelStyle options.
@using Syncfusion.EJ2;
@using Syncfusion.EJ2.CircularGauge;
@Html.EJS().CircularGauge("circular2").Axes(axes => axes
.LabelStyle(ls => ls.Font(new CircularGaugeFont {Color="red", Size="20px", FontWeight="Bold" })).Add()).Render()
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;
using EJ2_Core_Application.Models;
using Newtonsoft.Json;
namespace EJ2_Core_Application.Controllers
{
public class HomeController : Controller
{
public IActionResult Index()
{
return View();
}
}
}
Label Position
Labels can be moved by using offset or position property. The offset defines the distance between the labels and ticks. By default, offset value is 0. The position will place the labels either inside or outside of the axis. By default, labels will be placed inside
the axis.
@using Syncfusion.EJ2;
@using Syncfusion.EJ2.CircularGauge;
@Html.EJS().CircularGauge("circular").Axes(axes => axes
.LabelStyle(labels =>labels.Position(Position.Outside).Offset(5)).Add()).Render()
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;
using EJ2_Core_Application.Models;
using Newtonsoft.Json;
namespace EJ2_Core_Application.Controllers
{
public class HomeController : Controller
{
public IActionResult Index()
{
return View();
}
}
}
Auto Angle
Labels can be swept along the axis angle by enabling autoAngle property.
@using Syncfusion.EJ2;
@Html.EJS().CircularGauge("circular").Axes(axes => axes
.LabelStyle(labels =>labels.AutoAngle(true)).Add()).Render()
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;
using EJ2_Core_Application.Models;
using Newtonsoft.Json;
namespace EJ2_Core_Application.Controllers
{
public class HomeController : Controller
{
public IActionResult Index()
{
return View();
}
}
}
Smart Labels
When an axis makes a complete circle, then the first and last label of the axis will get overlap with each other. In this scenario, you can either hide 1st or last label using hiddenLabel property. When hiddenLabel
value is First
, then the 1st label will be hidden and when the hiddenLabel
value is ‘Last’, then the last label will be hidden.
using Syncfusion.EJ2.CircularGauge;
@using Syncfusion.EJ2;
@Html.EJS().CircularGauge("circular").Axes(axes => axes.Minimum(0).Maximum(12).StartAngle(0).EndAngle(360)
.MajorTicks(majorticks => majorticks.Interval(1)
.Position(Position.Inside).Height(10))
.MinorTicks(minorticks =>minorticks.Interval(0.2)
.Position(Position.Inside).Height(5))
.LabelStyle(labels => labels.Position(Position.Inside)
.HiddenLabel(HiddenLabel.First)).Add()).Render()
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;
using EJ2_Core_Application.Models;
using Newtonsoft.Json;
namespace EJ2_Core_Application.Controllers
{
public class HomeController : Controller
{
public IActionResult Index()
{
return View();
}
}
}
Label Format
Axis labels can be formatted by using format property in labelStyle and its supports all globalize format.
@using Syncfusion.EJ2;
@Html.EJS().CircularGauge("circular").Axes(axes => axes
.LabelStyle(labels =>labels.Format("p1")).Add()).Render()
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;
using EJ2_Core_Application.Models;
using Newtonsoft.Json;
namespace EJ2_Core_Application.Controllers
{
public class HomeController : Controller
{
public IActionResult Index()
{
return View();
}
}
}
The following table describes the result of applying some commonly used label formats on numeric values.
Label Value | Label Format property value | Result | Description |
1000 | n1 | 1000.0 | The Number is rounded to 1 decimal place |
1000 | n2 | 1000.00 | The Number is rounded to 2 decimal places |
1000 | n3 | 1000.000 | The Number is rounded to 3 decimal places |
0.01 | p1 | 1.0% | The Number is converted to percentage with 1 decimal place |
0.01 | p2 | 1.00% | The Number is converted to percentage with 2 decimal places |
0.01 | p3 | 1.000% | The Number is converted to percentage with 3 decimal places |
1000 | c1 | $1,000.0 | The Currency symbol is appended to number and number is rounded to 1 decimal place |
1000 | c2 | $1,000.00 | The Currency symbol is appended to number and number is rounded to 2 decimal places |
Custom Label Format
Axis labels support custom label format using placeholder like {value}°C, in which the value represent the axis label e.g 20°C.
@using Syncfusion.EJ2;
@Html.EJS().CircularGauge("circular").Axes(axes => axes
.LabelStyle(labels =>labels.Format("{value}°C")).Add()).Render()
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;
using EJ2_Core_Application.Models;
using Newtonsoft.Json;
namespace EJ2_Core_Application.Controllers
{
public class HomeController : Controller
{
public IActionResult Index()
{
return View();
}
}
}
Hide Intersecting Axis Labels
When the axis labels overlap with each other, you can hide the intersected labels by setting the hideIntersectingLabel
property to true in the axis.
@using Syncfusion.EJ2;
@Html.EJS().CircularGauge("container").Axes(axes => axes
.Minimum(0).Maximum(200).StartAngle(270).EndAngle(90).HideIntersectingLabel(true)
.MajorTicks(mi => mi.Interval(4)).MinorTicks(mj => mj.Interval(2)).Add()).Render()
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;
using EJ2_Core_Application.Models;
using Newtonsoft.Json;
namespace EJ2_Core_Application.Controllers
{
public class HomeController : Controller
{
public IActionResult Index()
{
return View();
}
}
}
Minimum and Maximum
The minimum and maximum properties enables you to customize the start and end values of an axis.
@using Syncfusion.EJ2;
@Html.EJS().CircularGauge("circular").Axes(axes => axes.Minimum(50).Maximum(250).Add()).Render()
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;
using EJ2_Core_Application.Models;
using Newtonsoft.Json;
namespace EJ2_Core_Application.Controllers
{
public class HomeController : Controller
{
public IActionResult Index()
{
return View();
}
}
}
Multiple Axes
In addition to the default axis, you can add n number of axis to a gauge. Each axis will have its own ranges, pointers, annotations and customization options.
@using Syncfusion.EJ2;
@Html.EJS().CircularGauge("circular2").Axes(axes => {
axes
.MajorTicks(majortick => majortick.Interval(10).Color("red").Height(10).Width(3))
.MinorTicks(minortick => minortick.Interval(5).Color("green").Height(5).Width(2))
.Add();
axes.MajorTicks(majortick => majortick.Interval(10).Color("blue").Height(10).Width(3))
.MinorTicks(minortick => minortick.Interval(5).Color("lime").Height(5).Width(2)).Add();
}).Render()
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;
using EJ2_Core_Application.Models;
using Newtonsoft.Json;
using Syncfusion.EJ2.Charts;
using Syncfusion.EJ2.CircularGauge;
namespace EJ2_Core_Application.Controllers
{
public class HomeController : Controller
{
public IActionResult Index()
{
return View();
}
}
}
NOTE