在我的 JSF 应用程序中,我想拖放 JPEG 图片(30 张图片,大小约为 10Mo),而我正面临着一个缓慢的充电页面和图片。我正在使用下面的代码压缩这些图片:
public void reduceImageQuality(int sizeThreshold, UploadedFile file, String destImg) throws Exception {
float quality = 0.05f;
long fileSize = file.getSize();
if (fileSize <= sizeThreshold) {
System.out.println("Image file size is under threshold");
return;
}
Iterator iter = ImageIO.getImageWritersByFormatName("jpeg");
ImageWriter writer = (ImageWriter) iter.next();
ImageWriteParam iwp = writer.getDefaultWriteParam();
iwp.setCompressionMode(ImageWriteParam.MODE_EXPLICIT);
BufferedImage originalImage = ImageIO.read(file.getInputstream());
IIOImage image = new IIOImage(originalImage, null, null);
float percent = 0.01f; // 10% of 1
while (fileSize > sizeThreshold) {
if (percent >= quality) {
percent = percent * 0.1f;
}
quality -= percent;
File fileOut = new File(destImg);
if (fileOut.exists()) {
fileOut.delete();
}
try (FileImageOutputStream output = new FileImageOutputStream(fileOut)) {
writer.setOutput(output);
iwp.setCompressionQuality(quality);
writer.write(null, image, iwp);
File fileOut2 = new File(destImg);
long newFileSize = fileOut2.length();
if (newFileSize == fileSize) {
// cannot reduce more, return
break;
} else {
fileSize = newFileSize;
}
System.out.println("quality = " + quality + ", new file size = " + fileSize);
}
}
writer.dispose();
}
对于我的 XHTML 代码:
<h:form id="firstGenForm" enctype="multipart/form-data" >
<h:panelGrid columns="1" style="margin-left:40px;">
<p:outputPanel id="imageForPenetrationPointPublic" styleClass="slot">
<h:panelGrid columns="1" rendered="#{generationTdeEbmMB.selectedImageForPenetrationPointPublic!= null}">
<p:graphicImage url="/images/#{generationTdeEbmMB.selectedImageForPenetrationPointPublic}" style="width: 100%;height: 260px;"/>
</h:panelGrid>
</p:outputPanel>
<p:droppable for="imageForPenetrationPointPublic" tolerance="fit" activeStyleClass="ui-state-highlight" datasource=":availablePictureForm:availablePicturesDGrid" onDrop="handleDrop">
<p:ajax listener="#{generationTdeEbmMB.onImageForPenetrationPointPublicDrop}" update="imageForPenetrationPointPublic " />
</p:droppable>
</h:panelGrid>
</h:form>
<h:form id="availablePictureForm" >
<p:fieldset legend="Photos disponibles " rendered="#{generationTdeEbmMB.uploadedImageNameList.size() != 0}">
<p:scrollPanel style="width:400px;height: 600px;">
<p:dataGrid id="availablePicturesDGrid" value="#{generationTdeEbmMB.uploadedImageNameList}" var="imageName" columns="3" emptyMessage="Aucune photo trouvée.">
<p:panel id="pnl" header="#{imageName}" style="text-align:center">
<h:panelGrid columns="1" style="width:20%">
<p:graphicImage url="/images/#{imageName}" style="width: 120px;height: 110px;"/>
</h:panelGrid>
</p:panel>
<p:draggable for="pnl" proxy="true" revert="true" helper="clone" handle=".ui-panel-content" stack=".ui-panel"/>
</p:dataGrid>
</p:scrollPanel>
</p:fieldset>
</h:form>
但缓慢的问题仍然存在。如果不纠正这个问题,我什么也做不了。我正在使用 JSF 2.1 和 PrimeFaces 3.5
欢迎任何建议或想法。
提前谢谢了。