上篇介绍了FusionCharts加载XML文件,这篇将介绍另一种加载方式,使用json串。通常我们在前台使用ajax来异步加载后台的数据,后台处理table数据,转换成json,这样就可以将数据展现给用户。具体的过程如下:

   首先说一下后台获取数据及将数据转换成json格式:     

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Data;
using System.Data.OracleClient;
namespace FusionCharts
{
    /// <summary>
    /// getData 的摘要说明
    /// </summary>
    public class getData : IHttpHandler
    {

        public void ProcessRequest(HttpContext context)
        {
            context.Response.ContentType = "text/plain";

            context.Response.Write(getAllData(context));
        }

        /// <summary>
        /// 获取数据
        /// </summary>
        /// <param name="context"></param>
        /// <returns>json串</returns>
        public string getAllData(HttpContext context)
        {
            string test = "";
            string connString = @"Data Source=  
                   (DESCRIPTION=  
                   (ADDRESS=(PROTOCOL=TCP)(HOST=127.0.0.1)(PORT=1521))  
                   (CONNECT_DATA=  
                   (SERVICE_NAME=ORCL)));  
                   User Id=drp;Password=drp";

            try
            {
                OracleConnection conn = new OracleConnection(connString);
                string sql = "select name,  sum(case Course when '数学' then Score else null end) Math,         sum(case Course when '英语' then Score else null end) English   from test where name='victor' or name='lucy' or name='Jim'  group by name";
                OracleCommand cmd = new OracleCommand(sql, conn);
                OracleDataAdapter da1 = new OracleDataAdapter(cmd);
                DataSet ds1 = new DataSet();//定义数据集
                da1.Fill(ds1);
                DataTable dt = ds1.Tables[0];
                int rowcount = 0;
                if (dt.Rows.Count > 0)
                {
                    rowcount = dt.Rows.Count;
                }
                test = Dataset2Json(ds1, rowcount);

            }
            catch (Exception ex)
            {
                // Response.Write(ex.Message);
            }
            return test;
        }

        /// <summary>  
        /// DataSet转换成Json格式   
        /// </summary>   
        /// <paramname="ds">DataSet</param>  
        ///<returns></returns>   
        //public static string Dataset2Json(DataSet ds, int Fpage, int FpageSize, int total = -1)
        public static string Dataset2Json(DataSet ds, int total = -1)
        {
            System.Text.StringBuilder json = new System.Text.StringBuilder();

            foreach (DataTable dt in ds.Tables)
            {
                //设置表格属性
                json.Append("{\"chart\":{");
                //表格主题
                json.Append("\"caption\":");
                json.Append("\"成绩分析\",");
                //x轴
                json.Append("\"xAxisname\":");
                json.Append("\"姓名\",");
                //y轴
                json.Append("\"yAxisName\":");
                json.Append("\"成绩\"},");
                //加载具体内容
                json.Append(DataTable2Json(dt));
                json.Append("}");
            } return json.ToString();
        }

        /// <summary>   
        /// dataTable转换成Json格式   
        /// </summary>   
        /// <paramname="dt"></param>   
        ///<returns></returns>   
        //public static string DataTable2Json(DataTable dt, int Zpage, int ZpageSize)
        public static string DataTable2Json(DataTable dt)
        {
            System.Text.StringBuilder jsonBuilder = new System.Text.StringBuilder();
            //设置系列
            jsonBuilder.Append("\"categories\":[{");
            //设置每个系列
            jsonBuilder.Append("\"category\":[");
            for (int i = 0; i < dt.Rows.Count; i++)
            {

                jsonBuilder.Append("{\"label\":\"");
                jsonBuilder.Append(dt.Rows[i][0].ToString());

                jsonBuilder.Append("\"},");

            }
            if (dt.Rows.Count > 0)
            {
                jsonBuilder.Remove(jsonBuilder.Length - 1, 1);
            }
            jsonBuilder.Append("]}],");
            //设置系列中的内容
            jsonBuilder.Append("\"dataset\": [");
            for (int i = 0; i < dt.Columns.Count - 1; i++)
            {
                //设置各系列值
                jsonBuilder.Append("{\"seriesname\":\"");
                jsonBuilder.Append(dt.Columns[i + 1].ColumnName);
                jsonBuilder.Append("\",\"data\": [");
                for (int j = 0; j < dt.Rows.Count; j++)
                {                    
                    jsonBuilder.Append("{\"value\": \"");
                    jsonBuilder.Append(dt.Rows[j][i + 1].ToString());

                    jsonBuilder.Append("\"},");
                }
                jsonBuilder.Remove(jsonBuilder.Length - 1, 1);
                jsonBuilder.Append("]},");
            }
            if (dt.Rows.Count > 0)
            {
                jsonBuilder.Remove(jsonBuilder.Length - 1, 1);
            }
            jsonBuilder.Append("]");

            string jsonstr = jsonBuilder.ToString();
            return jsonstr;

        }

        public bool IsReusable
        {
            get
            {
                return false;
            }
        }
    }
}
   在这里,需要说明一下获取到的 table的数据,如下:

       

   页面设置如下:      

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="firstChart.aspx.cs" Inherits="FusionCharts.firstChart" %>

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title></title>    
</head>
<body>
    <form id="form1" runat="server">
        <table>
            <tr>
                <td style="width: 50%; height: 50%">
                    <div id="Column2D"></div>
                </td> 
            </tr>         
        </table>

    </form>
</body>
</html>
<script src="FusionCharts/FusionCharts.js"></script>
<script src="jQuery/jquery-1.6.4.min.js"></script>
<script type="text/javascript">
    
    var chart1 =
   new FusionCharts('FusionCharts/MSColumn2D.swf', "ChartId", "400", "300");
   
    $.ajax( {
        type: "POST",       
        url: "getData.ashx",
        dataType: "json",
        success: function (data) {            
            chart1.setJSONData(data);
            
        },
        error: function (data) {
          
    }  
    })    
    chart1.render('Column2D');    
    
</script>
   其效果如下:(柱状图2D)

                                 

    同样,跟之前说的一样,替换核心SWF文件即可加载不同样式的 图表,如下效果:

    柱状图3D:

                            


    小结:

       使用json加载与XML加载的基本原理是一样的,我们也可以将table中的数据转换成XML格式来进行加载。需要注意的是在转换的过程中要注意FusionCharts所能识别的格式,它所加载的json格式与我们之前使用ajax+EasyUI加载后台的json串格式有点不同。

       介绍完基本的加载形式之后,下篇介绍一下FusionCharts中的向下钻取。

 posted on 2016-07-23 14:48  走出自己的未来  阅读(234)  评论(0编辑  收藏  举报