Highcharts的部分属性与Y轴数据值刻度显示Y轴最小最大值

Stella981
• 阅读 908
Highcharts.setOptions({global:{useUTC : false}});  
$(function(){    
    //声明报表对象    
    var chart = new Highcharts.Chart({    
        chart: {  
        renderTo: 'container', // 报表显示在 页面位置 container 为 div 定义的属性  
        defaultSeriesType: 'spline', // 定义报表类型 例如:line ,spline ,colume  
        events: {  
                load:  getForm  //调用js 方法  
            }  
        },  
        title:{  
            text:'实时监测曲线图" //定义曲线报表 名称  
        },  
        xAxis: {  
            type: 'datetime', // 定义时间轴的 类型  
            maxPadding : 0.05,  
            minPadding : 0.05,  
            tickWidth:1,//刻度的宽度  
            lineWidth :1,//自定义x轴宽度  
            gridLineWidth :1,//默认是0,即在图上没有纵轴间隔线  
            lineColor : '#990000'     
        },  
        yAxis: {  
                max:12, // 定义Y轴 最大值  
                min:0, // 定义最小值(如果只定义了最小值,而没有定义最大值,则Y轴的刻度会根据series中所有的Y值自动计算)  
                minPadding: 0.2,   
                maxPadding: 0.2,  
                tickInterval:1, // 刻度值  
                title: {  
                    text: 'PH值'  
                },  
                // plotLines 表示为定义曲线报表中的 (刻度线)或者叫做(定义的区间范围)  
// 一下为2条表示线  
                plotLines: [{   
                            value: 6,  
                            color: 'green',  
                            dashStyle: 'shortdash',  
                            width: 2,  
                            label: {  
                                text: '正常'  
                            }  
                        },{  
                            value: 8,  
                            color: 'green',  
                            dashStyle: 'shortdash',  
                            width: 2,  
                            label: {  
                                text: '正常'  
                            }  
                        }  
                }]  
        },  
        tooltip: {  // 表示为 鼠标放在报表图中数据点上显示的数据信息  
            formatter: function() {  
                  return '<b>'+'日期:' +'</b>'  
+Highcharts.dateFormat('%Y-%m-%d %H:%M:%S', this.x) +'<br/>'+  
                   '<b>'+'<%=lbname%>:' +'</b>'+ this.y+'  <%=shll%>';  
            }  
        },  
        series: [{  
            name: 'PH',  
            data: [] // 此处存放数据值 用,分开 例如:1.8,8.9,null,9.2,   如果在某一点数据为空    
//可以用null 来表示   
            //如果是想动态扶植  这个位置 应该为空 即:data: []  
        }]  
    });    
    // 与后台进行数据交互  
    function getForm(){    
        jQuery.getJSON("test!test.do?id=123456", null, function(data) {     
            //为图表设置值     
            chart.series[0].setData(data);     
        });       
    }    
    //定时刷新 列表数据  
   $(document).ready(function() {    
       //每隔3秒自动调用方法,实现图表的实时更新    
       window.setInterval(getForm,50000);     
   });    
});  
  
//定义 曲线报表图 的样式  
    Highcharts.theme = {  
       colors: ['#058DC7', '#50B432', '#ED561B', '#DDDF00', '#24CBE5', '#64E572', '#FF9655',  
 '#FFF263', '#6AF9C4'],  
       chart: {  
          backgroundColor: {  
             linearGradient: [0, 0, 500, 500],  
             stops: [  
                [0, 'rgb(255, 255, 255)'],  
                [1, 'rgb(240, 240, 255)']  
             ]  
          },  
          borderWidth: 2,  
          plotBackgroundColor: 'rgba(255, 255, 255, .9)',  
          plotShadow: true,  
          plotBorderWidth: 1  
       },  
       title: {  
          style: {   
             color: '#000',  
             font: 'bold 16px "Trebuchet MS", Verdana, sans-serif'  
          }  
       },  
       subtitle: {  
          style: {   
             color: '#666666',  
             font: 'bold 12px "Trebuchet MS", Verdana, sans-serif'  
          }  
       },  
       xAxis: {  
          gridLineWidth: 1,  
          lineColor: '#000',  
          tickColor: '#000',  
          labels: {  
             style: {  
                color: '#000',  
                font: '11px Trebuchet MS, Verdana, sans-serif'  
             }  
          },  
          title: {  
             style: {  
                color: '#333',  
                fontWeight: 'bold',  
                fontSize: '12px',  
                fontFamily: 'Trebuchet MS, Verdana, sans-serif'  
  
             }              
          }  
       },  
       yAxis: {  
          //minorTickInterval: 'auto'  // 此处会在Y轴坐标2点之前出现小格  所以就没有使用。  
       },  
       legend: {  
          itemStyle: {           
             font: '9pt Trebuchet MS, Verdana, sans-serif',  
             color: 'black'  
          },  
          itemHoverStyle: {  
             color: '#039'  
          },  
          itemHiddenStyle: {  
             color: 'gray'  
          }  
       },  
       labels: {  
          style: {  
             color: '#99b'  
          }  
       }  
    };  
    var highchartsOptions = Highcharts.setOptions(Highcharts.theme);

常用的文档说明:

1.chart:

renderTo 图表的页面显示容器

defaultSeriesType 图表的显示类型(line,spline, scatter, splinearea bar,pie,area,column)

margin 上下左右空隙

events 事件

click function(e) {}

load function(e) {}

2.xAxis:yAxis:

属性:

gridLineColor 网格颜色

reversed 是否反向 true ,false

gridLineWidth 网格粗细

startOnTick 是否从坐标线开始画图区域

endOnTick 是否从坐标线结束画图区域

tickmarkPlacement 坐标值与坐标线标记的对齐方式on,between

tickPosition 坐标线标记的样式 向内延伸还是向外延伸(insidel,outside)

tickPixelInterval 决定着横坐标的密度

tickColor 坐标线标记的颜色

tickWidth 坐标线标记的宽度

lineColor 基线颜色

lineWidth 基线宽度

max 固定坐标最大值

min 固定坐标最小值

plotlines 标线属性

maxZoom

minorGridLineColor

minorGridLineWidth

/minorTickColor

title: 

enabled: 是否显示

text: 坐标名称

Labels 坐标轴值显示类 默认:defaultLabelOptions

formatter 格式化函数

enabled 是否显示坐标轴的坐标值

rotation 倾斜角度

align 与坐标线的水平相对位置

x 水平偏移量

y 垂直偏移量

style 

font 字体样式 默认defaultFont

color 颜色

3.Tooltip 数据点的提示框

enabled 鼠标经过时是否可动态呈现true,false

formatter 格式化提示框的内容样式

4.plotOptions 画各种图表的数据点的设置

defaultOptions 默认设置

属性

Area类:

lineWidth 线宽度

fillColor area的填充颜色组

marker{} 设置动态属性

shadow 是否阴影 true,false

states 设置状态?

Line类

dataLabels: 数据显示类

enabled 是否直接显示点的数据true,false

5.series

name 该条曲线名称

data[] 该条曲线的数据项

addPoint([x,y],redraw,cover) 添加描点,redraw 是否重画,cover是否左移

setData: function(data, redraw) 重新设置Data数组,redraw是否重画

remove: function(redraw) 删除曲线

redraw: function() 重画曲线

marker :

enabled 是否显示描点

http://www.highcharts.com是一个很强大的js画图工具,这几天把它用在项目里。

有个问题一直困扰我,在画曲线图的时候,横轴想让它显示成时间格式,怎么搞都不行。如果直接用字符串方式显示,一条线上数据点很多的时候,就都挤到一起去了。

这玩意中文资料很少,去它官网论坛逛了逛,后来发现,xAxis如果想设置成datetime,时间数据是不能放到categories里的,要放到series里去。

下面是个例子:

 var chart1option = {
            chart: {
                renderTo: 'sysThreadChart'//画到id为sysThreadChart的div容器里
            },
            credits : {
                enabled:false
            },
            title: {
                text: 'Date Time Axis Test',
                style: {
                    margin: '10px 100px 0 0'// center it
                }
            },
            xAxis: {
                type:"datetime",//时间轴要加上这个type,默认是linear
                maxPadding : 0.05,
                minPadding : 0.05,
                //tickInterval : 24 * 3600 * 1000 * 2,//两天画一个x刻度
                //或者150px画一个x刻度,如果跟上面那个一起设置了,则以最大的间隔为准
                tickPixelInterval : 150,
                tickWidth:5,//刻度的宽度
                lineColor : '#990000',//自定义刻度颜色
                lineWidth :3,//自定义x轴宽度
                gridLineWidth :1,//默认是0,即在图上没有纵轴间隔线
                //自定义x刻度上显示的时间格式,根据间隔大小,以下面预设的小时/分钟/日的格式来显示
                                dateTimeLabelFormats:
                {
                    second: '%H:%M:%S',
                    minute: '%e. %b %H:%M',
                    hour: '%b/%e %H:%M',
                    day: '%e日/%b',
                    week: '%e. %b',
                    month: '%b %y',
                    year: '%Y'
                }
            },
//经测试,不能把时间值放到categories里,必须放到series的data里面去
//这样是不行的:categories:[1274457600000,1274544000000,1274630400000]
//时间单位是毫秒,Unix时间戳乘上1000
            series:[{
                    data:
                    [
                        [1274457600000, 1200],
                        [1274544000000, 1300],
                        [1274630400000, 1250],
                        [1274803200000,1350]
                    ]
                    }]
        };
    $(document).ready(function() {
                //真正的画图是这句
        chart1= new Highcharts.Chart(chart1option);
    });

画出来是这样的:

这个帖子也给了2个例子,似乎时间格式不一定使用时间戳也行?

有时间再整理一下其他hightcharts画图的例子,有点把它那个Options Reference翻译一下的冲动。。。

附上其他一些关于hightcharts的网址:
http://www.hcharts.cn/docs/index.php?doc=basic-series; 
http://www.lxway.com/62125684.htm;
http://www.jb51.net/article/39455.htm; 
http://blog.csdn.net/gzh0222/article/details/24543647; 
http://www.cnblogs.com/liuhaorain/archive/2012/01/24/2311352.html;

当然,series中的data数据是可以从服务器获取的,例如项目中的代码:

series : [ 
    {
    name : '订单数',
    data:getSeriesData2(seriesData,"订单数"),
    }]
/**
 * 动态的设置Highcharts的显示值
 * param 格式为从Action返回给页面的一个List<String>
 * @returns {Array}
 */
function getSeriesData2(param,param1){
    var returnData = [];
    actionData = param;
    if(actionData != null && actionData != ""){
        actionData = actionData.substring(1,actionData.length-1);
        var data = actionData.split(",");
        for(var i = 0;i<data.length;i++){
            //获得每组数组,数组0为订单数量;数组1为年月
            var subData = data[i].split(";");
            //分割年月(2015-1)
            var yearAndMonth = subData[1].split("-");
            var obj = {};
            obj.x = Date.UTC(yearAndMonth[0],yearAndMonth[1]);
            obj.y = parseFloat(subData[0]);//注意在动态赋值的时候:因为Y轴只能识别数字,所以这里需要把字符串subData[0]转换成数字
            obj.name = param1;
            returnData.push(obj);
        }
    }
    return returnData;
}
点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Wesley13 Wesley13
3年前
java将前端的json数组字符串转换为列表
记录下在前端通过ajax提交了一个json数组的字符串,在后端如何转换为列表。前端数据转化与请求varcontracts{id:'1',name:'yanggb合同1'},{id:'2',name:'yanggb合同2'},{id:'3',name:'yang
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
5个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Stella981 Stella981
3年前
Python之time模块的时间戳、时间字符串格式化与转换
Python处理时间和时间戳的内置模块就有time,和datetime两个,本文先说time模块。关于时间戳的几个概念时间戳,根据1970年1月1日00:00:00开始按秒计算的偏移量。时间元组(struct_time),包含9个元素。 time.struct_time(tm_y
Stella981 Stella981
3年前
Highcharts属性
1.Highcharts.setOptions({global:{useUTC : false}});2.$(function(){3.//声明报表对象4.var chart  new Highcharts.Chart({5.chart: {6.rende
Wesley13 Wesley13
3年前
Java日期时间API系列36
  十二时辰,古代劳动人民把一昼夜划分成十二个时段,每一个时段叫一个时辰。二十四小时和十二时辰对照表:时辰时间24时制子时深夜11:00凌晨01:0023:0001:00丑时上午01:00上午03:0001:0003:00寅时上午03:00上午0
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
11个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这