在网页上实现实时动态曲线——利用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 drow = new Dictionary();
            foreach(DataColumn colin dtb.Columns)
            {
                drow.Add(col.ColumnName, row[col.ColumnName]);
            }
            dic.Add(drow);
        }
        return jss.Serialize(dic);
    }
	#endregion

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



		故障监测主页
		
		
		
		


      

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

 


你可能感兴趣的:(C#,SQL数据库开发)