`
wujunyi911622
  • 浏览: 9341 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

pushlet结合fusionCharts

 
阅读更多

Fusioncharts
FusionCharts是一个Flash的图表组件,它可以用来制作数据动画图表等

使用它非常简单,我按照在开发这个test的过程记录

首先将FusionCharts.js和Line.swf拷贝到你项目的WebContent(WebRoot)下


pushlet

1:到http://sourceforge.net/projects/pushlets/files/pushlets/上下载pushlet.jar并把它放到lib目录中,引入到工程。并且将pushlet.properties和sources.properties两个文件拷贝到WEB-INF目录中去
目录结构如下:



 2:在你的web.xml中加入

 

 <servlet>
    <servlet-name>pushlet</servlet-name>
    <servlet-class>
            nl.justobjects.pushlet.servlet.Pushlet
        </servlet-class>
    <load-on-startup>1</load-on-startup>
  </servlet>
  <servlet-mapping>
    <servlet-name>pushlet</servlet-name>
    <url-pattern>/pushlet.srv</url-pattern>
  </servlet-mapping>
  <welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
  </welcome-file-list>

 

3:修改你的sources.properties文件

加入你的pushle类

source9=com.wjy.HelloWorldPushlet

 


4:然后编写index.jsp

 

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">
<title>hello chart</title>
<meta http-equiv="pragma" content="no-cache">
    <meta http-equiv="cache-control" content="no-cache">
    <meta http-equiv="expires" content="0">   
    <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
    <meta http-equiv="description" content="This is my page">
    <script type="text/javascript" src="ajax-pushlet-client.js"></script>
<script language="JavaScript" src='FusionCharts.js'></script>  

</head>
<body>
<form >

<div id="ok"></div>
<div id="chartdiv" align="center">
<script type="text/javascript">
 PL._init();
 PL.joinListen('/ok/haha');
 function onData(event) {
  var dataXml ="<graph baseFont='SunSim' baseFontSize='12' caption='折线图' subcaption='' xAxisName='时间' yAxisName='数字' hovercapbg='FFECAA' hovercapborder='F47E00' formatNumberScale='0' decimalPrecision='2' showValues='1' numdivlines='10' numVdivlines='0' showNames='1' rotateNames='1' rotateYAxisName='0' showAlternateHGridColor='1'>";
     dataXml += event.get("haha");
     dataXml += "</graph>"; 
     var chart = new FusionCharts('Line.swf', "ChartId", "1024", "600");
     chart.setDataXML(dataXml);
     chart.render('chartdiv');
 }
</script>
</div>
</form> 
</body>
</html>

 

5:后天HelloWorldPushlet 代码

 package com.wjy;

import java.io.Serializable;
import java.util.Calendar;

import net.sf.json.JSONArray;
import net.sf.json.JSONObject;
import nl.justobjects.pushlet.core.Event;
import nl.justobjects.pushlet.core.EventPullSource;

@SuppressWarnings("serial")
public class HelloWorldPushlet extends EventPullSource implements Serializable {
 StringBuffer stringBuffer = new StringBuffer();
 
 JSONArray helloArray = new JSONArray();
    /**
     * 设置休眠时间
     */
    @Override
    protected long getSleepTime() {
        return 5000;
    }     
    /**
     * 创建事件
     *
     * 业务部分写在pullEvent()方法中,这个方法会被定时调用。
     */
    @Override
    protected Event pullEvent() {
     Long time = System.currentTimeMillis();
        Event event = Event.createDataEvent("/ok/haha");
        Calendar c = Calendar.getInstance();
        c.add(Calendar.DAY_OF_MONTH, 0);      
        StringBuffer sb = new StringBuffer();
        sb.append(c.get(Calendar.HOUR_OF_DAY));
        sb.append(":");
        sb.append(c.get(Calendar.MINUTE));
        sb.append(":");
        sb.append(c.get(Calendar.SECOND));
        StringBuffer sb1 = new StringBuffer();
        sb1.append((""+time).substring(8));
        if(null != helloArray && helloArray.size() > 11){
         helloArray.remove(0);               
        }
        HelloBean helloBean = new HelloBean();
     helloBean.setKey(sb.toString());
     helloBean.setValue(sb1.toString());
     helloArray.add(helloBean);

        StringBuffer strXml = new StringBuffer();   
        for(Object hello : helloArray){
   JSONObject jsonHelloBean = (JSONObject)hello;
   String key = jsonHelloBean.getString("key");
   String value = jsonHelloBean.getString("value");
   strXml.append("<set name='" + key + "' value='" + value + "' color='AFD8F8' />");
        }  
        String str =  strXml.toString(); 
        event.setField("haha", str);
        return event;
    }  
}
 

以上 每5秒钟刷新一次fusioncharts展现;

 

 

 

 

---------------------------------------------------------------------

以下是 复杂一点的功能;首次是查询,后面是每隔一段时间刷新一次

DataCollectPushletAction 中内嵌DataCollectPushlet ;外面实现业务

内部类实现推送服务数据

 

 

 

 package com.topinfo.action;

import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;
import java.util.List;

import nl.justobjects.pushlet.core.Event;
import nl.justobjects.pushlet.core.EventPullSource;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.context.annotation.Scope;
import org.springframework.stereotype.Controller;
import com.topinfo.entity.DataCollect;
import com.topinfo.entity.DataEquipment;
import com.topinfo.entity.DataMachine;
import com.topinfo.service.DataCollectService;
import com.topinfo.service.DataEquipmentService;
import com.topinfo.service.DataMachineService;

/**
 *
 *@Description: 将实时数据推送到前台,结合前台fusionCharts展现
 *@Since:2013-6-28上午09:14:41
 */
@Controller
@Qualifier
@Scope("prototype")
public class DataCollectPushletAction extends BaseAction {
  

 /**
  *@Fields serialVersionUID : (用一句话描述这个变量表示什么)
  */
 private static final long serialVersionUID = 1L;
  
 private static DataCollectService dataCollectService;
 
 private static List<DataCollect> dataCollectList; 
 
 private static Date                 startDate;
   
    private static Long      equipmentKey;
   
    static SimpleDateFormat formatter = new SimpleDateFormat("HH:mm:ss");
   
 @Autowired
 private DataMachineService dataMachineService;
 
 @Autowired
 private DataEquipmentService dataEquipmentService;
 
    private Long      machineKey;
   
    /**
     *
     *@Description: 跳转到页面 根据equipmentKey来查它相关的最近半小时数据

     *@Since: 2013-6-28上午09:16:07
     *@return
     */
    public String ssxxtj(){  
     String dataString = "";
     Calendar c = Calendar.getInstance();
     c.add(Calendar.MINUTE, -30);
     startDate = c.getTime();
     dataCollectList = dataCollectService.getXxtjList(equipmentKey,startDate,null);
     StringBuffer strXml = new StringBuffer();        
        for(DataCollect dc : dataCollectList){
         strXml.append("<set name='" + formatter.format(dc.getCollectTime()) + "' value='" + dc.getDataValue() + "' color='FF1493' />");
        }
        dataString = strXml.toString();
     request.setAttribute("dataString", dataString);
     return "ssxxtj";
    }
 
    /**
     *
     *@Description: 根据equipmentKey来查它相关的最近半小时数据

     *@Since: 2013-6-28上午09:46:21
     */
    public static void pullPerMinute(){
     Calendar c = Calendar.getInstance();
      c.add(Calendar.MINUTE, -30);
      startDate = c.getTime();
      if(null != dataCollectService){
       dataCollectList = dataCollectService.getXxtjList(equipmentKey,startDate,null);
      }
    }
   
    public static class DataCollectPushlet extends EventPullSource{
     /**
      *
      *@Description: 设置休眠时间(设置1分钟)
      *@Author: WuJunyi
      *@Since: 2013-6-27下午03:22:02
      *@return
      */
     @Override
     protected long getSleepTime() {  
      return 15000;
     }
     /**
      *
      *@Description: 创建事件,统计数据等业务写在pullEvent()方法中,这个方法会被定时调用。
      *根据equipmentKey来查它相关的最近半小时数据
      *@Since: 2013-6-27下午03:22:24
      *@return
      */
     @Override
     protected Event pullEvent() {      
            Event event = Event.createDataEvent("/ok/haha");
            StringBuffer strXml = new StringBuffer();
            if(null != dataCollectList){
              for(DataCollect dc : dataCollectList){
         String key = formatter.format(dc.getCollectTime());
         Double value = dc.getDataValue();
         strXml.append("<set name='" + key + "' value='" + value + "' color='AFD8F8' />");
              }
            }
            String str =  strXml.toString(); 
            event.setField("haha", str);
            pullPerMinute();
            return event;
     } 
    }
    /**
     *
     *@Description: 获取所有机器
     *@Since: 2013-6-26上午09:22:43
     *@return
     */
    public List<DataMachine> getMachine(){
     return dataMachineService.findAllDataMachine();
    }
   
    /**
     *
     *@Description: 根据机器id获取该机器的所有设备
     *@Since: 2013-6-26上午09:26:48
     *@return
     */
    public List<DataEquipment> getByMachineId(){
     return dataEquipmentService.getByMachineId(machineKey);
    }
   
 public static DataCollectService getDataCollectService() {
  return dataCollectService;
 }

 @Autowired(required = true)
 public void setDataCollectService(DataCollectService dataCollectService) {
  DataCollectPushletAction.dataCollectService = dataCollectService;
 }

 public static List<DataCollect> getDataCollectList() {
  return dataCollectList;
 }

 public static void setDataCollectList(List<DataCollect> dataCollectList) {
  DataCollectPushletAction.dataCollectList = dataCollectList;
 }

 public static Date getStartDate() {
  return startDate;
 }

 public static void setStartDate(Date startDate) {
  DataCollectPushletAction.startDate = startDate;
 }

 public static Long getEquipmentKey() {
  return equipmentKey;
 }

 public static void setEquipmentKey(Long equipmentKey) {
  DataCollectPushletAction.equipmentKey = equipmentKey;
 }

 public Long getMachineKey() {
  return machineKey;
 }

 public void setMachineKey(Long machineKey) {
  this.machineKey = machineKey;
 }

}

 

 

jsp页面

<%@ page language="java" contentType="text/html; charset=utf-8"
 pageEncoding="utf-8"%>
<%@ taglib uri="/struts-tags" prefix="s"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<base href="<%=basePath%>">
<title></title>
<link rel="stylesheet" type="text/css" href="css/common.css" />
<script  type="text/javascript"
 src="javascript/jquery-1.4.2.min.js"></script>
<script src="javascript/tuxun_tips.js" type="text/javascript"></script>
<script type="text/javascript" src="javascript/view/view.js"></script>
<script type="text/javascript" src="javascript/common.js"></script>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<script type="text/javascript" src='javascript/FusionCharts.js'></script> 
<script type="text/javascript" src="javascript/ajax-pushlet-client.js"></script>

</head>
<body>

 <form action="dataCollectPushletAction!ssxxtj.action" name="form1" id="form1"
  method="get">
  <h2 class="content_title  marginTop10 textIndent">采集数据列表</h2>
  <div class="search_div  marginTop10">
   <table class="search_table marginLeft40">
    <tr>
     <td class="search3_title">采集机器:</td>
     <td class="search3_text">
      <span class="select_span">
      <select name="machineKey" id="machine_Key">
              <option value="">-请选择-</option>
              <s:iterator value="getMachine()">
               <option value="${machineId }" <s:if test="machineId == machineKey">selected</s:if> >${name }</option> 
              </s:iterator>
             </select>
     </span>
     </td>

     <td class="search3_title">采集设备:</td>
     <td class="search3_text">
      <span class="select_span">
      <select name="equipmentKey" id="equipment_Key">
              <option value="">-请选择-</option>
              <s:iterator value="getByMachineId()">
               <option value="${equipmentId }" <s:if test="equipmentId == equipmentKey">selected</s:if> >${name }</option> 
              </s:iterator>
             </select>
     </span>
     </td>
     <td class="searc5_btn" colspan="3"><input type="submit" value="查询"
      data-hover="24" class="default_btn marginRight20 floatRight"/>
     </td>
    </tr>
   </table>
  </div>
  <p class="search_bottom ">&nbsp;</p>
  <div id="chartdiv" align="center" class="table_list_div  marginTop10">
  <script type="text/javascript">     
    var flag = true;    
    if(flag){
     var dataXml ="<graph baseFont='SunSim' baseFontSize='12'  subcaption=''  hovercapbg='FFECAA' hovercapborder='F47E00' formatNumberScale='0' decimalPrecision='2' showValues='1' numdivlines='10' numVdivlines='0' showNames='1' rotateNames='1' rotateYAxisName='0' showAlternateHGridColor='1'>";    
     dataXml += "<%=request.getAttribute("dataString") %>";   
        dataXml += "</graph>";
     var chart = new FusionCharts('swf/Line.swf', "ChartId", "1050", "360");
     chart.setDataXML(dataXml);
     chart.render('chartdiv');
    }
    PL._init();
    PL.joinListen('/ok/haha');
    function onData(event) {
     var dataXml ="<graph baseFont='SunSim' baseFontSize='12' subcaption='' hovercapbg='FFECAA' hovercapborder='F47E00' formatNumberScale='0' decimalPrecision='2' showValues='1' numdivlines='10' numVdivlines='0' showNames='1' rotateNames='1' rotateYAxisName='0' showAlternateHGridColor='1'>";
        dataXml += event.get("haha");
        dataXml += "</graph>"; 
        var chart = new FusionCharts('swf/Line.swf', "ChartId", "1024", "600");
        chart.setDataXML(dataXml);
        chart.render('chartdiv');
        flag = false;
    }
  </script>    
  </div>
 </form>
</body>
<script type="text/javascript">
$(document).ready(function(){
 init();
 var message = "<s:property value='message'/>";
 if (message.length != 0){
  tuxunTips.createTips(message,"middle");
 }
});

$(document).ready(function(){
  $("#machine_Key").change(function(){
    if($(this).val() == ""){
     $("#equipment_Key").html("<option value=\"\">- 请选择 -</option>");
    }else{
     $.post("dataCollectAction!getOptionsByMachineId.action",{machineId:$(this).val()},function(result){
      $("#equipment_Key").html("<option value=\"\">- 请选择 -</option>"+result);
     });
    }
  });
});
</script>
</html>

 

 

开发中遇到两个问题:第一,实现业务查询action为了使用pushlet,内部定义了static类实现EventPullSource,业务接口在内部类无法注入,后来采用@Autowired(required = true)
 public void setDataCollectService(DataCollectService dataCollectService) {
  DataCollectPushletAction.dataCollectService = dataCollectService;
 }来注入;希望各位兄弟姐妹能给出别的注入方式。

第二:

 位置不能换,换了只有google浏览器能用,调试很长时间才换了现在这个顺序,这个顺序就ok;

 

 

这次做的小记一个目的是记录一下,代码规范之类的就没有考虑,现在这个功能就是每隔一定的时间刷新一次,能否有什么方法让线条在向左推送而不是刷新整个页面

 

相关下载

 

  • 大小: 40.6 KB
  • 大小: 78.5 KB
分享到:
评论

相关推荐

    pushlet 之 Pushlet使用手把手实例

    在实际开发中,Pushlet可以与各种工具集成,例如与Spring框架结合,或者利用Maven构建项目。这需要你熟悉相关的集成技术和配置。 总结,Pushlet 提供了一种高效、简单的实现服务器推送的解决方案,通过本文档中的...

    pushlet jar包下载

    服务器推 pushlet 服务器推 pushlet 服务器推 pushlet 服务器推 pushlet

    pushlet

    Pushlet的核心组件是Pushlet Server和Pushlet Client。Pushlet Server作为服务端,接收并处理客户端的连接,当有新的数据可用时,会主动将数据推送到已经建立连接的客户端。Pushlet Client则是在用户端运行的程序,...

    pushlet简单配置应用

    Pushlet是一种基于Java的实时数据推送技术,由荷兰JustObjects公司开发。Pushlet库的核心功能是实现实时的服务器向客户端推送数据,而无需客户端频繁发起请求,这大大提高了网络应用的效率和用户体验。以下是对...

    Pushlet点对点发送消息

    Pushlet结合点对点的概念,可以构建出分布式、高效且健壮的消息传递系统。 在"Pushlet点对点发送消息"这个主题中,我们可以深入探讨以下几个关键知识点: 1. **Pushlet框架**:Pushlet是Apache Cocoon项目的一部分...

    服务器推送pushlet讲解

    Pushlet的核心概念包括Pushlet服务器、Pushlet客户端和Pushlet事件。 1. Pushlet服务器:这是Comet服务的实现,负责接收客户端连接并保持连接打开状态,直到有新的数据可推送到客户端。 2. Pushlet客户端:通常是一...

    PushLet实例,可直接运行

    在实际应用中,PushLet可以与各种前端技术(如JavaScript、jQuery、WebSocket等)结合,构建出交互性强、用户体验优秀的实时Web应用。同时,由于PushLet基于Java,所以它可以很好地融入Java EE环境,与其他企业级...

    pushlet.jar 和示例工程

    "pushlet.jar 和示例工程"是一个专注于实现服务器端向客户端主动推送消息的框架,它在Web开发领域中扮演着重要角色。Pushlet框架的设计旨在克服传统的HTTP协议中客户端请求、服务器响应的被动通信模式,转而采用一种...

    pushlet服务器推技术例子

    【Pushlet服务器推技术】是一种实时通信技术,主要用于构建能够实时推送信息的Web应用程序,比如聊天、股票更新、在线游戏等场景。Pushlet是基于Java的开源项目,它利用了HTTP的长连接特性,实现了服务器主动向...

    pushlet实现简单的用户聊天

    在IT行业中,Pushlet是一种基于Java的推送技术,主要用于实现实时的数据传输,尤其是在Web应用中创建实时聊天、通知服务等功能。Pushlet是基于HTTP连接持久化的概念,它允许服务器主动向客户端推送数据,而无需...

    Pushlet简单示例测试

    Pushlet是一种基于Java的实时数据推送技术,它允许服务器向客户端主动推送数据,而无需客户端持续不断地轮询请求。在Web应用中,Pushlet能够显著提高用户体验,因为它减少了延迟并优化了服务器资源的使用。本示例...

    comet 框架 之 pushlet

    在pushlet-2.0.3这个压缩包中,可能包含了Pushlet框架的源代码、文档、示例代码和配置文件等,用于帮助开发者理解和使用Pushlet。开发者可以通过阅读源码了解其工作原理,参考示例快速入门,通过配置文件定制Pushlet...

    PUSHLET即时通讯工程实例

    - **AJAX**:在客户端,通常结合JavaScript使用AJAX技术来异步更新页面,提高用户体验。 总结,PUSHLET即时通讯工程实例是一个实际的Java Web应用,展示了如何利用Servlet和WebSocket实现即时通讯。通过部署在...

    pushlet 和comet 资料介绍

    Pushlet和Comet技术是Web服务器向浏览器推送数据的两种策略,主要用于实现实时的、双向的通信。这两种技术在传统的HTTP协议基础上进行了扩展,克服了HTTP请求-响应模型的限制,使得服务器能够主动向客户端推送数据,...

    pushlet文档和项目

    Pushlet是一种基于Java的推送技术框架,用于实现实时数据从服务器向客户端的推送。Pushlet项目是由Peter Mularien开发的,它提供了一个简单、轻量级的解决方案,允许服务器端主动向浏览器或其他客户端应用程序发送...

    Pushlet的Ajax-pushlet-client.js分析

    《Pushlet的Ajax-pushlet-client.js深度解析》 在当今的Web开发中,实时通信技术已经成为了一项不可或缺的技能,而Pushlet的Ajax-pushlet-client.js则是实现服务器“推”技术的重要工具。本文将深入剖析这个...

    pushlet例子

    【服务器推送技术与Pushlet详解】 服务器推送技术是一种在Web应用中实现实时通信的方法,它与传统的HTTP请求-响应模型不同。在传统的模型中,客户端(浏览器)需要不断地发起请求来获取新数据,而在服务器推送技术...

    Pushlet白皮书

    虽然**Pushlet**最初是为Java开发的,但它也可以与动态HTML结合使用。这意味着开发者可以利用现代网页技术,如JavaScript和HTML5,来构建更加丰富的用户界面。 #### 六、框架设计 **Pushlet**的设计包括服务器端和...

Global site tag (gtag.js) - Google Analytics