我有一个场景,我需要以对数顺序显示a轴刻度。我做了一些搜索,发现这个选项不可用,但帖子差不多一年了。此功能是否在最新版本中提供?剑道图中的对数轴刻度
这里是剑道论坛,我看着
http://www.kendoui.com/forums/dataviz/chart/logarithmic-scale.aspx http://www.kendoui.com/forums/dataviz/chart/does-kendo-support-log-scale.aspx
我有一个场景,我需要以对数顺序显示a轴刻度。我做了一些搜索,发现这个选项不可用,但帖子差不多一年了。此功能是否在最新版本中提供?剑道图中的对数轴刻度
这里是剑道论坛,我看着
http://www.kendoui.com/forums/dataviz/chart/logarithmic-scale.aspx http://www.kendoui.com/forums/dataviz/chart/does-kendo-support-log-scale.aspx
我知道这是旧的文章,但我发现它试图做这样的事情。我找到了一个解决方法,它可能会帮助别人。
我找到了在Kendo UI中实现对数比例的方法。基本上,这个想法是将它的对数形式的值转换为线性形式,然后用KendoUI系列(在我的情况下为“散乱线”)绑定数据,并使用模板替换Y轴上的标签。
.YAxis(axis => axis
.Numeric()
.Title("BER (dB)")
.Labels(l => l.Template("#= formatLog2('{0:0}', value) #"))
.Reverse()
.AxisCrossingValue(double.MaxValue)
.Tooltip(tooltip => tooltip
.Visible(true)
.Template("#= formatLog('{0:0.00000000000000}', value.y) #")
和JavaScript函数“formatLog2”。 (它是一个刮代码,只是为了ilustrate的点):
function formatLog2(format, value) {
if (value < 0) value = value * -1;
value = Math.pow(10, value);
return kendo.format(format, value);
}
和数据源变换:
using (IDatabase db = Database.Create())
using (DataTable dt = new DataTable())
{
db.ExecuteQuery(dt, Query);
List<UnavailabilityChartPoint> l = new List<UnavailabilityChartPoint>();
foreach (DataRow r in dt.Rows)
{
l.Add(new UnavailabilityChartPoint(
r.Field<DateTime>("Date"),
Math.Log10(r.Field<double>("UnSignalMonthly"))
));
}
return Json(l);
}
的重要组成部分是记录的线性和对数到线性变换:
value = Math.pow(10, value);
Math.Log10(r.Field<double>("UnSignalMonthly"))
希望这有助于某人。
没有链接,你可以这样做,在剑道图表