使用StreamedContent动态图像

时间:2017-03-29 11:21:25

标签: primefaces jsf-2 graphicimage

根据找到的解决方案,我已经实现了两个StreamedContent bean来动态加载图形图像 here

1)使用第一个我在contentFlow中显示图像(一切正常)

<p:contentFlow value="#{imageBean.images}" var="image">
           <p:graphicImage value="#{imageStreamer.fileContent}" styleClass="content" cache="false">
                  <f:param name="index" value="#{image.index}"/>
            </p:graphicImage>
</p:contentFlow>

2)对于第二个,我尝试使用foreach(或重复)显示图像:

 <c:forEach items="#{imageBean.images}" var="item" varStatus="varStatus">
          <p:graphicImage value="#{imageStreamer.fileContent}" cache="false">
                            <f:param name="index" value="#{varStatus.index}" />
          </p:graphicImage>
</c:forEach>

这不起作用。支票(context.getCurrentPhaseId() == PhaseId.RENDER_RESPONSE)始终为真。

如果我将Bean的范围更改为RequestScoped而不是它的工作原理!我很困惑......有人能帮帮我吗?

管理bean:

@ManagedBean
@ApplicationScoped
public class ImageStreamer{

      public ImageStreamer(){}

      public StreamedContent getFileContent(){
        List<Link> links = this.getLinkItems();
        ExternalContext externalContext = FacesContext.getCurrentInstance().getExternalContext();

        FacesContext fc = FacesContext.getCurrentInstance();
        String linkIndex = externalContext.getRequestParameterMap().get("index");

        if(fc.getCurrentPhaseId() == PhaseId.RENDER_RESPONSE){
          return new DefaultStreamedContent();
        }else{

          int parsedIndex = Integer.parseInt(linkIndex);
          Link ql = links.get(parsedIndex);
          return new DefaultStreamedContent(new ByteArrayInputStream(ql.getBytes()), "image/png");
        }
      }
    }

1 个答案:

答案 0 :(得分:0)

由于您使用的是primefaces,请尝试使用p:repeat

  

Repeat是标准重复组件的扩展,用于提供JSF实现和PrimeFaces组件之间的互操作性。

https://www.primefaces.org/showcase/ui/data/repeat.xhtml