image - PrimeFaces imageCropper 不显示可选区域

标签 image jsf-2 primefaces jboss7.x crop

我只是复制了 primefaces 展示上的示例,但未显示选择图像的区域。在陈列柜中,它看起来如此简单。

我的页面:

<ui:composition 
    xmlns="http://www.w3.org/1999/xhtml"
    xmlns:ui="http://java.sun.com/jsf/facelets"
    xmlns:f="http://java.sun.com/jsf/core"
    xmlns:h="http://java.sun.com/jsf/html"
    xmlns:p="http://primefaces.org/ui">

<h:form>  

<p:imageCropper value="#{uploadMB.croppedImage}" id="imageCropper" 
image="/images/banner.jpg" />


</h:form>  

</ui:composition>

我的背 bean :
@ManagedBean
public class UploadMB implements Serializable{

    private static final Logger logger = Logger.getLogger(UploadMB.class.getName());

    private CroppedImage croppedImage;
    private String newImageName;  

    public String crop() {  
        if(croppedImage == null)  
            return null;  

        setNewImageName(getRandomImageName());  
        ServletContext servletContext = (ServletContext) FacesContext.getCurrentInstance().getExternalContext().getContext();  
        String newFileName = servletContext.getRealPath("") + File.separator + "images" + File.separator + "barca" + File.separator + getNewImageName() + ".jpg";  

        FileImageOutputStream imageOutput;  
        try {  
            imageOutput = new FileImageOutputStream(new File(newFileName));  
            imageOutput.write(croppedImage.getBytes(), 0, croppedImage.getBytes().length);  
            imageOutput.close();  
        } catch (FileNotFoundException e) {  
            e.printStackTrace();  
        } catch (IOException e) {  
            e.printStackTrace();  
        }  

        return null;  
    }  

    private String getRandomImageName() {  
        int i = (int) (Math.random() * 100000);  

        return String.valueOf(i);  
    }  

    public String getNewImageName() {  
        return newImageName;  
    }  

    public CroppedImage getCroppedImage() {
        return croppedImage;
    }

    public void setCroppedImage(CroppedImage croppedImage) {
        this.croppedImage = croppedImage;
    }

    public void setNewImageName(String newImageName) {
        this.newImageName = newImageName;
    }  

是否可能缺少一些库?或其他配置选项?我刚刚下载了 primefaces 3.5 jar 并将其放入我的类路径中。

谢谢

最佳答案

您的图片位于 %WEBAPP_ROOT%/images/banner.jpg

您可以通过 HTTP Url(浏览器)访问您的图片吗?

关于image - PrimeFaces imageCropper 不显示可选区域,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17242917/

相关文章:

ajax - PrimeFaces ajax 更改另一个字段上的输入和操作

php - 如何使用 php 更新 sql 中的图像

jsf-2 - 如何在Primefaces中显示带有html标记的文本

javascript - instagram 图片库如何运作?

java - 动态 <ui :include> doesn't work

jsf - jsf中没有 session 生成

jsf-2 - 是否可以将全局过滤器放在 p :dataTable? 之外

java - Primefaces 数据表过滤器

java - 确保在Java中保留List中的顺序并提高效率

iOS Swift 动画 - 将图像移动到新位置