在FusionCharts中有一种特有的方法--向下钻取,应用此方法,我们可以将任意图表转换成一个热点或链接。这样能给我们的图形带来更好的视觉效果与功能效果。

    向下钻取主要有两种方法,一种是简单简单链接,一种是图表链接。图表链接可以从图表链接到图表(有兴趣的可以自己试试,本篇就不再介绍),下面我们注意说一下简单链接与图表获取单击事件。

    使用XML文件进行设置连接:      

<?xml version="1.0" encoding="utf-8" ?>
<graph baseFont='SunSim' baseFontSize='12' caption='分析' subcaption='' yAxisMinValue='51650.1' yAxisMaxValue='71118.3' xaxisname='日期' yaxisname='数量' hovercapbg='FFECAA' hovercapborder='F47E00' formatNumberScale='0' decimalPrecision='0' showvalues='1' numdivlines='10' numVdivlines='0' shownames='1' rotateNames='1'>
  <set name='2009-10-04' value='57653' color='AFD8F8' link='Index.html'/>
  <set name='2009-10-05' value='57389' color='F6BD0F' link='j-myJS-1079'/>
  <set name='2009-10-06' value='59256' color='8BBA00'/>
  <set name='2009-10-07' value='62762' color='FF8E46'/>
  <set name='2009-10-08' value='63287' color='008E8E'/>
  <set name='2009-10-09' value='60109' color='D64646'/>
  <set name='2009-10-10' value='64653' color='8E468E'/>
  <set name='2009-10-11' value='61687' color='588526'/>
</graph>
    在XML元素中,加入link标签,如果是想跳转页面,只需要写上要跳转的页面即可。若要获取单击事件,我们可以使用link="j-myJS-1079",其中j表示我们使用的是js,固定形式;myJS是自己前台要写的js函数名称;1079是自己要传递的参数,多个参数可以使用逗号隔开。

    前台js函数:      

<script>
        function myJS(myVar) {
            alert(myVar);          
        }       

    </script>
     其效果如下:

       


    使用json串实现单击事件也是类似,只需要在转json的过程中加入link标签,然后可以设置需要传递的参数 (部分代码,完整代码请看上篇)   

 //设置系列中的内容
            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.Append(" \"link\":\"j-myJS-");
                    jsonBuilder.Append(dt.Columns[i + 1].ColumnName);
                    jsonBuilder.Append(",");
                    jsonBuilder.Append(dt.Rows[i][0].ToString());
                    jsonBuilder.Append("\"},");

                    //jsonBuilder.Append("{\"value\": \"");
                    //jsonBuilder.Append(dt.Rows[j][i + 1].ToString());

                    //jsonBuilder.Append("\"},");
                }
                jsonBuilder.Remove(jsonBuilder.Length - 1, 1);
                jsonBuilder.Append("]},");
            }
    在往json串中添加时,需要注意添加的位置,需要设置在系列值中。

  

   小结:

      初次接触FusionCharts时,挺陌生的,尤其是在项目中应用。一方面是项目重新封装,另一方面是实际操作能力,但是随着不断的接触学习,对它的理解也不断加深,使用的熟练程度也不断提高。在这个过程中,一定要多看使用文档,会给我的理解带来极大的方便。

    

 posted on 2016-07-26 19:45  走出自己的未来  阅读(277)  评论(0编辑  收藏  举报