amchart在struts2中应用

本文详细介绍了如何在Struts2框架中集成Amchart工具,用于展示软件的日、月、年下载量报表。包括Amchart的下载、Struts2配置、Action编写、使用Amchart实现报表显示等步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近做了一个SSH项目,其中有一个统计模块,查看选中的软件的下载量,通过amchart报表工具显示出软件日下载量,月下载量以及年下载量,下面简单介绍,amchart在struts2中的应用。(关于amchart的介绍,这里不累述,网上很多文章都有说明)

 
一、下载amchart
        http://www.amcharts.com/download
        选择你想使用的报表显示形状进行下载,较常用的主要是曲线图和饼图,这里以曲线图为例:Line & Area

二、配置struts2

        新建一个Web Project,比如:amchartDemo

        1. JAR包引用

        这里使用的是struts2的最新JAR包:struts-2.2.1.1:

        该版本的struts2需要用到的JAR包有7个,一个都不能少

        可在下面工程中获取:struts-2.2.1.1\apps\struts2-blank\WEB-INF\lib

        commons-fileupload-1.2.1.jar

        commons-io-1.3.2.jar

        freemarker-2.3.16.jar

        javassist-3.7.ga.jar

        ognl-3.0.jar

        struts2-core-2.2.1.1.jar

        xwork-core-2.2.1.1.jar

 
        2. 配置web.xml (WebRoot\WEB-INF\web.xml)
<filter>
 <filter-name>struts2</filter-name>
 <filter-class>
  org.apache.struts2.dispatcher.FilterDispatcher
 </filter-class>
</filter>
<filter-mapping>
 <filter-name>struts2</filter-name>
 <url-pattern>/*</url-pattern>
</filter-mapping>

        3. 配置struts.xml
            可从 struts-2.2.1.1\apps\struts2-blank\WEB-INF\src\java\ 获取struts.xml,复制到你自己的项目工程(amchartDemo)的src下
<struts>
 <package name="statistic" extends="struts-default">
  <action name="report" class="com.web.action.ReportAction">
   <result name="show-suc">/index.jsp</result>
  </action>
 </package>
</struts>

        4. 编写Action
            根据以上struts.xml的配置,创建ReportAction类,以及需要的Bean:
package com.web.action;

import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.TreeMap;

import com.model.beans.BaseBean;
import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionSupport;

public class ReportAction extends ActionSupport {

 public String showDay() throws Exception {
  List<BaseBean> daylist = new ArrayList<BaseBean>();
  /*================数据模拟==================*/
  daylist.add(createBean(1L,"软件A","#FF0000"));
  daylist.add(createBean(2L,"软件B","#FFC0CB"));
  daylist.add(createBean(3L,"软件C","#40E0D0"));
  daylist.add(createBean(4L,"软件D","#9ACD32"));
  daylist.add(createBean(5L,"软件E","#00FF7F"));
  /*=========================================*/
  ActionContext.getContext().getSession().put("chartDataList", daylist);
  return "show-suc";
 }

 /**
  * 创建模拟数据
  * @author Christy Lan
  * @version 1.0
  * @param
  * @return BaseBean
  * @exception
  */
 private BaseBean createBean(Long id, String softName, String color){
  BaseBean bean = new BaseBean();
  bean.setSoftId(id);
  bean.setSoftName(softName);
  bean.setColor(color);
  Map<Integer, Integer> dataMap = new TreeMap<Integer, Integer>();
  //一天24小时
  for(int i = 1; i <= 24; i++){
   dataMap.put(i, getRandom());//模拟每小时的下载量
  }
  bean.setDataMap(dataMap);
  return bean;
  
 }
 
 private Integer getRandom(){
  return (int)(Math.random()*1000);
 }
}
        该bean与数据库的表结构无关,而是对数据库中的数据进行了进一步的统计处理(使用oracle的统计函数),封装成这个BaseBean。主要就是对dataMap<时刻, 下载量>的封装
package com.model.beans;

import java.util.Map;

public class BaseBean {
 
 private Long softId;//软件ID
 private String softName;//软件名字
 private String color;//该软件在amchart报表中显示的颜色
 private Map<Integer, Integer> dataMap;//存放统计信息
 
 public Long getSoftId() {
  return softId;
 }
 public void setSoftId(Long softId) {
  this.softId = softId;
 }
 public String getSoftName() {
  return softName;
 }
 public void setSoftName(String softName) {
  this.softName = softName;
 }
 public String getColor() {
  return color;
 }
 public void setColor(String color) {
  this.color = color;
 }
 public Map<Integer, Integer> getDataMap() {
  return dataMap;
 }
 public void setDataMap(Map<Integer, Integer> dataMap) {
  this.dataMap = dataMap;
 }
}
  
三、使用amchart

       1. 在WebRoot下新建一个目录 WebRoot/statistic/line

       2. 解压amline_1.6.4.1.zip

           a) 将 amline_1.6.4.1\amline 目录下的swfobject.js复制到statistic目录下(注:swfobject.js放于哪无所谓,关键是页面上的引用)

           b) 将 amline_1.6.4.1\amline 目录下的amline.swf 复制到statistic/line目录下

           c) 将 amline_1.6.4.1\amline 目录下的amline_settings.xml 复制到statistic/line目录下,同时,把amline_settings.xml改名为day_settings.jsp

 

        3. 修改day_settings.jsp
           a) 在day_settings.jsp的最开始处增加如下代码:
 <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
 <%@ taglib prefix="s" uri="/struts-tags" %>         

            b) 将<digits_after_decimal>2</digits_after_decimal> 改为
                  <digits_after_decimal>0</digits_after_decimal>
                  这里的数值表示小数点后的位数

           c) 将<graphs></graphs>标签里的内容删除,替换成:
  <graphs>                                                   
    <s:iterator value="#session.chartDataList" status="st">
    <graph gid="<s:property value="#st.index"/>">
     <title><s:property value="softName"/></title>
     <line_width>2</line_width>
       <color><s:property value="color"/></color>
       <color_hover><s:property value="color"/></color_hover>
       <bullet>round_outlined</bullet>
       <balloon_text_color>000000</balloon_text_color>  
       <balloon_text>
         <![CDATA[{title} on {series}: 【{value}次】]]>
       </balloon_text>
       <selected>true</selected>
    </graph>
    </s:iterator>
  </graphs>        
        4. 在statistic/line目录下新建day_data.jsp
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%@ taglib prefix="s" uri="/struts-tags" %>
<?xml version="1.0" encoding="UTF-8"?>  
<chart>
 <series>
  <s:iterator value="#session.chartDataList" status="st">
  <s:if test="#st.index==0">
   <s:iterator value="dataMap">
    <value xid="<s:property value="key"/>"><s:property value="key"/>时</value>
   </s:iterator>
  </s:if>
  </s:iterator>
 </series>
 <graphs>
  <s:iterator value="#session.chartDataList" status="st">
  <graph gid="<s:property value="#st.index"/>">
   <s:iterator value="dataMap">
    <value xid="<s:property value="key"/>"><s:property value="value"/></value>
   </s:iterator>
  </graph>
  </s:iterator>
 </graphs>
</chart>       

       5. 补充:破解amchart
             在statistic/line目录下新建amcharts_key.txt,内容为
             AMCHART-LNKS-1966-6679-1965-1082

        6. WebRoot/index.jsp
            1) 引入JS
  <body>
    <div id="flashcontent">
  <strong>You need to upgrade your Flash Player</strong>
 </div>

 <script type="text/javascript">
  // <![CDATA[  
  var so = new SWFObject("statistic/line/amline.swf", "amline", "900", "600", "8", "#FFFFFF");
  so.addVariable("path", "statistic/line/");
  so.addVariable("settings_file", encodeURIComponent("statistic/line/day_settings.jsp?<%=Math.random()%>"));
  so.addVariable("data_file", encodeURIComponent("statistic/line/day_data.jsp"));
  so.write("flashcontent");
  // ]]>
 </script>
  </body>
四、完成
       访问 h ttp://localhost:端口号/amchartDemo/report!showDay.action  即可看到效果

基于数据挖掘的音乐推荐系统设计与实现 需要一个代码说明,不需要论文 采用python语言,django框架,mysql数据库开发 编程环境:pycharm,mysql8.0 系统分为前台+后台模式开发 网站前台: 用户注册, 登录 搜索音乐,音乐欣赏(可以在线进行播放) 用户登陆时选择相关感兴趣的音乐风格 音乐收藏 音乐推荐算法:(重点) 本课题需要大量用户行为(如播放记录、收藏列表)、音乐特征(如音频特征、歌曲元数据)等数据 (1)根据用户之间相似性或关联性,给一个用户推荐与其相似或有关联的其他用户所感兴趣的音乐; (2)根据音乐之间的相似性或关联性,给一个用户推荐与其感兴趣的音乐相似或有关联的其他音乐。 基于用户的推荐和基于物品的推荐 其中基于用户的推荐是基于用户的相似度找出相似相似用户,然后向目标用户推荐其相似用户喜欢的东西(和你类似的人也喜欢**东西); 而基于物品的推荐是基于物品的相似度找出相似的物品做推荐(喜欢该音乐的人还喜欢了**音乐); 管理员 管理员信息管理 注册用户管理,审核 音乐爬虫(爬虫方式爬取网站音乐数据) 音乐信息管理(上传歌曲MP3,以便前台播放) 音乐收藏管理 用户 用户资料修改 我的音乐收藏 完整前后端源码,部署后可正常运行! 环境说明 开发语言:python后端 python版本:3.7 数据库:mysql 5.7+ 数据库工具:Navicat11+ 开发软件:pycharm
MPU6050是一款广泛应用在无人机、机器人和运动设备中的六轴姿态传感器,它集成了三轴陀螺仪和三轴加速度计。这款传感器能够实时监测并提供设备的角速度和线性加速度数据,对于理解物体的动态运动状态至关重要。在Arduino平台上,通过特定的库文件可以方便地与MPU6050进行通信,获取并解析传感器数据。 `MPU6050.cpp`和`MPU6050.h`是Arduino库的关键组成部分。`MPU6050.h`是头文件,包含了定义传感器接口和函数声明。它定义了类`MPU6050`,该类包含了初始化传感器、读取数据等方法。例如,`begin()`函数用于设置传感器的工作模式和I2C地址,`getAcceleration()`和`getGyroscope()`则分别用于获取加速度和角速度数据。 在Arduino项目中,首先需要包含`MPU6050.h`头文件,然后创建`MPU6050`对象,并调用`begin()`函数初始化传感器。之后,可以通过循环调用`getAcceleration()`和`getGyroscope()`来不断更新传感器读数。为了处理这些原始数据,通常还需要进行校准和滤波,以消除噪声和漂移。 I2C通信协议是MPU6050与Arduino交互的基础,它是一种低引脚数的串行通信协议,允许多个设备共享一对数据线。Arduino板上的Wire库提供了I2C通信的底层支持,使得用户无需深入了解通信细节,就能方便地与MPU6050交互。 MPU6050传感器的数据包括加速度(X、Y、Z轴)和角速度(同样为X、Y、Z轴)。加速度数据可以用来计算物体的静态位置和动态运动,而角速度数据则能反映物体转动的速度。结合这两个数据,可以进一步计算出物体的姿态(如角度和角速度变化)。 在嵌入式开发领域,特别是使用STM32微控制器时,也可以找到类似的库来驱动MPU6050。STM32通常具有更强大的处理能力和更多的GPIO口,可以实现更复杂的控制算法。然而,基本的传感器操作流程和数据处理原理与Arduino平台相似。 在实际应用中,除了基本的传感器读取,还可能涉及到温度补偿、低功耗模式设置、DMP(数字运动处理器)功能的利用等高级特性。DMP可以帮助处理传感器数据,实现更高级的运动估计,减轻主控制器的计算负担。 MPU6050是一个强大的六轴传感器,广泛应用于各种需要实时运动追踪的项目中。通过 Arduino 或 STM32 的库文件,开发者可以轻松地与传感器交互,获取并处理数据,实现各种创新应用。博客和其他开源资源是学习和解决问题的重要途径,通过这些资源,开发者可以获得关于MPU6050的详细信息和实践指南
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值