commit
58028b9b41
11 changed files with 304 additions and 0 deletions
@ -0,0 +1,117 @@ |
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?> |
||||||
|
<project basedir="." default="jar" name="plugin"> |
||||||
|
<!-- JDK路径,根据自己机器上实际位置修改--> |
||||||
|
<property name="jdk.home" value="/System/Library/Java/JavaVirtualMachines/1.6.1.jdk/Contents/Home"/> |
||||||
|
|
||||||
|
<property name="libs" value="${basedir}/lib"/> |
||||||
|
<property name="publicLibs" value=""/> |
||||||
|
<property name="destLoc" value="."/> |
||||||
|
<property name="classes" value="classes"/> |
||||||
|
<xmlproperty file="${basedir}/plugin.xml"/> |
||||||
|
<property name="current-version" value="${plugin.version}"/> |
||||||
|
|
||||||
|
<!-- 插件版本--> |
||||||
|
<property name="plugin-version" value="${current-version}"/> |
||||||
|
<!-- 插件名字--> |
||||||
|
<property name="plugin-name" value="lazy-sheet"/> |
||||||
|
<property name="plugin-jar" value="fr-plugin-${plugin-name}-${plugin-version}.jar"/> |
||||||
|
|
||||||
|
<target name="prepare"> |
||||||
|
<delete dir="${classes}"/> |
||||||
|
<delete dir="fr-plugin-${plugin-name}-${plugin-version}"/> |
||||||
|
<xmlproperty file="${basedir}/plugin.xml"/> |
||||||
|
<delete dir="${destLoc}/${plugin.name}"/> |
||||||
|
</target> |
||||||
|
<path id="compile.classpath"> |
||||||
|
<fileset dir="${libs}"> |
||||||
|
<include name="**/*.jar"/> |
||||||
|
</fileset> |
||||||
|
<fileset dir="${publicLibs}"> |
||||||
|
<include name="**/*.jar"/> |
||||||
|
</fileset> |
||||||
|
</path> |
||||||
|
<patternset id="resources4Jar"> |
||||||
|
<exclude name="**/.settings/**"/> |
||||||
|
<exclude name=".classpath"/> |
||||||
|
<exclude name=".project"/> |
||||||
|
|
||||||
|
<exclude name="**/*.java"/> |
||||||
|
<exclude name="**/*.db"/> |
||||||
|
<exclude name="**/*.g"/> |
||||||
|
<exclude name="**/package.html"/> |
||||||
|
</patternset> |
||||||
|
<target name="copy_resources"> |
||||||
|
<echo message="从${resources_from}拷贝图片,JS,CSS等资源文件"/> |
||||||
|
<delete dir="tmp"/> |
||||||
|
<copy todir="tmp"> |
||||||
|
<fileset dir="${resources_from}\src"> |
||||||
|
<patternset refid="resources4Jar"/> |
||||||
|
</fileset> |
||||||
|
</copy> |
||||||
|
<copy todir="${classes}"> |
||||||
|
<fileset dir="tmp"/> |
||||||
|
</copy> |
||||||
|
<delete dir="tmp"/> |
||||||
|
</target> |
||||||
|
<target name="compile_javas"> |
||||||
|
<echo message="编译${compile_files}下的Java文件"/> |
||||||
|
<javac destdir="${classes}" debug="false" optimize="on" source="${source_jdk_version}" |
||||||
|
target="${target_jdk_version}" |
||||||
|
fork="true" memoryMaximumSize="512m" listfiles="false" srcdir="${basedir}" |
||||||
|
executable="${compile_jdk_version}/bin/javac"> |
||||||
|
<src path="${basedir}/src"/> |
||||||
|
<exclude name="**/.svn/**"/> |
||||||
|
<compilerarg line="-encoding UTF8 "/> |
||||||
|
<classpath refid="compile.classpath"/> |
||||||
|
</javac> |
||||||
|
</target> |
||||||
|
|
||||||
|
<target name="jar_classes"> |
||||||
|
<echo message="打Jar包:${jar_name}"/> |
||||||
|
<delete file="${basedir}/${jar_name}"/> |
||||||
|
<jar jarfile="${basedir}/${jar_name}"> |
||||||
|
<fileset dir="${classes}"> |
||||||
|
</fileset> |
||||||
|
</jar> |
||||||
|
</target> |
||||||
|
|
||||||
|
<target name="super_jar" depends="prepare"> |
||||||
|
<antcall target="copy_resources"> |
||||||
|
<param name="resources_from" value="${basedir}"/> |
||||||
|
</antcall> |
||||||
|
<antcall target="compile_javas"> |
||||||
|
<param name="source_jdk_version" value="1.6"/> |
||||||
|
<param name="target_jdk_version" value="1.6"/> |
||||||
|
<param name="compile_jdk_version" value="${jdk.home}"/> |
||||||
|
<param name="compile_files" value="${basedir}/src"/> |
||||||
|
</antcall> |
||||||
|
<echo message="compile plugin success!"/> |
||||||
|
|
||||||
|
<antcall target="jar_classes"> |
||||||
|
<param name="jar_name" value="${plugin-jar}"/> |
||||||
|
</antcall> |
||||||
|
<delete dir="${classes}"/> |
||||||
|
|
||||||
|
</target> |
||||||
|
<target name="jar" depends="super_jar"> |
||||||
|
<antcall target="zip"/> |
||||||
|
</target> |
||||||
|
|
||||||
|
<target name="zip"> |
||||||
|
<property name="plugin-folder" value="fr-plugin-${plugin-name}-${plugin-version}"/> |
||||||
|
<echo message="----------zip files----------"/> |
||||||
|
<mkdir dir="${plugin-folder}"/> |
||||||
|
<copy todir="${plugin-folder}"> |
||||||
|
<fileset dir="."> |
||||||
|
<include name="${plugin-jar}"/> |
||||||
|
<include name="plugin.xml"/> |
||||||
|
</fileset> |
||||||
|
</copy> |
||||||
|
<zip destfile="${basedir}/${plugin-folder}.zip" basedir="."> |
||||||
|
<include name="${plugin-folder}/*.jar"/> |
||||||
|
<include name="${plugin-folder}/plugin.xml"/> |
||||||
|
</zip> |
||||||
|
<xmlproperty file="${basedir}/plugin.xml"/> |
||||||
|
<move file="${plugin-folder}.zip" todir="${destLoc}/${plugin.name}"/> |
||||||
|
</target> |
||||||
|
</project> |
@ -0,0 +1,26 @@ |
|||||||
|
<?xml version="1.0" encoding="UTF-8"?> |
||||||
|
<module type="JAVA_MODULE" version="4"> |
||||||
|
<component name="NewModuleRootManager" LANGUAGE_LEVEL="JDK_1_6" inherit-compiler-output="false"> |
||||||
|
<output url="file://$MODULE_DIR$/../../../env/8.0/WebReport/WEB-INF/classes" /> |
||||||
|
<content url="file://$MODULE_DIR$"> |
||||||
|
<sourceFolder url="file://$MODULE_DIR$/src" isTestSource="false" /> |
||||||
|
</content> |
||||||
|
<orderEntry type="inheritedJdk" /> |
||||||
|
<orderEntry type="sourceFolder" forTests="false" /> |
||||||
|
<orderEntry type="library" name="lib" level="project" /> |
||||||
|
<orderEntry type="module" module-name="base" /> |
||||||
|
<orderEntry type="module" module-name="base-basic" /> |
||||||
|
<orderEntry type="module" module-name="base-calculate" /> |
||||||
|
<orderEntry type="module" module-name="base-data" /> |
||||||
|
<orderEntry type="module" module-name="base-file" /> |
||||||
|
<orderEntry type="module" module-name="base-performance" /> |
||||||
|
<orderEntry type="module" module-name="base-stable" /> |
||||||
|
<orderEntry type="module" module-name="chart-base" /> |
||||||
|
<orderEntry type="module" module-name="engine" /> |
||||||
|
<orderEntry type="module" module-name="engine-page" /> |
||||||
|
<orderEntry type="module" module-name="engine-view" /> |
||||||
|
<orderEntry type="module" module-name="engine-write" /> |
||||||
|
<orderEntry type="module" module-name="designer" /> |
||||||
|
<orderEntry type="module" module-name="designer_base" /> |
||||||
|
</component> |
||||||
|
</module> |
@ -0,0 +1,20 @@ |
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?> |
||||||
|
<plugin> |
||||||
|
<id>com.fr.plugin.report.lazysheet</id> |
||||||
|
<name><![CDATA[多sheet懒加载]]></name> |
||||||
|
<active>yes</active> |
||||||
|
<version>2.0</version> |
||||||
|
<env-version>8.0</env-version> |
||||||
|
<jartime>2015-08-09</jartime> |
||||||
|
<vendor>路人乙</vendor> |
||||||
|
<description><![CDATA[多sheet报表仅仅只加载当前sheet(不支持sheet间运算)]]></description> |
||||||
|
<change-notes><![CDATA[无]]></change-notes> |
||||||
|
<extra-core> |
||||||
|
</extra-core> |
||||||
|
<extra-report> |
||||||
|
<ActorProvider class="com.fr.plugin.lazy.sheet.LazySheetActorMark"/> |
||||||
|
</extra-report> |
||||||
|
<extra-designer> |
||||||
|
<PreviewProvider class="com.fr.plugin.lazy.sheet.LazySheetPreview"/> |
||||||
|
</extra-designer> |
||||||
|
</plugin> |
@ -0,0 +1,12 @@ |
|||||||
|
# 多sheet懒加载插件 |
||||||
|
**特性:**第一次只会计算第一个sheet,后台计算也是如此,后续点击一个sheet再去计算一个sheet,解决sheet过多时计算比较慢的问题,缺点是无法处理sheet间运算。如下图所示,点击“懒加载多sheet”即可看到效果: |
||||||
|
 |
||||||
|
|
||||||
|
|
||||||
|
下面来看一下测试结果,现有一张多sheet报表,分别有两个数据集ds1和ds2,ds1用在sheet1中,ds2用在sheet2中,分别看一下一般的```op=view```预览方式和加了插件后的```op=view&__lazy__==true```的预览结果: |
||||||
|
|
||||||
|
* 普通的```op=view```方式,可以看到ds1和ds2同时都参与了运算 |
||||||
|
 |
||||||
|
|
||||||
|
* 加了插件后的懒加载sheet方式```op=view&__lazy__==true```,可以看到预览sheet1的时候,只有ds1参与了运算 |
||||||
|
 |
After Width: | Height: | Size: 109 KiB |
After Width: | Height: | Size: 32 KiB |
After Width: | Height: | Size: 188 KiB |
@ -0,0 +1,22 @@ |
|||||||
|
package com.fr.plugin.lazy.sheet; |
||||||
|
|
||||||
|
import com.fr.main.impl.WorkBook; |
||||||
|
import com.fr.main.workbook.ResultWorkBook; |
||||||
|
import com.fr.stable.ViewActor; |
||||||
|
|
||||||
|
import java.util.Map; |
||||||
|
|
||||||
|
/** |
||||||
|
* Created by richie on 15/7/17. |
||||||
|
*/ |
||||||
|
public class LazySheetActor extends ViewActor { |
||||||
|
|
||||||
|
@Override |
||||||
|
public ResultWorkBook executeWorkBook(WorkBook workBook, Map parameterMap, int sheetIndex) { |
||||||
|
if (parameterMap.containsKey("__lazy__")) { |
||||||
|
return new LazySheetWorkBookExecutor(workBook, parameterMap, sheetIndex).execute(); |
||||||
|
} else { |
||||||
|
return super.executeWorkBook(workBook, parameterMap, sheetIndex); |
||||||
|
} |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,22 @@ |
|||||||
|
package com.fr.plugin.lazy.sheet; |
||||||
|
|
||||||
|
import com.fr.report.fun.impl.AbstractActorProvider; |
||||||
|
import com.fr.report.stable.fun.Actor; |
||||||
|
|
||||||
|
/** |
||||||
|
* Created by richie on 15/7/17. |
||||||
|
*/ |
||||||
|
public class LazySheetActorMark extends AbstractActorProvider { |
||||||
|
|
||||||
|
@Override |
||||||
|
public int currentAPILevel() { |
||||||
|
return CURRENT_LEVEL; |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public Actor[] createActor() { |
||||||
|
return new Actor[]{ |
||||||
|
new LazySheetActor() |
||||||
|
}; |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,34 @@ |
|||||||
|
package com.fr.plugin.lazy.sheet; |
||||||
|
|
||||||
|
import com.fr.design.preview.ViewPreview; |
||||||
|
|
||||||
|
import java.util.HashMap; |
||||||
|
import java.util.Map; |
||||||
|
|
||||||
|
/** |
||||||
|
* Created by richie on 15/7/17. |
||||||
|
*/ |
||||||
|
public class LazySheetPreview extends ViewPreview { |
||||||
|
|
||||||
|
@Override |
||||||
|
public int currentAPILevel() { |
||||||
|
return CURRENT_LEVEL; |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public String nameForPopupItem() { |
||||||
|
return "懒加载多sheet"; |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public int previewTypeCode() { |
||||||
|
return 18; |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public Map<String, Object> parametersForPreview() { |
||||||
|
Map<String, Object> map = super.parametersForPreview(); |
||||||
|
map.put("__lazy__", true); |
||||||
|
return map; |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,51 @@ |
|||||||
|
package com.fr.plugin.lazy.sheet; |
||||||
|
|
||||||
|
import com.fr.main.impl.WorkBook; |
||||||
|
import com.fr.main.workbook.AnalyRWorkBook; |
||||||
|
import com.fr.main.workbook.ResultWorkBook; |
||||||
|
import com.fr.report.report.ResultReport; |
||||||
|
import com.fr.report.report.TemplateReport; |
||||||
|
import com.fr.report.stable.fun.Actor; |
||||||
|
import com.fr.view.cal.sheet.AnalyWorkBookExecutor; |
||||||
|
|
||||||
|
import java.util.Map; |
||||||
|
|
||||||
|
/** |
||||||
|
* Created by richie on 15/7/17. |
||||||
|
*/ |
||||||
|
public class LazySheetWorkBookExecutor extends AnalyWorkBookExecutor { |
||||||
|
private int sheetIndex; |
||||||
|
|
||||||
|
public LazySheetWorkBookExecutor(WorkBook workBook, Map<String, Object> parameterMap, int sheetIndex) { |
||||||
|
super(workBook, parameterMap); |
||||||
|
this.sheetIndex = sheetIndex; |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public ResultWorkBook initResultBook(Map<String, Object> parameterMap) { |
||||||
|
return new AnalyRWorkBook(parameterMap); |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public Actor getExeType() { |
||||||
|
return new LazySheetActor(); |
||||||
|
} |
||||||
|
|
||||||
|
protected void _execute(){ |
||||||
|
// 先按顺序来,其实这里就一个个塞进去,然后在这里面开始统一分步计算
|
||||||
|
TemplateReport report; |
||||||
|
for (int i = 0, len = this.nameListMap.size(); i < len; i++) { |
||||||
|
|
||||||
|
report = (TemplateReport) this.nameListMap.getByIndex(i); |
||||||
|
Actor actor = getExeType(); |
||||||
|
if (i == sheetIndex) { |
||||||
|
ResultReport resultReport = report.execute(parameterMap, actor); |
||||||
|
if (null != resultReport) { |
||||||
|
this.listForResultReport.set(i, resultReport); |
||||||
|
} |
||||||
|
} else { |
||||||
|
this.listForResultReport.set(i, ResultReport.EMPTY); |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
Loading…
Reference in new issue