浏览 4364 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2011-09-01
上一篇文章主要介绍了柱形图和条形图(横向柱形图)的使用方法,这里讲一下折线图、堆积图、分布图、双项比较图的使用方法 其实这些以上那些图的使用方式与柱形图的使用方式没有太大的区别,只是分布图和双向比较图需要有一些需要注意的地方
先说一下折线图 Chart.Line
new Chart.Line({ 'item' : [ { 'text' : 'A', 'value' : [90,50,60,80,75] }, { 'text' : 'B', 'value' : [25,33,45,98,50] }, { 'text' : 'C', 'value' : [12,15,17,13,18] } ], 'legend':{'x':100, 'y':5}, 'zoom' : 'follow', 'valueHalf' : true, 'linePoint':true, 'grid' : true, 'showValue' : true, 'categoryMax' : 100, 'categoryMin' : 20, 'categoryUnit' : 20, 'valueMax' : 110, 'valueMin' : 10, 'valueUnit' : 10 }).render('canvas-wrapper');
生成的图表为 http://everyjs.co.cc/demo.html#line1
堆积图 Chart.Stack
new Chart.Stack({ 'item' : [ {'text':'A','value':[10,15,20,25]}, {'text':'B','value':[12,18,22,21]}, {'text':'C','value':[30,35,37,40]} ], 'categories':['2009','2010','2011','2012'], 'showValue':true, 'focusEvent':'mousemove', 'tip':'mousemove', 'grid':'v', 'valueAxis':'x', 'valueMax' : 100, 'valueMin' : 0, 'valueUnit' : 25 }).render('canvas-wrapper');
生成的图表为 http://everyjs.co.cc/demo.html#stack1 如果不设置valueAxis为x,生成的堆积图就是纵向的,这里就不贴代码了
分布图 Chart.Scatter
new Chart.Scatter({ 'valueMax':140, 'valueMin':20, 'valueUnit':20, 'valueText':'体重 (kg)', 'categoryMax' : 200, 'categoryMin' : 145, 'categoryUnit' : 5, 'categoryText' : '身高 (cm)', 'padding':20, 'legend':{'x':65, 'y':20}, 'focusEvent':'mousemove', 'tip':'mousemove', 'item' : [ {'text':'女性', 'value':[ [161.2, 51.6], [167.5, 59.0], [159.5, 49.2], [157.0, 63.0], [155.8, 53.6], [170.0, 59.0], [159.1, 47.6], [166.0, 69.8], [176.2, 66.8], [160.2, 75.2], [172.5, 55.2], [170.9, 54.2], [172.9, 62.5], [153.4, 42.0], [160.0, 50.0], [147.2, 49.8], [168.2, 49.2], [175.0, 73.2], [157.0, 47.8], [167.6, 68.8], [159.5, 50.6], [175.0, 82.5], [166.8, 57.2], [176.5, 87.8], [170.2, 72.8], [174.0, 54.5], [173.0, 59.8], [179.9, 67.3], [170.5, 67.8], [160.0, 47.0], [154.4, 46.2], [162.0, 55.0], [176.5, 83.0], [160.0, 54.4], [152.0, 45.8], [162.1, 53.6], [170.0, 73.2], [160.2, 52.1], [161.3, 67.9], [166.4, 56.6], [167.6, 58.3], [165.1, 56.2], [160.0, 50.2], [170.0, 72.9], [157.5, 59.8], [160.0, 55.4], [165.1, 104.1], [174.0, 55.5], [170.2, 77.3], [160.0, 80.5], [167.6, 64.5], [167.6, 72.3], [167.6, 61.4], [154.9, 58.2], [162.6, 81.8], [175.3, 63.6], [171.4, 53.4], [157.5, 54.5], [165.1, 53.6], [160.0, 60.0], [174.0, 73.6], [162.6, 61.4], [174.0, 55.5], [162.6, 63.6], [161.3, 60.9], [156.2, 60.0], [149.9, 46.8], [169.5, 57.3], [160.0, 64.1], [175.3, 63.6], [169.5, 67.3], [160.0, 75.5], [172.7, 68.2], [162.6, 61.4], [157.5, 76.8], [176.5, 71.8], [164.4, 55.5], [160.7, 48.6], [174.0, 66.4], [163.8, 67.3]]}, {'text':'男性', 'value':[ [174.0, 65.6], [175.3, 71.8], [193.5, 80.7], [186.5, 72.6], [187.2, 78.8], [181.5, 74.8], [184.0, 86.4], [184.5, 78.4], [175.0, 62.0], [184.0, 81.6], [180.0, 76.6], [177.8, 83.6], [192.0, 90.0], [176.0, 74.6], [174.0, 71.0], [184.0, 79.6], [192.7, 93.8], [171.5, 70.0], [173.0, 72.4], [176.0, 85.9], [176.0, 78.8], [180.5, 77.8], [172.7, 66.2], [176.0, 86.4], [173.5, 81.8], [178.0, 89.6], [180.3, 82.8], [180.3, 76.4], [164.5, 63.2], [173.0, 60.9], [183.5, 74.8], [175.5, 70.0], [188.0, 72.4], [189.2, 84.1], [172.8, 69.1], [170.0, 59.5], [182.0, 67.2], [170.0, 61.3], [177.8, 68.6], [184.2, 80.1], [186.7, 87.8], [171.4, 84.7], [172.7, 73.4], [175.3, 72.1], [180.3, 82.6], [167.6, 75.5], [186.7, 101.4], [175.3, 91.1], [175.3, 67.3], [175.9, 77.7], [175.3, 81.8], [179.1, 75.5], [181.6, 84.5], [177.8, 76.6], [182.9, 85.0], [177.8, 102.5], [184.2, 77.3], [179.1, 71.8], [176.5, 87.9], [188.0, 94.3], [174.0, 70.9], [167.6, 64.5], [170.2, 77.3], [167.6, 72.3], [188.0, 87.3], [174.0, 80.0], [176.5, 82.3], [180.3, 73.6], [167.6, 74.1], [188.0, 85.9], [180.3, 73.2], [167.6, 76.3], [183.0, 65.9], [183.0, 90.9], [179.1, 89.1], [170.2, 62.3], [177.8, 82.7], [179.1, 79.1], [190.5, 98.2], [177.8, 84.1], [180.3, 83.2], [180.3, 83.2]]} ] }).render('canvas-wrapper');
这里要注意的是item的value属性是一个只有两位的数组集合,第一位表示的是category(即x轴)的数值,第二位表示的是value(即y轴)的数值,分布图可以不需要设置valueMax valueMin categoryMax 和categoryMin
生成的图表为 http://everyjs.co.cc/demo.html#scatter1
双项比较图 Chart.Compare
这里说的双项比较图是指只用两组比较数据的条形图,可以在运动数据统计中经常见到,因为只用两组数据所以在使用它的时候一定要记住保证item集合的长度为2
new Chart.Compare({ 'item': [{ 'text': 'Bryant', 'value': [40, 10, 10, 5, 3] }, { 'text': 'James', 'value': [42, 15, 12, 6, 4] }], 'categories': ['Score', 'Rebounds', 'Steals', 'Assists','Third ball'], 'valueMax': 80, 'valueUnit': 20, 'padding':40, 'tip': 'mousemove', 'focusEvent': 'mousemove', 'showValue':true, 'grid':'v', 'legend': { 'x': 50, 'y': 20 } }).render('canvas-wrapper');
生成的图表为 http://everyjs.co.cc/demo.html#compare1 以上就是折线图、堆积图、分布图、双项比较图的使用方法和需要注意的地方. 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2011-12-06
请问楼主一个问题啊!能在chart 中添加监听吗?想达到的效果就是点击相关数据获得相关信息就行,比如一表 x轴是 月份 Y轴是销售额 有牛奶 蛋糕等种类 我单机7月牛奶 获得7月牛奶的销售额 这个怎么实现啊 我只能实现到 获取7月所有的信息 就不能细分了 我用的是
listeners:{ itemclick : function(o){ alert(o); // alert(store.getAt(o.index)['data']); } } |
|
返回顶楼 | |
发表时间:2011-12-14
你的这个建议很好 目前还没有这种监听的功能 不过会在近期考虑添加此监听的接口
能留下你的联系方式么 如果提供了接口会在第一时间通知你的 |
|
返回顶楼 | |
发表时间:2011-12-21
用Canvas的话,做事件侦听挺费劲的吧,图上很多曲线的时候,点一下要算出点在哪个上面,相当麻烦,如果是简单的矩形图还好,折线图麻烦一点,圆弧、贝赛尔曲线图,就很难求解了。
|
|
返回顶楼 | |
发表时间:2011-12-24
还好 这些在everychart上都已经实现了
目前主要的问题是ie下会很卡 万恶了ie啊~ |
|
返回顶楼 | |