开源库Magicodes.ECharts使用教程

目录

1    概要    2

2    Magicodes.ECharts工作原理    3

2.1    架构说明    3

2.1.1    Axis    4

2.1.2    CommonDefinitions    4

2.1.3    Components    4

2.1.4    JsonConverter    4

2.2    Series    6

2.3    ValueTypes    6

2.4    EChartsOptions    7

2.5    TimelineOptions    8

3    Magicodes.EchartsJs    8

3.1    全局配置    8

3.2    组件配置    8

3.3    Demo    9

4    5分钟上手Magicodes.EChart    9

4.1    获取EChart    9

4.2    引用Magicodes.ECharts    9

4.3    引用Echart相关脚本    10

4.4    编写第一个图表    11

4.4.1    编写控制器代码    11

4.4.2    编写前端代码    12

4.4.3    效果    12

4.5    编写动态图表    13

5    相关示例    13

博客使用Word发博,发布后,排版会出现很多问题,一一修正工作量极大,敬请谅解。可加群获取原始文档。

  1. 概要

Magicodes.ECharts是心莱团队基于百度EChart封装的开源的.NET类库,以便让用户更快更便捷的上手开发EChart图表。本篇主要讲解Magicodes.ECharts的相关使用。

注意:EChart图表插件是由百度提供的一套前端图表库,可以流畅运行在PC端和移动设备上。Echarts具备完善的兼容性和丰富的图表类型,目前已经存在2.0和3.0两个版本,Magicodes.ECharts针对的是最新版本的封装。ECharts的官网为:http://echarts.baidu.com/

官方博客:http://www.cnblogs.com/codelove/

相关开源库地址:https://github.com/xin-lai

在开始之前,您需要了解以下内容:

  • Magicodes.ECharts是基于百度EChart封装的开源的.NET类库,封装的目的便于使用强类型语言约束后台代码,以便于更好维护和重构代码,并且封装自身业务
  • Magicodes.EChartsJS是基于knockoutJs封装的组件,结合Magicodes.ECharts能够很方便的利用Ajax加载Echart图表
  • 目前Magicodes.ECharts已经支持大部分图表,但是尚不能支持所有图表和所有情形
  • 本着按需设计的原则,在遇到不支持的情形,希望您能够自行扩展并贡献自己的代码。众人拾材火焰高,Magicodes.ECharts在不断地实践中会更加完善的
  • 在设计上,我们不会过多设计,但是后续版本可能会不断地进行重构
  1. Magicodes.ECharts工作原理

  1. 架构说明

Magicodes.ECharts目前主要由以下部分组成:

  1. Axis

直角坐标系 grid 中的轴的相关配置封装,比如x轴、y轴等。

  1. CommonDefinitions

通用定义,目前定义了以下内容:

  • Align(水平对齐)
  • Label(标签)
  • Orients(图例列表的布局朝向)
  • Symbols(标记的图形)
  • TextAlign(标题文本水平对齐)
  • TextStyles(文本样式)
  • VerticalAlign(垂直对齐)
  1. Components

组件定义。目前定义了以下内容:

  • DataZoom(区域缩放)

    • DataZoomInside(内置型数据区域缩放组件)
    • DataZoomSlider(滑动条型数据区域缩放组件)
  • Grid(直角坐标系内绘图网格)
  • Legend(图例组件)
  • TimeLine(timeline 组件)
  • Title(标题)
  • ToolBox(工具箱)
  • ToolTip(提示框组件)
  1. JsonConverter

定义了一些自定义实现的JSON转换器,依赖自JSON.NET。

  • ValueConverter

ValueConverter用于相关值JSON转换,需要实现IValue<T>接口。如下面例子:

/// <summary>

/// 小数数组

/// </summary>

[JsonConverter(typeof(ValueConverter<double[]>))]

public class ArrayNumberValue : IValue<double[]>, INumberOrArrayNumberValue

{

public double[] Value { get; set; }

}

/// <summary>

/// 数值

/// </summary>

[JsonConverter(typeof(ValueConverter<double>))]

public class NumberValue : ILeftValue, ITopValue, IRightValue, IBottomValue, IValue<double>, INumberOrArrayNumberValue, INumberOrStringValue

{

public NumberValue(double? value = null)

{

if (value.HasValue)

{

Value = value.Value;

}

}

public double Value { get; set; }

}

接下来,在DataZoom组件上用到了我们的定义,如下所示:

public abstract class DataZoom

{

….省略其他代码

/// <summary>

/// 设置 dataZoom-inside 组件控制的 y轴(即yAxis,是直角坐标系中的概念,参见 grid)。

/// 不指定时,当 dataZoom-inside.orient 为 ‘vertical‘时,默认控制和 dataZoom 平行的第一个 yAxis。但是不建议使用默认值,建议显式指定。

/// 如果是 number 表示控制一个轴,如果是 Array 表示控制多个轴。

/// </summary>

public INumberOrArrayNumberValue XAxisIndex { get; set; }

}

在使用时,我们可以这样赋值:

new DataZoomInside()

{

Start=30,

End=70,

XAxisIndex=new ArrayNumberValue() {Value=new double[] { 0,1} }

}

当然也可以给其赋予数值:

new DataZoomInside()

{

Start=30,

End=70,

//XAxisIndex=new ArrayNumberValue() {Value=new double[] { 0,1} }

XAxisIndex=new NumberValue(1)

}

在生成JSON时,改转换器会生成对应正确的JSON,如下图所示:

  1. Series

定义了系列。每个系列通过 Type 决定自己的图表类型。

目前定义有:

  • BarSeries
  • LineSeries
  • 其他图表类型大都可以通过实例化基类然后指定系列类型
  1. ValueTypes

值类型。因EChart的许多属性配置均可以支持不同的数据类型和对象,Magicodes.Echarts特对此进行了封装,以进行约束。目前定义有以下值类型:

  • AlignValue
  • ArrayNumberValue
  • DoubleValue
  • IBottomValue
  • ILeftValue
  • INumberOrArrayNumberValue
  • INumberOrStringValue
  • IRightValue
  • ISymbolValue
  • ITopValue
  • IValue
  • NumberValue
  • StringValue
  • SymbolValue
  • VerticalAlignValue

具体使用请参考本框架源码。

  1. EChartsOptions

EChart配置基类。允许设置各个组件和对象来定义Echart。

如下面Demo:

[HttpGet]

public JavaScriptJsonResult Demo1()

{

var provinces = new List<object>() { "岳阳", "长沙", "北京", "上海", "武汉", "贵州", "大连", "成都", "深圳" };

var valueList = new List<object>() { 50, 100, 130, 39, 31, 66, 11, 34, 9 };

var chartOptions = new EChartsOption

{

Title = new Title("粉丝分布统计图") { Left = new AlignValue(Align.center) },

Series = new Series.Series[]

{

new BarSeries

{

Name = "粉丝分布",

Data = valueList,

MarkPoint = new MarkPoint

{

Data = new List<MarkData>

{

new MarkData {Type = MarkPointDataTypes.max, Name = "最大值"},

new MarkData {Type = MarkPointDataTypes.min, Name = "最小值"}

}

},

MarkLine = new MarkLine

{

Data = new List<MarkData>

{

new MarkData {Type = MarkPointDataTypes.average, Name = "平均值"}

}

}

}

},

XAxis = new XAxis[1] { new XAxis { Type = AxisTypes.category, Data = provinces } },

YAxis = new YAxis[1] { new YAxis { Type = AxisTypes.value } }

};

return this.ToEChartResult(chartOptions);

}

  1. TimelineOptions

Timeline配置基类。允许设置各个组件和对象来定义Echart。

  1. Magicodes.EchartsJs

Magicodes.EChartsJs为针对Echart封装的Ajax加载的knockoutjs库,需要依赖以下javascript库:

  • Jquery
  • Knockoutjs

关于Magicodes.EChartsJs,你可以在开源库源码中的项目Magicodes.ECharts.Demo找到。

该组件主要有以下配置:

  1. 全局配置

基于window.mcs.echarts.settings进行配置,比如设置全局主题:

mcs.echarts.settings.theme="macarons"

  1. 组件配置

  • ajaxUrl:Ajax加载路径
  • isBlockUI:是否显示加载遮罩层
  • theme:主题
  1. Demo

<div data-bind=‘component:{name: "echart",params: { ajaxUrl: "/ChartDemo/Demo1" ,theme:"macarons"}}‘ style="height: 280px; width: 100%"></div>

<div data-bind=‘component:{name: "echart",params: { ajaxUrl: "/ChartDemo/Demo2" ,theme:"macarons"}}‘ style="height: 280px; width: 100%"></div>

<div data-bind=‘component:{name: "echart",params: { ajaxUrl: "/ChartDemo/Demo3" ,theme:"macarons"}}‘ style="height: 800px;width: 100%"></div>

  1. 5分钟上手Magicodes.EChart

    1. 获取EChart

你可以在此下载EChart:http://echarts.baidu.com/download.html

  1. 引用Magicodes.ECharts

使用Nuget包下载,请分别下载:

  • Magicodes.ECharts
  • Magicodes.ECharts.Mvc
  • Magicodes.EChartsJs

相关操作如下图所示:

也可以在Github下载源代码引用,地址为:https://github.com/xin-lai/Magicodes.ECharts

  1. 引用Echart相关脚本

推荐使用ASP.NET Bundle技术,配置如下所示:

//echarts

bundles.Add(new ScriptBundle("~/plugins/echarts").Include(

"~/Scripts/plugins/echart/echarts.js",

"~/Scripts/plugins/echart/theme/macarons.js",

"~/Scripts/components/magicodes.echart.js"));

注意:如果使用到了相关主题,请注意引用主题脚本。

那么在View页引用如下:

@Scripts.Render("~/bundles/jquery")

@Scripts.Render("~/bundles/knockout")

@Scripts.Render("~/bundles/bootstrap")

@Scripts.Render("~/plugins/echarts")

其中,Jquery、Knockoutjs、Echarts脚本是必须的,其他请按需引用。

  1. 编写第一个图表

    1. 编写控制器代码

首先我们需要编写控制器代码,以便Ajax调用。如下所示:

[HttpGet]

public JavaScriptJsonResult Demo2()

{

var data = new List<object>() {

new {value=400, name= "搜索引擎"},

new {value=335, name="直接访问"},

new {value=310, name="邮件营销"},

new {value=274, name="联盟广告"},

new {value=235, name="视频广告"}

};

var chartOptions = new EChartsOption

{

Title = new Title("搜索来源") { Left = new AlignValue(Align.center) },

Series = new Series.Series[]

{

new Series.Series

{

Name = "访问来源‘",

Data = data,

Type=SeriesTypes.pie,

Radius="55%",

}

}

};

return this.ToEChartResult(chartOptions);

}

请注意引用相关命名空间,并注意,ToEChartResult为扩展方法,用于将上述配置对象输出为JSON序列化内容。

  1. 编写前端代码

前端组件代码如下:

<div data-bind=‘component:{name: "echart",params: { ajaxUrl: "/ChartDemo/Demo2" ,theme:"macarons"}}‘ style="height: 280px; width: 100%"></div>

注意,定义好Echart组件之后,我们还需要在页面上添加以下代码:

@section Scripts

{

<script>

$(function () {

ko.applyBindings({});

});

</script>

}

该脚本用于绑定KO组件,请务必添加。

  1. 效果

至此,代码编写完毕,效果如下所示:

  1. 编写动态图表

有时候,我们希望图表能够即时的进行数据刷新并动态变化,那么使用Magicodes.EChartsJs就比较简单了,如下面Demo:

<script>

$(function () {

var viewModel = function () {

var self = this;

this.demo4Url = ko.observable(‘/ChartDemo/Demo1‘);

this.init = function () {

//设置定时器

setInterval(function () {

//可以通过Url传参

self.demo4Url(self.demo4Url() == ‘/ChartDemo/Demo1‘ ? ‘/ChartDemo/Demo2‘ : ‘/ChartDemo/Demo1‘);

}, 2000);

};

self.init();

};

ko.applyBindings(new viewModel());

});

</script>

HTML:

<div class="row">

<div class="col-md-12">

<h2>Demo4——动态图</h2>

<div data-bind=‘component:{name: "echart",params: { ajaxUrl: demo4Url ,theme:"macarons"}}‘ style="height: 400px;width: 100%"></div>

</div>

</div>

上述Demo实现了图表每隔两秒的刷新,会自动从Demo1切换为Demo2的图表,在实际应用中,您可以可以通过Url传参或者按照自身业务来动态加载图表数据。

由上面代码得知,Magicodes.EChartsJs组件的ajaxUrl参数不仅仅支持字符串,还支持绑定ko的监视器,如果图表需要即时刷新,只需要给监视器赋值就可以了,当值产生变化时,图表会自动刷新,如下面代码:

self.demo4Url(self.demo4Url() == ‘/ChartDemo/Demo1‘ ? ‘/ChartDemo/Demo2‘ : ‘/ChartDemo/Demo1‘);

  1. 相关示例

目前在开源库中,定义了4个Demo,如下图所示:

下面是我们使用该组件在实践中的一些示例:

目前Magicodes.ECharts尚不能支持所有图表和所有情形,如果你对本项目有兴趣,可以贡献自己的代码哦。本着按需设计的原则,Magicodes.ECharts在不断地实践中会更加完善的。

时间: 2024-10-07 12:53:57

开源库Magicodes.ECharts使用教程的相关文章

使用开源库MAGICODES.WECHAT.SDK进行微信公众号支付开发

概要 博客使用Word发博,发布后,排版会出现很多问题,敬请谅解.可加群获取原始文档. 本篇主要讲解微信支付的开发流程,相关业务基于MAGICODES.WECHAT.SDK实现.通过本篇教程,您可以很方便的快速完成微信公众号支付的开发. 关于Magicodes.WeChat.SDK MAGICODES.WECHAT.SDK为心莱团队封装的轻量级微信SDK,现已全部开源,开源库地址为:https://github.com/xin-lai/Magicodes.WeChat.SDK 更多介绍,请关注后

开源库Magicodes.Storage正式发布

说明 Magicodes.Storage,是心莱科技团队提供的统一存储库,相关库均使用.NET标准库(netstandard2.0)编写,支持.NET Framework以及.NET Core. 我们希望,使用了Magicodes.Storage之后,开发者可以很快的从本地存储切换到云端存储:我们希望,使用了Magicodes.Storage之后,开发者可以快速地从不同的云存储供应商之间切换. 目前主要支持以下存储: 本地存储(本地站点目录) 阿里云存储 腾讯云存储 开源库地址:https://

安卓 USB摄像头 开源库 UVCCamera 教程

https://github.com/saki4510t/UVCCamera UVCCamera 听名字就知道使用UVC( USB VEDIO CLASS) 协议的通用类库.linux原生支持,基本支持市面上所有免区USB摄像头. 此开源库包含JNI及android封装的类库.是目前最好用的安卓USB摄像头类库. UVCCamera来控制.管理与外接设备的连接,UVCCamera.setFrameCallback(final IFrameCallback callback, final int

开源导入导出通用库Magicodes.ExporterAndImporter发布

导入导出通用库 Magicodes.ExporterAndImporter为心莱团队封装的导入导出通用库,并且仍在跟随项目不断地打磨. GitHub地址: https://github.com/xin-lai/Magicodes.ExporterAndImporter 目录 特点 相关官方Nuget包 导出 Demo 普通导出 特性导出 列头处理或者多语言支持 导入Demo 普通模板 多数据类型 数据验证 Docker中使用 Dockerfile Demo 特点 封装导入导出业务,目前仅支持 E

ECharts案例教程2

p{text-indent:2em;}th,td{border:1px solid #333;}前端开发whqet,csdn,王海庆,whqet,前端开发专家 ECharts案例教程系列文章,试图通过案例从入门到精通的方式学习数据可视化工具ECharts,第1篇我们通过简单的条形图.条形图和折线图的混搭两个案例描述ECharts的使用流程,数据配置框架等.本博文为第2篇,研究时间轴在数据图中的应用. ------------------------------------------------

【开源框架】Android之史上最全最简单最有用的第三方开源库收集整理,有助于快速开发,欢迎各位...

[转]http://www.tuicool.com/articles/jyA3MrU Android开源库 自己一直很喜欢Android开发,就如博客签名一样, 我是程序猿,我为自己代言 . 在摸索过程中,GitHub上搜集了很多很棒的Android第三方库,推荐给在苦苦寻找的开发者,而且我会 不定期的更新 这篇文章. Android下的优秀开发库数不胜数,在本文中,我列举的多是开发流程中最常用的一些.如果你还想了解更多的Android开源库,可以关注我的博客,每一个库都是我认真查看或者编译运行

android开源库发布到jcenter图文详解与填坑

相信很多人都用过开源项目,特别是android studio普及以后,使用开源库更方便简单.而如何上传开源库到jcenter供大家方便使用,虽然网上也有教程,但还是遇坑了,最后总结一下,希望可以帮助大家. [csdn地址: http://blog.csdn.net/zhangke3016/article/details/52075159] [本文简书地址: http://www.jianshu.com/p/0acf9e05b27e]同步更新 AndroidStudio是从Maven Reposi

IOS开发第三方开源库

IOSios开发第三方开源库 1. AFNetworking 在众多iOS开源项目中,AFNetworking可以称得上是最受开发者欢迎的库项目.AFNetworking是一个轻量级的iOS.Mac OS X网络通信类库,现在是GitHub上第三大Objective-C库.它建立在NSURLConnection.NSOperation等类库的基础上,让很多网络通信功能的实现变得十分简单,因此,许多iOS应用开发都会使用到它. 支持HTTP请求和基于REST的网络服务(包括GET.POST.PUT

&lt;Android开源库&gt; GreenDAO 用法详解&lt;译文&gt;

简介 greenDAO是一个开源的Android ORM,使SQLite数据库的开发再次变得有趣. 它减轻了开发人员处理底层的数据库需求,同时节省开发时间. SQLite是一个很不错的关系型数据库. 尽管如此,编写SQL和解析查询结果仍然是相当乏味和耗时的任务. greenDAO通过将Java对象映射到数据库表(称为ORM,"对象/关系映射")来解决这些问题. 这样,您可以使用简单的面向对象的API来存储,更新,删除和查询Java对象. 特性 最高性能(可能是Android中最快的OR