Highcharts Stock 实时图表监控JS

第一次加载时从数据库中抽取监控数据,JS生成昨天及上周同天的对比数据。 每分钟动态更新图表。

Highcharts Stock 实时图表监控JS_第1张图片

var bistock = bistock || {};
$(function () {				
    var seriesOptions = [], 
		// 历史对比曲线 0当前,1昨天,7上周
        periods = [0, 1, 7], 
        impl,				
		config,
		seriesCount = 0,	
		charts = [],
		get_data_url = false,
		update_url = false;
    impl = {		
		config_chart: function() {
			 Highcharts.setOptions({ 
				colors: ['#DDDF00', '#058DC7', '#50B432', '#ED561B', '#24CBE5', '#64E572', '#FF9655', '#FFF263', '#6AF9C4'],
				global: { useUTC: false  } 
			});		
		},	
		debug: function(msg, vars) {
			console.log(msg);
			if(vars) {
				$.each(vars, function(i, v) {
					console.log(i+':'+v);
				});
			}
		},
		/**
		 * 生成监控图表
		 * @id 图表id
		 * @div 图表渲染的div
		 */
		generate_chart: function(id, div) {			
			var tmp_count = 0;
			$.ajax({
				 type: "get",
				 async: false,
				 data: {menuid: id},
				 url: get_data_url,
				 dataType: "json",
				 success: function (response) {
					$.each(response.rs, function (series_name, item) { 					
						// 添加历史对比数据						
						$.each(periods, function (j, period) {							
							seriesOptions[seriesCount] = {
								name: impl.get_series_name(period) + series_name,
								data: (period === 0) ? item.data : impl.get_series_data(item.data, period),
								type: 'spline',
								lineWidth: (seriesCount == 0 || seriesCount == 3) ? 4 : 2
							};
							impl.debug("Series info: ", {'name':seriesOptions[seriesCount]['name'], 'number': seriesCount});
							seriesCount++;
						});  
					});
					impl.createChart(seriesOptions, div, id);						
					seriesOptions = [];
					seriesCount = 0;
				 },
				 error: function(){
					 alert('Fail to render to chart '+id);
				 }
			 });
		},
		/**
		 * 获取图表曲线的名称
		 * @period 图表曲线周期0,1,7
		 */
        get_series_name: function (period) {		
            return (period == 0) ? '当天' : ((period == 1) ? '昨天' : '上周同天');
        },
		/**
		 * 获取图表的数据
		 * @data 原始数据
		 * @period 图表曲线周期0,1,7
		 */
        get_series_data: function (data, period) {			           
            var new_series_data = [],
                time_offset = period * 86400 * 1000,
                now = (new Date()).getTime();            
				
            $.each(data, function (i, item) {
                // 删除某段时间的数据,然后整体偏移.
                var point_data;
                if (item[0]+time_offset < now+8*3600*1000-600*1000) {
					new_series_data[i] = [item[0] + time_offset, item[1]];
                }                
            });			
            return new_series_data;
        },
		/**
		 * 动态更新图表 
		*/
		updateChart: function(menuid) {
			setInterval(function() {											
				$.ajax({
			    		url: update_url,
			    		type: 'GET',
						data: {menuid: menuid},
			    		async: false,
			            contentType: "application/json; charset=utf-8",
			    		dataType: 'JSON',
			    		success: function(response) {													
							if (!response.rs) {
								impl.debug('No Data');							
								impl.debug("Chart Info: ",{'menuid': menuid, 'time': response.happen_time});
								return;
							}
							
							impl.debug("Chart Info: ",{'menuid': menuid, 'time': response.happen_time});						
							var updateCount = 0;				    		
							$.each(response.data, function(i, items){
								$.each(items, function(j, item) {										
									impl.debug("Series info: ", {'data': item, 'number': updateCount});
									charts[menuid].series[updateCount].addPoint(item, true, true);									
									updateCount++;									
								});
							});
							updateCount = 0;
			    		},
			    		cache: false
			    });				
			}, 60000);	
		},
		/**
		 * 从缓存中读取历史数据
		 * @id menuid
		 * @period 1,7
		 * @num 数据序列 0,1,2...
		 * @size 曲线的大小
		 * @time 当期时间
		 * @return 返回一个点的数据
		 */
		get_history_point: function(id, period, num, size, time) {						
			var idx = (size == 1) ? 0 : num;
			var tmp_size = cacheData[id][idx].length;
			// fix the time
			var tmp_point_data = cacheData[id][idx][tmp_size-period*144+1][1];		
			return [time, tmp_point_data];
		},
		rand_point: function(max) {
			var x = (new Date()).getTime(), // current time
				y = Math.round(Math.random() * max);
			return [x,y];
		},
		/**
		 * 创建图表
		 * @seriesData 图表数据
		 * @div 渲染到div
		 * @id 图表的唯一id		 
		 */
        createChart: function (seriesData,div,id) {
			charts[id] = new Highcharts.StockChart({
				chart: {					
	                animation: Highcharts.svg, 
	                marginRight: 10,
	                renderTo: div,
	                events: {
	                    load: impl.updateChart(id)
	                }
	            },				
				colors: (config['colors']) ? config['colors'] : ['#AA4643','#4572A7','#89A54E','#80699B','#3D96AE','#DB843D','#92A8CD','#A47D7C','#B5CA92'],
                rangeSelector: {
                    buttons: [{
						count: 1,
						type: 'hour',
						text: '1h'
					},{
						count: 8,
						type: 'hour',
						text: '8h'
					}, {
						count: 1,
						type: 'day',
						text: '1d'
					}, {
						count: 1,
						type: 'week',
						text: '1w'
					},{
						count: 1,
						type: 'month',
						text: '1m'
					},{
						count: 3,
						type: 'month',
						text: '3m'
					},{
						type: 'all',
						text: 'All'
					}],
					inputEnabled: false,
					selected: 1
                },
				legend: {
					borderWidth: 0,
					enabled: true
				},
                yAxis: {                   
					min: 0,
                    plotLines: [{
                        value: 0,
                        width: 2,
                        color: 'silver'
                    }],
					labels: {
						enabled: config['isEnabled']		
					}
                },

                plotOptions: {
                    series: {
                        //compare: 'percent'
                    }
                },

                tooltip: {
					pointFormat: config['isEnabled'] 
									? '<span style="color:{series.color}">{series.name}</span>: <b>{point.y}</b><br />' 
									: '<span style="color:{series.color}">{series.name}</span><br />',
                    valueDecimals: 2
                },

                series: seriesData
            });
        },
		run: function() {		
			impl.config_chart();
			$.each(config['names'], function(i, name){
				impl.generate_chart(name, 'container_'+i);
			});
		}
    };
	bistock = {
		init: function(vars) {
			config = vars;
			impl.run();
		}
	};
});


你可能感兴趣的:(chart,Highcharts,realtime)