- 浏览: 233932 次
- 性别:
- 来自: 广东
文章分类
最新评论
-
wangmuchang:
解压需要密码
CAS单点登录之测试应用 -
ayang722:
首先就要在运行报表birt的IEngineTask中加入, J ...
birt配置动态数据源 -
lihong11:
very good!
js常用方法 -
qtlkw:
你共享出来为什么要密码?要密码为何要共享出来?汗
CAS单点登录之测试应用 -
lishouxinghome:
请问如何获得用户的Id呢,往指点
使用 CAS 在 Tomcat 中实现单点登录
这个例子演示了从建立DataSource ,然后建立DataSet , 动态的根据输入数据输出report template .
关于Birt 的 API , 在 eclipse 的 help content 里面有,3.3 支持新的基于topic 的search ,可以帮我们简化搜索的topic , 其中有五个API (一共是5个) : Report Object Model API , Report Engine API , Birt Report Scripting API , Open Data Access API , Data Engine API .另外也提供详细的讲解每一个report 的元素的意思.非常好的一份资料 .
DECreateDynamicTable.java 例子code :
这个例子一共有四个函数 :
1 . Main 函数: 这个例子简单之处在与它可以直接的运行,只要你修改了
config.setProperty("BIRT_HOME", "C:/birt-runtime-2_1_1/birt-runtime-2_1_1/ReportEngine"); 指向你自己的Birt Runtime 解压后的ReportEngine 目录.
designHandle = session.openDesign("c:/tmp/testdeapi.rptdesign"); 你可以从Birt 里面建立一个新的Report template.然后指向这个report 就可以了
designHandle.saveAs( "c:/temp/sample.rptdesign" ); //$NON-NLS-1$ 指定一个你想保存的位置,c:/temp 目录存在你才能够保存到c:/temp 目录下.
2 . buildDataSource 函数把一个ReportDesignHandle 的 Data Source 初始化, setProperties 左边的String 是不能变的,Data Source 的名字可以随便取,取DataSet 的时候要根据这个名字来取.
3 . buildDataSet 通过拼sql 的方式 ,来build DataSet, 注意sql 别拼错了.
4 . buildReport 注意element 的初始化顺序.在所有的DataItem 外面都是一层Cell,Cell 外面才是row .这个例子使用的row 来拼成table 的,也可以用column 来拼,相对应的数据处理也是一个column 一个 column 的处理的了.
关于Birt 的 API , 在 eclipse 的 help content 里面有,3.3 支持新的基于topic 的search ,可以帮我们简化搜索的topic , 其中有五个API (一共是5个) : Report Object Model API , Report Engine API , Birt Report Scripting API , Open Data Access API , Data Engine API .另外也提供详细的讲解每一个report 的元素的意思.非常好的一份资料 .
DECreateDynamicTable.java 例子code :
import java.io.IOException; import java.util.ArrayList; import org.eclipse.birt.core.framework.Platform; import org.eclipse.birt.report.model.api.CellHandle; import org.eclipse.birt.report.model.api.DataItemHandle; import org.eclipse.birt.report.model.api.DesignConfig; import org.eclipse.birt.report.model.api.ElementFactory; import org.eclipse.birt.report.model.api.IDesignEngine; import org.eclipse.birt.report.model.api.IDesignEngineFactory; import org.eclipse.birt.report.model.api.LabelHandle; import org.eclipse.birt.report.model.api.OdaDataSetHandle; import org.eclipse.birt.report.model.api.OdaDataSourceHandle; import org.eclipse.birt.report.model.api.PropertyHandle; import org.eclipse.birt.report.model.api.ReportDesignHandle; import org.eclipse.birt.report.model.api.RowHandle; import org.eclipse.birt.report.model.api.SessionHandle; import org.eclipse.birt.report.model.api.StructureFactory; import org.eclipse.birt.report.model.api.TableHandle; import org.eclipse.birt.report.model.api.activity.SemanticException; import org.eclipse.birt.report.model.api.elements.structures.ComputedColumn; import com.ibm.icu.util.ULocale; /** * Dynamic Table BIRT Design Engine API (DEAPI) demo. */ public class DECreateDynamicTable { ReportDesignHandle designHandle = null; ElementFactory designFactory = null; StructureFactory structFactory = null; public static void main( String[] args ) { try { DECreateDynamicTable de = new DECreateDynamicTable(); ArrayList al = new ArrayList(); al.add("OFFICECODE"); al.add("CITY"); al.add("COUNTRY"); de.buildReport(al, "From Offices" ); } catch ( IOException e ) { // TODO Auto-generated catch block e.printStackTrace(); } catch ( SemanticException e ) { // TODO Auto-generated catch block e.printStackTrace(); } } void buildDataSource( ) throws SemanticException { OdaDataSourceHandle dsHandle = designFactory.newOdaDataSource( "Data Source", "org.eclipse.birt.report.data.oda.jdbc" ); dsHandle.setProperty( "odaDriverClass", "org.eclipse.birt.report.data.oda.sampledb.Driver" ); dsHandle.setProperty( "odaURL", "jdbc:classicmodels:sampledb" ); dsHandle.setProperty( "odaUser", "ClassicModels" ); dsHandle.setProperty( "odaPassword", "" ); designHandle.getDataSources( ).add( dsHandle ); } void buildDataSet(ArrayList cols, String fromClause ) throws SemanticException { OdaDataSetHandle dsHandle = designFactory.newOdaDataSet( "ds", "org.eclipse.birt.report.data.oda.jdbc.JdbcSelectDataSet" ); dsHandle.setDataSource( "Data Source" ); String qry = "Select "; for( int i=0; i < cols.size(); i++){ qry += " " + cols.get(i); if( i != (cols.size() -1) ){ qry += ","; } } qry += " " + fromClause; dsHandle.setQueryText( qry ); designHandle.getDataSets( ).add( dsHandle ); } void buildReport(ArrayList cols, String fromClause ) throws IOException, SemanticException { //Configure the Engine and start the Platform DesignConfig config = new DesignConfig( ); config.setProperty("BIRT_HOME", "C:/birt-runtime-2_1_1/birt-runtime-2_1_1/ReportEngine"); IDesignEngine engine = null; try{ Platform.startup( config ); IDesignEngineFactory factory = (IDesignEngineFactory) Platform .createFactoryObject( IDesignEngineFactory.EXTENSION_DESIGN_ENGINE_FACTORY ); engine = factory.createDesignEngine( config ); }catch( Exception ex){ ex.printStackTrace(); } SessionHandle session = engine.newSessionHandle( ULocale.ENGLISH ) ; try{ //open a design or a template designHandle = session.openDesign("c:/tmp/testdeapi.rptdesign"); designFactory = designHandle.getElementFactory( ); buildDataSource(); buildDataSet(cols, fromClause); TableHandle table = designFactory.newTableItem( "table", cols.size() ); table.setWidth( "100%" ); table.setDataSet( designHandle.findDataSet( "ds" ) ); PropertyHandle computedSet = table.getColumnBindings( ); ComputedColumn cs1 = null; for( int i=0; i < cols.size(); i++){ cs1 = StructureFactory.createComputedColumn(); cs1.setName((String)cols.get(i)); cs1.setExpression("dataSetRow[\"" + (String)cols.get(i) + "\"]"); computedSet.addItem(cs1); } // table header RowHandle tableheader = (RowHandle) table.getHeader( ).get( 0 ); for( int i=0; i < cols.size(); i++){ LabelHandle label1 = designFactory.newLabel( (String)cols.get(i) ); label1.setText((String)cols.get(i)); CellHandle cell = (CellHandle) tableheader.getCells( ).get( i ); cell.getContent( ).add( label1 ); } // table detail RowHandle tabledetail = (RowHandle) table.getDetail( ).get( 0 ); for( int i=0; i < cols.size(); i++){ CellHandle cell = (CellHandle) tabledetail.getCells( ).get( i ); DataItemHandle data = designFactory.newDataItem( "data_"+(String)cols.get(i) ); data.setResultSetColumn( (String)cols.get(i)); cell.getContent( ).add( data ); } designHandle.getBody( ).add( table ); // Save the design and close it. designHandle.saveAs( "c:/temp/sample.rptdesign" ); //$NON-NLS-1$ designHandle.close( ); System.out.println("Finished"); }catch (Exception e){ e.printStackTrace(); } } }
这个例子一共有四个函数 :
1 . Main 函数: 这个例子简单之处在与它可以直接的运行,只要你修改了
config.setProperty("BIRT_HOME", "C:/birt-runtime-2_1_1/birt-runtime-2_1_1/ReportEngine"); 指向你自己的Birt Runtime 解压后的ReportEngine 目录.
designHandle = session.openDesign("c:/tmp/testdeapi.rptdesign"); 你可以从Birt 里面建立一个新的Report template.然后指向这个report 就可以了
designHandle.saveAs( "c:/temp/sample.rptdesign" ); //$NON-NLS-1$ 指定一个你想保存的位置,c:/temp 目录存在你才能够保存到c:/temp 目录下.
2 . buildDataSource 函数把一个ReportDesignHandle 的 Data Source 初始化, setProperties 左边的String 是不能变的,Data Source 的名字可以随便取,取DataSet 的时候要根据这个名字来取.
3 . buildDataSet 通过拼sql 的方式 ,来build DataSet, 注意sql 别拼错了.
4 . buildReport 注意element 的初始化顺序.在所有的DataItem 外面都是一层Cell,Cell 外面才是row .这个例子使用的row 来拼成table 的,也可以用column 来拼,相对应的数据处理也是一个column 一个 column 的处理的了.
发表评论
-
ssh框架加入atomikos分布式事务管理
2015-01-06 18:48 1478一、概念 分布式事务分布式事务是指事务 ... -
Spring 动态切换数据源
2014-05-09 14:30 3646一、开篇 这里整合分别采用了Hibernate和MyB ... -
Spring切入点表达式常用写法
2014-05-09 14:25 824自从使用AspectJ风格切面配置,使得Spring的切面配 ... -
Spring中线程池的应用
2014-03-24 11:03 903多线程并发处理起来通常比较麻烦,如果你使用spring容器来 ... -
Spring线程池开发实战
2014-03-24 11:02 760本文提供了三个Spring多线程开发的例子,由浅入深,由于例 ... -
JSch - Java实现的SFTP(文件上传详解篇)
2013-11-21 09:36 906JSch是Java Secure Channel的缩写。J ... -
JAVA线程池ThreadPoolExecutor
2013-07-17 14:45 902java.util.concurrent.ThreadPoo ... -
log4j.properties 使用说明
2013-05-29 10:54 813一、Log4j简介Log4j有三个主要的组件:Logger ... -
eclipse安装反编译插件(附jad下载)
2012-12-12 10:45 831一、eclipse反编译插件Jadclipse jadclip ... -
web.xml 配置404和500错误的自定义页面
2012-12-07 11:47 820web.xml <error-page>< ... -
java内存溢出
2012-06-28 18:57 877一、常见的Java内存溢出 ... -
List Set Map区别
2012-12-25 17:54 921List有序key和value都能重 ... -
Java 自定义Annotation(元数据、注解)
2011-08-05 11:50 1927Annotation在java的世界正铺天盖地展开,有空写这一 ... -
LOG4J properties 配置文件
2011-06-29 16:31 1177一、参数意义说明1、输出级别的种类 ERROR、 ... -
servlet输出一个文件
2010-11-10 18:33 1171String fileName= file.getName() ... -
关于RSS、RDF、ATOM和Feed
2010-11-02 09:48 1231RSS被不同的技术团体做不同的解释,分别有 Rich Site ... -
正确理解Traceback的含义
2010-11-02 09:44 1019Traceback是Blog的一个重要 ... -
关于Serializable的serialVersionUID
2010-10-26 09:10 1764众所周知,当某class实现了Serializable接口 ... -
获得CLASSPATH之外路径的方法
2010-10-14 10:37 965URL base = this.getClass().getR ... -
操作properties文件
2010-10-14 10:30 810发个例子大家自己看哈.package control; im ...
相关推荐
1. `env.py`:游戏环境的实现,可能包含与Flappy Bird游戏API的接口。 2. `model.py`:DQN网络模型的定义,可能使用TensorFlow或PyTorch等深度学习框架。 3. `agent.py`:智能体的实现,包括经验回放缓冲区、策略...
本项目基于DQN算法对经典游戏Flappy Bird进行了训练,使得AI能够自主学习游戏策略,实现较高的得分。 Flappy Bird是一款挑战玩家反应速度和空间判断的游戏,其目标是控制小鸟避开柱子,尽可能地飞行更远。在DQN的...
在本项目中,“flappybird强化学习”是一个利用深度学习技术,特别是强化学习算法来实现自动玩游戏Flappy Bird的示例。Flappy Bird是一款非常流行的手机游戏,玩家需要控制一只小鸟避开柱子以获得高分。这个项目的...
PyTorch是Facebook开源的一个强大的深度学习库,以其动态计算图和易于使用的API而备受青睐。在实现DQN时,PyTorch可以轻松构建和训练神经网络模型,同时提供便捷的工具进行数据处理和模型优化。 在这个项目中,我们...
学习并熟练掌握Bluebird,能极大地提升JavaScript异步编程的效率和质量。在实际项目中,可以根据需求选择适合的方法,实现高效、可靠的异步控制。在阅读`bluebird-api-master`这个压缩包中的内容,我们可以期待找到...
在本文中,我们将深入探讨如何使用神经网络和遗传算法来实现对经典游戏Flappy Bird的机器学习。Flappy Bird是一款非常流行的休闲游戏,其简单但极具挑战性的玩法使其成为研究机器学习技术的理想平台。 首先,我们...
《使用Keras与Python实现强化学习:Flappy Bird游戏》 在当今的AI领域,强化学习(Reinforcement Learning,RL)已经成为了重要的研究方向,它通过与环境的交互学习最优策略,尤其在游戏控制方面表现出色。本项目...
微信小程序源码 富文本解析,折线图,MD5,bluebird(学习版)微信小程序源码 富文本解析,折线图,MD5,bluebird(学习版)微信小程序源码 富文本解析,折线图,MD5,bluebird(学习版)微信小程序源码 富文本解析,折线图,...
综上所述,"OpenCv制作的FlappyBird"项目展示了OpenCV在游戏开发中的创新应用,结合了图像处理、物体检测、机器学习等多个方面的知识,是学习和实践OpenCV技术的一个有趣案例。通过深入研究项目源码、观看成果视频并...
在FlappyBird的cocos2dx版本中,游戏场景、角色动画、碰撞检测等功能都通过cocos2dx的API实现。 2. 游戏对象:游戏中的Bird对象和管道(Pipes)对象是核心。Bird的移动和跳跃通过物理引擎模拟,而Pipes则动态生成,...
在这里,我们拥有的是自己制作的Flappy Bird游戏的完整源码以及相关的素材,这为我们提供了一个学习和理解游戏开发的绝佳机会。 首先,我们来看看"Swing"这个标签。Swing是Java的一种图形用户界面(GUI)工具包,...
《flappy bird》是一款由来自越南的独立游戏开发者Dong Nguyen所开发的作品,游戏于2013年5月24日上线,并在2014年2月突然暴红。2014年2月,《Flappy Bird》被开发者...--------素材包括相关图片以及音效仅供学习参考
《Flappy Bird游戏素材解析与应用》 Flappy Bird是一款风靡全球的休闲游戏,以其简单易上手的操作和极具挑战性的玩法深受玩家喜爱。...这对于想要学习游戏开发或者想要改进自己作品的开发者来说,都是宝贵的学习资源。
这不仅是学习编程的好机会,也是锻炼逻辑思维和解决问题能力的过程。如果你是一名对编程感兴趣的学生或教师,这个资源包无疑是一个极好的实践项目,它将带你走进游戏开发的世界,体验从无到有的创造乐趣。
# DQN强化学习训练Flappy Bird游戏Python代码 基于TensorFlow和Pygame ## 介绍 DQN(Deep Q-Network)是一种卷积神经网络,基于Q学习的思想进行训练,其输入是原始像素,输出是估计未来奖励的值函数。 ## 安装依赖...
《Flappy Bird 图像音频资源解析》 在游戏开发领域,资源是构成游戏世界的基础,它们赋予游戏视觉和听觉的生动性。本资源包“flappybird图像音频资源包”便是针对经典游戏《Flappy Bird》而设计的,旨在为开发者...
9. **界面设计(UI Design)**:虽然Flappy Bird的界面简洁,但设计良好的UI可以增强游戏的吸引力。源码中包含了如何使用Java的Swing或JavaFX库来构建游戏界面的方法。 10. **调试与测试(Debugging and Testing)*...
《Flappy Bird Bot 使用强化学习》 在游戏开发和人工智能领域,强化学习(Reinforcement Learning,RL)已经成为一种热门的技术。本项目聚焦于利用强化学习来训练一个Flappy Bird游戏的自动玩家,即Flappy Bird Bot...
使用DQN自动玩flappybird,最近,github上有人放出使用DQN玩Flappy Bird的代码,https://github.com/yenchenlin1994/DeepLearningFlappyBird【1】 该repo通过结合之前的repo成功实现了这个想法。这个repo对整个实现...
Thunderbird是一款由Mozilla开发的开源电子邮件客户端,它提供了丰富的功能,包括邮件管理、新闻组、聊天和RSS阅读等。在日常使用中,为了防止数据丢失或进行迁移,定期备份Thunderbird的邮件设置和数据是非常重要的...