2013-05-10 101 views

回答

2

我知道这是旧的文章,但我发现它试图做这样的事情。我找到了一个解决方法,它可能会帮助别人。

我找到了在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")) 

希望这有助于某人。

0

没有链接,你可以这样做,在剑道图表