4

按照此处找到的解决方案,我已经实现了两个 StreamedContent bean 来动态加载图形图像

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比它有效!我很困惑......有人可以帮助我吗?

托管豆:

@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");
        }
      }
    }
4

1 回答 1

0

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

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

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

于 2017-04-03T20:50:39.177 回答