本文实例讲述了extjs图表绘制之条形图实现方法。分享给大家供大家参考,具体如下:
这篇文章将介绍extjs图表中条形图。
将实现以下的功能:
1.从后端请求数据并运用到图表中,形成动态数据。
2.查询出每年各个月中人数。
3.改变条形柱的颜色,改变默认的颜色换成自己想要的颜色。
renderer: function(sprite, storeItem, barAttr, i, store) { barAttr.fill = '#3D96AE' return barAttr; },
先看完整的代码:
Ext.define('ChartColumnTest', { extend: 'Ext.panel.Panel', autoScroll : true, selectYear:null, initComponent: function () { var me = this; me.store = me.createStore(); me.grid = me.getGridPanel(); me.mainPanel = Ext.create('Ext.panel.Panel',{ layout:'fit', items:[me.grid], tbar:me.createQueryTbar(), }); Ext.apply(me,{ layout:'fit', items:[me.mainPanel] }); me.callParent(); me.mainPanel.down('chart').on('cellclick', function(grid, td, cellIndex, record, tr, rowIndex, e, eOpts) { me.onCellClick(cellIndex, record); }); }, getGridPanel:function(){ var me = this; return { xtype:'chart', animate : true,// 是否支持动态数据变化 legend: {// 图例 display: "bottom", spacing: 2, padding: 5, font: { name: 'Tahoma', color: '#3366FF', size: 12, bold: true } }, store:me.store, axes:me.createAxes(), series:me.createSeries(), } }, createQueryTbar: function(){ var me=this; var tbar=[ { xtype : 'combo', fieldLabel:'选择年份', name:'selectYear', queryMode : 'local', editable : true, readOnly:false, labelWidth: 60, width:200, store : new Ext.data.ArrayStore({ fields : ['id','name'], data : [] }), valueField : 'name', displayField : 'id', triggerAction : 'all', autoSelect : true, listeners : { beforerender : function(){ var newyear = Ext.Date.format(new Date(),'Y');//这是为了取现在的年份数 var yearlist = []; for(var i = newyear;i>=2015;i--){ yearlist.push([i,i]); } this.store.loadData(yearlist); } } }, {xtype: 'button',text : '查找', listeners : { "click" : function() { var value = Ext.ComponentQuery.query('[name=selectYear]')["0"].value; me.selectYear = value; me.store.load(); }}} ]; return tbar; }, createStore: function () { var me = this; return Ext.create('Ext.data.JsonStore', { //从后端请求数据 fields: [ {name: 'id', mapping: 'id'}, {name:'statTime',mapping:'statTime',type:'date',dateFormat:'time'}, 'activeCount', 'effectiveCount','effectiveProportion', ], proxy: { type: 'ajax', url: ctx+'/mvc/com/analyze/tblVwMonthUserStat', reader: { type: 'json', root: 'root', totalProperty: 'totalProperty' } }, listeners: { 'beforeload': function (store, operation, eOpts) { store.proxy.extraParams.selectYear = me.selectYear } }, autoLoad: true }); }, createAxes: function () { var me = this; var columns = [ { type: 'Numeric', position: 'left', minimum: 1000, maximum: 10000, label: { renderer: Ext.util.Format.numberRenderer('0,0') }, title: '人数', grid: true, }, { type: 'Numeric', position: 'right', minimum: 1000, maximum: 10000, label: { renderer: Ext.util.Format.numberRenderer('0,0') }, title: '人数', grid: true, }, { type: 'Time', position: 'bottom', fields: 'statTime', step: [Ext.Date.MONTH, 1], dateFormat: 'y-m', title: '日期', grid: false, } ]; return columns; }, createSeries: function () { var me = this; var columns = [ { type: 'column', axis: 'left', title:'活跃用户数', highlight: true, tips: { trackMouse: true, width: 200, height: 28, renderer: function(storeItem, item) { this.setTitle( "人数:"+storeItem.get('activeCount')+",占比:"+storeItem.get('effectiveProportion') ); } }, //设置条形柱的颜色 renderer: function(sprite, storeItem, barAttr, i, store) { barAttr.fill = '#3D96AE' return barAttr; }, //设置显示每个坐标上的文字 label: { display: 'outside', 'text-anchor': 'middle', field: 'activeCount', renderer: Ext.util.Format.numberRenderer('0'), orientation: 'horizontal',//改变数字方向 水平显示 font: '25px Helvetica, sans-serif', 'text-anchor': 'start', color: 'red', }, xField: 'statTime', yField: 'activeCount', // yPadding:100, 距离x轴的高度 }, ]; return columns; } });
下面讲解上图中的代码:
1.在panel中定义图表。条形图主要data(数据)、轴(y、x轴)、系列(series)组成。
2.定义查询的tbar,图中的数据是根据年份所查询出来的,用来动态显示。
3.在y轴上标刻的是人数,定义最大值和最小值,会自动调节每个间距的大小,position 定义位置 有‘left',‘right',bottom,‘top'四种
type: 'Numeric', position: 'left', minimum: 1000, maximum: 10000,
4.step 定义以多少为间隔,在此案例中,我以一个月为间隔。position 定义位置 有‘left',‘right',bottom,‘top'四种,grid:false 不是网格布局。
{ type: 'Time', position: 'bottom', fields: 'statTime', step: [Ext.Date.MONTH, 1], dateFormat: 'y-m', title: '日期', grid: false, }
5.tips 当鼠标放在图表上所显示的文字。在renderer方法中设置自己想显示的文字。
tips: { trackMouse: true, width: 200, height: 28, renderer: function(storeItem, item) { this.setTitle( "人数:"+storeItem.get('activeCount')+",占比:"+storeItem. get('effectiveProportion') ); } },
6.可以在定义的系列中(series)中定义renderer方法,在此方法中改变条形柱的颜色。
renderer: function(sprite, storeItem, barAttr, i, store) { barAttr.fill = '#3D96AE' return barAttr; },
7.可以在label中调节显示文字的方向和文字显示的位置。
label: { display: 'outside', 'text-anchor': 'middle', field: 'activeCount', renderer: Ext.util.Format.numberRenderer('0'), orientation: 'horizontal',//改变数字方向 水平显示 font: '25px Helvetica, sans-serif', 'text-anchor': 'start', color: 'red', },
display 可以改变文字在图表中的显示位置。‘insideStart',‘insideEnd',‘outside'分别代表在条形柱的最开始,最后面和外面。大家可以自己去试试。
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript图片操作技巧大全》、《JavaScript切换特效与技巧总结》、《JavaScript运动效果与技巧汇总》、《JavaScript动画特效与技巧汇总》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
本文向大家介绍extjs图形绘制之饼图实现方法分析,包括了extjs图形绘制之饼图实现方法分析的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了extjs图形绘制之饼图实现方法。分享给大家供大家参考,具体如下: 这篇文章将介绍extjs中自带的饼图。 代码如下: 注: 1.上面中的createStore是创建饼图所需要的数据的--store。 2.上面中的legend 显示的右边的图例(表明
本文向大家介绍C#实现绘制面形图表的方法详解,包括了C#实现绘制面形图表的方法详解的使用技巧和注意事项,需要的朋友参考一下 本例详细讲述了C#实现的面形图绘制例子,这是其中一个核心绘制文件的代码,代码中的里面的注释很多,也比较详细,相信对于初学者学习及理解C#图形绘制方面的技术要点、难点有所帮助。 C#绘制面形图的主要功能代码如下: 面形图是平时很普及的一种图表风格,用来显示数据挺方便的。合理的加
本文向大家介绍js+html5实现canvas绘制圆形图案的方法,包括了js+html5实现canvas绘制圆形图案的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了js+html5实现canvas绘制圆形图案的方法。分享给大家供大家参考。具体实现方法如下: 希望本文所述对大家的web程序设计有所帮助。
问题内容: 我正在尝试将一些简单的图形绘制到框架上。我还希望能够从主要方法中调整要绘制的内容。例如,设置要打印的String变量或矩形的坐标。 我似乎遇到的问题是,可以在设置类变量之前调用该方法。如何在绘制到屏幕之前更改此代码以设置/ 变量? 谢谢 问题答案: 从FrameTest类中删除test_string。使用set方法直接设置test_string。参见示例:
我遇到了一个关于Python中matplotlib的棘手问题。我想用几个代码创建一个分组条形图,但是图表出错了。你能给我一些建议吗?代码如下。 这个代码模块的输出真是一团糟。但我所期望的应该像图中的条形图。你能告诉我代码中哪一点不正确吗?
我是数据可视化方面的新手。我正在练习海运,我正在尝试用这个数据帧绘制一个条形图。我希望图表有3条在每个符号上,然而,输出只有1条在每个符号上。我能知道怎么修吗? 数据帧的一部分... 代码如下所示: 输出如下: