Asp .net MVC4 利用Highcharts.js 生成曲線圖

1、先來看看效果css

  

2、前臺實現代碼html

  一、引入相對應得css及Javascript文件jquery

        <link href="~/Content/css/bootstrap.css" rel="stylesheet" />
        <link href="~/Content/css/css.css" rel="stylesheet" />
        <script src="~/Scripts/jquery-1.8.2.min.js"></script>
        <script src="~/Scripts/js/bootstrap.min.js"></script>
        <script src="~/Scripts/js/datepicker/WdatePicker.js"></script>
        <script src="~/Scripts/js/highcharts.js"></script>
        <script src="~/Scripts/js/exporting.js"></script>
ajax

  <style type="text/css">
        #AssayItems {
            width: 100%;  
            margin:10px auto;  
            text-align:center;
            vertical-align:middle;
            border: 1px solid #F8F8FF;
            display: none;
        }

        #Loading {
            text-align: center;
            display: none;
        }
    </style>
json

  二、統計按鈕觸發的事件bootstrap

    $("#statiBtn").click(function () {
                    var Processid = $("#Process_PTR").children('option:selected').val();
                    ItemNo = $("#ItemNo").children('option:selected').val();
                    selectTit = $("#ItemNo").children('option:selected').text();
                    v = $("#Process_PTR").children('option:selected').text();
                    var begintime = $("#beginDate").val();
                    var lasttime = $("#lastDate").val();
                    LoadMEIRange(ItemNo,currRV);
                    $.ajax({
                        type: "POST",
                        url: '../StatisticsAssay/LoadCharts',
                        data: { 'Process_PTR': Processid, 'ItemNo': ItemNo, 'beginDate': begintime, 'lastDate': lasttime },
                        dataType: "json",
                        error: function (request) {
                            alert("Connection error");
                        },
                        beforeSend: function () {
                            //加載圖標
                            $("#Loading").show();
                            $("#AssayItems").hide();
                        },
                        success: function (result) {
                            $("#AssayItems").show();
                            var assalyData = result;
                            var assaly = eval('(' + assalyData + ')');
                            var assalyd = eval('(' + assaly + ')');
                            var timeArr = new Array();
                            var resArr = new Array();
                            $.each(assalyd.ds, function (i, idtem) {
                                timeArr[i] = idtem.Timer; // 時間值
                            });
                            $.each(assalyd.res, function (i, idtem) {
                                resArr[i] = idtem.Result; // 檢測結果
                            });

                            //加載曲線圖
                            LoadCharts(timeArr, resArr);
                            $("#Loading").hide();
                        }
                    });
                    //防止Ajax頁面提交後被刷新
                    //return false;
                });
ide

  三、生成曲線圖
url

  function LoadCharts(t,c)
        {
            Highcharts.setOptions({
                lang: {
                    printChart: "打印圖表",
                    downloadJPEG: "下載JPEG 圖片",
                    downloadPDF: "下載PDF文檔",
                    downloadPNG: "下載PNG 圖片",
                    downloadSVG: "下載SVG 矢量圖",
                    exportButtonTitle: "導出圖片"
                }
            });
            $('#AssayItems').highcharts({
                chart: {
                    type:'line'
                },
                title: {
                    text:''+v+'化驗分析曲線圖',
                    x: -20
                },
                xAxis: {//X軸標籤
                    categories: t,
                    labels: {
                        rotation: -25,
                        style: {
                            fontSize: '10px',
                            fontFamily: 'Verdana, sans-serif'
                        }
                    }
                },
                yAxis: {
                    title: {
                        text: '統計數'
                    },
                    plotLines: [{
                        value: SXNums,
                        color: 'red',
                        dashStyle: 'shortdash',  
                        width: 2,  
                        label: {  
                            text: 'MEI下範圍('+SXNums+')'  
                        }  
                    },
                    {
                        value: MIDNums,
                        color: 'green',  
                        dashStyle: 'shortdash',  
                        width: 2,  
                        label: {  
                            text: 'MEI中範圍(' + MIDNums + ')'
                        }  
                    },
                    {
                        value:XXNums,
                        color: 'red',  
                        dashStyle: 'shortdash',  
                        width: 2,  
                        label: {  
                            text: 'MEI上範圍(' + XXNums + ')'
                        }  
                    }]
                },
                colors:
                [
                    '#00B2EE'
                ],  
                legend: {
                    layout: 'vertical',
                    align: 'right',
                    verticalAlign: 'middle',
                    borderWidth: 0
                },
                series: [
                {
                    name: '' + selectTit + '',
                    data: c
                }
                ]
            });
        }
spa

 

2、後臺實現代碼htm

  一、獲取Mei範圍

  public ActionResult LoadMEIRange()
        {
            int itemno = 0;
            int processid = 0;
            string meiStr = "";
            if (Request["itemno"] != null && Request["itemno"].ToString() != "")
            {
                itemno = Convert.ToInt32(Request["itemno"].ToString());
                processid = Convert.ToInt32(Request["processid"].ToString());
            }
            else
            {
                itemno = 1;
                processid = 1;
            }
            string meiSql = "select MeiRange from Assay_ProcessDetails where Process_PTR="+processid+" and ItemNo="+itemno+"";
            DataTable dt = SqlHelper.QueryTable(meiSql);
            if (dt.Rows.Count > 0)
            {
                meiStr = dt.Rows[0]["MeiRange"].ToString();
            }
            return Content(meiStr);
        }

 

3、博客地址:http://www.cnblogs.com/Resources-blogs/p/6600107.html

相關文章
相關標籤/搜索