java - 在 Primefaces 中使用 Galleria 进行 imageRotateAndResize
问题描述
我正在使用带有 StreamedContent 的 Galleria 来显示来自 c:// 的图像。画廊正确显示图像,但是当我使用按钮使用 pe:imageRotateAndResize 缩放图像时,它只影响第一张图像,当我更改图像并使用按钮时,它仍然只影响画廊中的第一张图像. 我需要什么或必须纠正什么,以便 pe:imageRotateAndResize 影响画廊的当前形象,而不仅仅是第一个?Primefaces 和 PrimefacesExtensions 版本 6.0-6.0.0
xhtml代码:
<p:galleria id="galleriaC" var="galle" value="#{controller.imagenes}" autoPlay="false" showCaption="false"
style="width: 100%; max-width: 100px; min-width: 100%; min-height: 10px; height: auto; overflow:scroll; ">
<p:graphicImage id="myImage" value="#{controller.imageItem}" style="width: auto; height: 100%;">
<f:param name="gh" value="#{galle}"/>
</p:graphicImage>
</p:galleria>
<pe:imageAreaSelect id="areaSelect"
for="myImage"
widgetVar="areaSelectWidget"
autoHide="true"
handles="false"
movable="false"
persistent="false"
resizable="false"
>
<p:ajax event="selectEnd" listener="#{controller.selectEndListener}" update="msg"/>
</pe:imageAreaSelect>
<pe:imageRotateAndResize id="rotateAndResize" for="myImage" widgetVar="rotateAndResizeWidget" >
<p:ajax event="rotate" listener="#{controller.rotateListener}"
update="msg" oncomplete="PF('areaSelectWidget').reload();"/>
<p:ajax event="resize" oncomplete="PF('areaSelectWidget').reload();" />
</pe:imageRotateAndResize>
<p:commandButton value="Regresar" actionListener="#{controller.regresar()}" update=":form"/>
<p:commandButton icon="ui-icon-zoomin" value="Scale +"
onclick="PF('rotateAndResizeWidget').scale(1.05);return false;"/>
<p:commandButton icon="ui-icon-zoomout" value="Scale -"
onclick="PF('rotateAndResizeWidget').scale(0.95);return false;"/>
代码Java:
public List<String> getImagenes() {
return imagenes;
}
public StreamedContent getImageItem(){
FacesContext context = FacesContext.getCurrentInstance();
try{
if(context.getRenderResponse()){
return new DefaultStreamedContent();
}else{
//String name = context.getExternalContext().getRequestParameterMap().get("gh");
Map<String,String> params = context.getExternalContext().getRequestParameterMap();
String nmFile = params.get("gh");
File imgFile = new File(nmFile);
System.out.println("File a stremear: "+nmFile);
StreamedContent ds = new DefaultStreamedContent(new FileInputStream(imgFile),context.getExternalContext().getMimeType(imgFile.getName()));
return ds;
}
}catch(Exception e){
e.printStackTrace();
}
return null;
}
public void selectEndListener(final ImageAreaSelectEvent e) {
final FacesMessage msg = new FacesMessage(FacesMessage.SEVERITY_INFO, "Area selected",
"X1: " + e.getX1() + ", X2: " + e.getX2() + ", Y1: " + e.getY1() + ", Y2: " + e.getY2()
+ ", Image width: " + e.getImgWidth() + ", Image height: " + e.getImgHeight());
FacesContext.getCurrentInstance().addMessage(null, msg);
}
public void rotateListener(final RotateEvent e) {
final FacesMessage msg = new FacesMessage(FacesMessage.SEVERITY_INFO, "Image rotated",
"Degree:" + e.getAngle());
FacesContext.getCurrentInstance().addMessage(null, msg);
}
解决方案
推荐阅读
- maven - Jenkins 中的“DevToolsActivePort 文件不存在”错误
- javascript - 值未传递给父组件
- audio - 低延迟的FFmpeg实时音频流
- python - 子进程 for 循环失败并出现语法错误
- javascript - Angular Webpack 设置:使用 webpack 从 css 迁移到 sass
- java - android中的CursorIndexOutOfBoundException index 0 size 0
- excel - 粘贴 Excel 图表
- java - 如何比较时间戳是否在Java中的给定时间段范围内
- cmd - 通过cmd和时间戳备份删除window中的子文件夹和文件
- python - 实现双链表 - 调用头节点时的最大递归深度