在网页上实现实时动态曲线——利用Highcharts控件和JQuery

Web上实现动态曲线

——实时地从数据库中获取数据,并在网页上实现无刷新显示。

      

本文利用JavaScript实现,每隔3秒,从数据库中获取一个数据,并在网页上动态显示。并且当用鼠标靠近曲线的点时,能够显示改点的相应的信息(横坐标和纵坐标值)。效果图(网页截图)如下图:

实现工具:Highcharts(www.highcharts.com/)和JQuery(http://jquery.com/)。其中主要参考了Highcharts的一个动态曲线的实例:http://www.highcharts.com/demo/dynamic-update

下面详细介绍开发过程。

开发工具:VisualStudio 2008

开发语言:C#和JavaScript(脚本语言)

系统环境:Windows7

数据表:数据表分为两列,第一列“time”,第二类“value”,在数据库中写一个名为Get_Value的存储过程,输入参数starttime,endtime,返回字段“time”值位于这两者之间的time和对应的value值。

具体步骤:

①    打开VS2008,新建网站HighchartsDemo,开始页面(默认)为Default.aspx;

②    下载highcharts.js和juery.min.js(在Google中搜索jquery-1.3.2.min.js ,并将文件名改为juery.min.js,当然也可以不改 ),将文件加入项目中,并新建文件夹JS,将这两个文件放入JS文件夹中;

③    在类_Default中添加静态变量:

static DateTime currenttime= Convert.ToDateTime("2009/07/13 0:20:00");

④    在Default.aspx.cs文件中加入一下函数:(注意要包含相应的应用)

//得到数据库中的数据,并在Highcharts控件中显示
[WebMethod]
    public static string getDataTableByAjax()
    {
        //连接字符串
        string sqlConnStr = "DataSource=NUAA-PC\\SQLEXPRESS;Initial Catalog=TempData;IntegratedSecurity=True";
        //数据集和数据适配器
        DataSetds = new DataSet("GetValue");
        SqlDataAdapterda = new SqlDataAdapter();
        using (SqlConnection sqlConn= new SqlConnection(sqlConnStr))
        {
            try
            {
                sqlConn.Open();
                //存储过程,”Get_Value”为存储过程名
                SqlCommandsqlComm = newSqlCommand("Get_Value",sqlConn);
                sqlComm.CommandType = CommandType.StoredProcedure;
                //添加查询参数和值
                sqlComm.Parameters.Add("@starttime", SqlDbType.DateTime).Value= currenttime;
                sqlComm.Parameters.Add("@endtime", SqlDbType.DateTime).Value= currenttime.AddMinutes(2);
                //执行存储过程
                sqlComm.ExecuteNonQuery();
                da.SelectCommand = sqlComm;
                da.Fill(ds);
                //创建存储返回值的表
                DataTabledt = new DataTable();
                //为表增加两个列,列名分别为x和y
                dt.Columns.Add("x", typeof(string));
                dt.Columns.Add("y", typeof(float));
				//将存储过程中的表复制到返回表中
                foreach(DataRow drin ds.Tables[0].Rows)
                {
                    DataRownewdr = dt.NewRow();
                    newdr["x"] = dr[0].ToString();
                    newdr["y"] = dr[1];
                    dt.Rows.Add(newdr);
                }
                 //更新currenttime,下次再访问该函数时,便得到不同的值,实现“实时”的要求
                currenttime= currenttime.AddMinutes(2);           
                stringresult = Dtb2Json(dt).ToString();
                returnresult.ToString();
            }
            catch
            {
                throw new Exception("调用Ajax Error");
            }
            finally
            {
               sqlConn.Dispose();
            }
        }
    }

    #region DataTablel Json
    public static string Dtb2Json(DataTabledtb)
    {
        JavaScriptSerializerjss = new JavaScriptSerializer();
        ArrayListdic = new ArrayList();
        foreach (DataRow row in dtb.Rows)
        {
            Dictionary<string, object> drow = new Dictionary<string,object>();
            foreach(DataColumn colin dtb.Columns)
            {
                drow.Add(col.ColumnName, row[col.ColumnName]);
            }
            dic.Add(drow);
        }
        return jss.Serialize(dic);
    }
	#endregion

⑤    在Default.aspx中适当地方加入以下代码:

<html xmlns="http://www.w3.org/1999/xhtml">
<head id="Head1" runat="server">
		<title>故障监测主页</title>
		<!—注意文件名应该和你下载的文件名保持一致 -->
		<script type="text/javascript"src="JS/jquery.min.js"></script>
		<script type="text/javascript"src="JS/highcharts.js"></script>
		<script type="text/javascript">
   		//<![CDATA[  
            $(function(){ 
                Highcharts.setOptions({
                     global: {
                        useUTC: false
                             }
                });
                //声明报表对象 
                var chart = new Highcharts.Chart({ 
                    chart:{ 
                    //将报表对象渲染到层上 
                    renderTo:'container' ,
                    defaultSeriesType:'spline'
                }, //chart end
                title:{
                   text:'实时PCA曲线'       
                },
                yAxis:{
                    title:{
                       text:'PCA值'           
                    }
                },
                //设定报表对象的初始数据 
                series:[{ 
                   data:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
                         0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
                         0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
                         0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]
                }]
            });  //Highcharts.Chart end       
        
                //获取后台数据
                functiongetForm(){
                    $.ajax({
                         type:"Post",
                         //后台获取数据的函数,注意当对该页面重命名时,
                          //必须手动更改该选项
                           url: "Default.aspx/getDataTableByAjax",
                           contentType:"application/json; charset=utf-8",
                           dataType:"json",
                           //成功获取数据
                           success:function (data){
                           data= jQuery.parseJSON(data.d); //JSON再次转换为Table 形式;
                           varseries= chart.series[0];
                          series.addPoint([data[0]["x"],data[0]["y"]],false,true);
                           chart.redraw();
                           },
                           //显示错误                                       
                           error:function (err){
                            alert(err + "调用后台程序出现错误,请尝试刷新!");
                        }
                     });
                }   
        
               $(document).ready(function() { 
                   //每隔3秒自动调用方法,实现图表的实时更新 
                   window.setInterval(getForm,2000);               
                });         
            }); 
            //]]>  
	</script>
</head>
<body>
      <div id="container" style="width: 800px; height: 600px; margin: 0 auto"></div>           
</body>
</html>

⑥    在浏览器中查看Default.aspx页,或者运行项目即可得到实时的动态曲线。

 


  • 3
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 17
    评论
好的,让我来帮您回答这个问题。首先,您需要安装 Highcharts 和 Vue 。然后,您可以将 Highcharts 引入您的 Vue 组件并创建一个气泡图。 以下是实现的步骤: 1. 安装 Highcharts 您可以通过 NPM 或 Yarn 安装 Highcharts 依赖。 npm install highcharts --save 或 yarn add highcharts 2. 引入 Highcharts 模块 在您的 Vue 组件中,您需要引入 Highcharts 模块。 import Highcharts from "highcharts"; 3. 创建 Vue 组件 您可以创建一个 Vue 组件,例如 BubbleChart 。 Vue.component("bubble-chart", { template: ` <div ref="chart"></div> `, mounted() { this.renderChart(); }, methods: { // 渲染气泡图 renderChart() { Highcharts.chart(this.$refs.chart, { chart: { type: "bubble", plotBorderWidth: 1, zoomType: "xy" }, title: { text: "气泡图" }, xAxis: { gridLineWidth: 1 }, yAxis: { startOnTick: false, endOnTick: false }, series: [ { data: [ [9, 81, 63], [98, 5, 89], [51, 50, 73], [41, 22, 14], [58, 24, 20], [78, 37, 34], [55, 56, 53], [18, 45, 70], [42, 44, 28], [3, 52, 59], [31, 18, 97], [79, 91, 63], [93, 23, 23], [44, 83, 22] ], marker: { fillColor: { radialGradient: { cx: 0.4, cy: 0.3, r: 0.7 }, stops: [ [0, "rgba(255,255,255,0.5)"], [1, Highcharts.Color(Highcharts.getOptions().colors[0]).setOpacity(0.5).get("rgba")] ] } } } ] }); } } }); 4. 使用组件 在您的 Vue 文件或模板中使用 BubbleChart 组件。 <template> <div> <h1>气泡图示例</h1> <bubble-chart></bubble-chart> </div> </template> 5. 运行您的应用 现在您可以运行您的应用并查看气泡图的效果。 这是一个简单的示例,您可以根据您自己的需求进行调整。希望这可以帮助您实现一个气泡图!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 17
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

nuaazdh

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值