O Jasper Reports Components não é renderizado corretamente no JavaFX Swing Node

13

Para criar o Jasper Report no JavaFX 11, estou usando relatórios dinâmicos. Estou carregando o relatório no Swing Node, mas o relatório Jasper será exibido apenas se eu clicar na área do painel de pilhas e em todos os outros componentes visíveis apenas se passar o mouse sobre todos esses componentes. Os componentes e o conteúdo do relatório não são carregados instantaneamente, em vez de serem exibidos ao passar o mouse e o relatório é exibido ao rolar o painel Pilha.

Como esse foi o bug no Java 8 e parece estar resolvido, mas no Java 11 também estou recebendo o mesmo problema.

Atualizar

Como não estou recebendo nenhuma resposta e, conforme sugerido pelo kleopatra, criei um código reproduzível mínimo. Por favor, olhe para isso.

JavaFxJasperReportsDemo.java

package demo;

import java.util.ArrayList;
import java.util.List;

import javax.swing.SwingUtilities;

import javafx.application.Application;
import javafx.application.Platform;
import javafx.embed.swing.SwingNode;
import javafx.event.ActionEvent;
import javafx.event.EventHandler;
import javafx.fxml.FXML;
import javafx.fxml.FXMLLoader;
import javafx.scene.Parent;
import javafx.scene.Scene;
import javafx.scene.layout.AnchorPane;
import javafx.scene.layout.StackPane;
import javafx.stage.Stage;
import javafx.stage.WindowEvent;
import net.sf.dynamicreports.jasper.builder.JasperReportBuilder;
import net.sf.dynamicreports.report.builder.DynamicReports;
import net.sf.dynamicreports.report.builder.column.Columns;
import net.sf.dynamicreports.report.builder.component.Components;
import net.sf.dynamicreports.report.builder.datatype.DataTypes;
import net.sf.dynamicreports.report.constant.HorizontalTextAlignment;
import net.sf.dynamicreports.report.exception.DRException;
import net.sf.jasperreports.engine.JasperPrint;
import net.sf.jasperreports.swing.JRViewer;

public class JavaFxJasperReportsDemo extends Application{

    @FXML
    private StackPane stackPane;

    public void start(Stage stage) throws Exception{

        try{
            System.out.println("Hello");
            Parent root = FXMLLoader.load(getClass().getResource("/FXMLJavaFXJasperReportsDemo.fxml"));
            Scene scene = new Scene(root);
            stage.setScene(scene);
            stage.setTitle("Java FX Demo");
            stage.show();
            stage.setOnCloseRequest(new EventHandler<WindowEvent>() {
                public void handle(WindowEvent arg0) {
                    Platform.exit();
                }
            });
        }
        catch (Exception e){
            throw e;
        }
    }


    @FXML
    public void loadReport(ActionEvent event) {
        JasperReportBuilder report = DynamicReports.report();
        List<DemoPOJO> lstDemoPOJOs=new ArrayList<DemoPOJO>();
        DemoPOJO demoPOJO=new DemoPOJO();
        demoPOJO.setName("ABC");
        demoPOJO.setCity("Delhi");
        lstDemoPOJOs.add(demoPOJO);
        demoPOJO = new DemoPOJO();
        demoPOJO.setName("XYZ");
        demoPOJO.setCity("Agra");
        lstDemoPOJOs.add(demoPOJO);
        report
        .columns(
                Columns.columnRowNumberColumn("S No"),
                Columns.column("Name", "name", DataTypes.stringType()),
                Columns.column("Address", "city", DataTypes.stringType())
                ).title(
                Components.text("Demo Java Fx Jasper Reports").
                setHorizontalTextAlignment(HorizontalTextAlignment.CENTER))
        .pageFooter(Components.pageXofY())
        .setDataSource(lstDemoPOJOs);

        try {
            JasperPrint jasperPrintReport=report.toJasperPrint();
            SwingNode swingNode = new SwingNode();
            AnchorPane.setTopAnchor(swingNode,0.0);
            AnchorPane.setBottomAnchor(swingNode,0.0);
            AnchorPane.setLeftAnchor(swingNode,0.0);
            AnchorPane.setRightAnchor(swingNode,0.0);
            JRViewer jrViewer=   new JRViewer(jasperPrintReport);
            SwingUtilities.invokeLater(() ->swingNode.setContent(jrViewer)
                    );
            stackPane.getChildren().add(swingNode);
        } catch (DRException e) {
            e.printStackTrace();
        }

    }

    public static void main(String[] args){
        System.out.println("Hello Main");
        try{
            launch(args);
        }
        catch (Exception e){
            e.printStackTrace();
        }
    }
}

DemoPOJO.java

package demo;

public class DemoPOJO {

    String name;

    String city;

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getCity() {
        return city;
    }

    public void setCity(String city) {
        this.city = city;
    }
}

FXMLJavaFXJasperReportsDemo.fxml

<?xml version="1.0" encoding="UTF-8"?>

<?import javafx.scene.control.Button?>
<?import javafx.scene.control.Label?>
<?import javafx.scene.layout.AnchorPane?>
<?import javafx.scene.layout.StackPane?>

<AnchorPane maxHeight="-Infinity" maxWidth="-Infinity" minHeight="-Infinity" minWidth="-Infinity" prefHeight="561.0" prefWidth="745.0" xmlns="http://javafx.com/javafx/11.0.1" xmlns:fx="http://javafx.com/fxml/1" fx:controller="demo.JavaFxJasperReportsDemo">
   <children>
      <Label layoutX="345.0" layoutY="24.0" text="Java FX Demo Application" />
      <StackPane fx:id="stackPane" layoutX="14.0" layoutY="120.0" prefHeight="392.0" prefWidth="722.0" />
      <Button layoutX="62.0" layoutY="68.0" mnemonicParsing="false" onAction="#loadReport" text="Load Report" />
   </children>
</AnchorPane>

As dependências que estou usando são: -

<dependency>
    <groupId>net.sourceforge.dynamicreports</groupId>
    <artifactId>dynamicreports-core</artifactId>
    <version>6.1.0</version>
</dependency>

<dependency>
    <groupId>org.openjfx</groupId>
    <artifactId>javafx-controls</artifactId>
    <version>11</version>
</dependency>

<dependency>
    <groupId>org.openjfx</groupId>
    <artifactId>javafx-fxml</artifactId>
    <version>11</version>
</dependency>

<dependency>
    <groupId>javax.xml.bind</groupId>
    <artifactId>jaxb-api</artifactId>
    <version>2.2.11</version>
</dependency>

<dependency>
    <groupId>org.openjfx</groupId>
    <artifactId>javafx-swing</artifactId>
    <version>11-ea+24</version>
</dependency>

Resultado

  1. Depois de clicar no botão carregar relatório, apenas um ícone de salvamento fica visível e nenhum relatório é visível. Depois de clicar no botão carregar relatório, apenas um ícone de salvamento fica visível, nenhum relatório é visível

  2. Depois de clicar na área do painel Pilha agora, o Relatório fica visível. Depois de clicar na área do painel Pilha agora, o relatório está visível

  3. Depois de passar o mouse sobre outro ícone, agora o ícone Imprimir fica visível. Depois de passar o mouse sobre outro ícone, agora o ícone Imprimir fica visível

  4. Depois de passar o mouse sobre outros ícones, eles ficam visíveis um a um. Depois de passar o mouse sobre outros ícones, eles ficam visíveis um a um

Satish Pahuja
fonte
Estou apenas recebendo votos, mas ninguém está me dando resposta. Estou muito desesperado para obter qualquer solução para essa pergunta.
Satish Pahuja
3
que você pode melhorar suas chances de uma resposta, fornecendo um exemplo reproduzível mínima (mente: não o código completo, mas um pequeno exemplo escrito com o único propósito de demonstrar o seu problema :)
kleopatra
2
e adicionar todas as tags relevantes .. talvez alguém da multidão swing / JasperReport tem algumas dicas úteis
kleopatra
11
Olá, Estou executando o programa jbsdk11b125_osx_x64e não consegui reproduzir o problema. Mostra o conteúdo completo diretamente. Embora eu esteja recebendo um aviso Carregando documento FXML com a API JavaFX da versão 11.0.1 pelo tempo de execução JavaFX da versão 10.0.2-internal ...
Vall0n 27/01
2
1) Também pode ser um problema relacionado ao driver gráfico. Algumas propriedades como ponto de partida para solução de problemas docs.oracle.com/en/java/javase/11/troubleshoot/… . 2) Você tentou uma versão mais recente do org.openjfx:javafx-swing, por exemplo 11? 3) Usando o Java 11.0.5, Maven 3.6.2 e o plug org.openjfx:javafx-maven-plugin:0.0.4- in, ele funciona sem problemas de renderização (o relatório é exibido depois de clicar no Load Reportbotão). O aplicativo é iniciado com mvn clean javafx:run.
SubOptimal

Respostas:

1

Após verificar o wiki do OpenJDK para sinalizadores de depuração do OpenJFX, você pode tentar seguir.

inclua na seção de construção da pom.xmlopção uma JVM para OpenJFX

<plugin>
    <groupId>org.openjfx</groupId>
    <artifactId>javafx-maven-plugin</artifactId>
    <version>0.0.4</version>
    <configuration>
        <mainClass>demo.JavaFxJasperReportsDemo</mainClass>
        <options>
            <option>-Dprism.verbose=true</option>
        </options>
    </configuration>
</plugin>

executar o aplicativo com mvn javafx:runele relatará a configuração do Prism detectada

saída no meu sistema

Prism pipeline init order: es2 sw 
Using Double Precision Marlin Rasterizer
Using dirty region optimizations
Not using texture mask for primitives
Not forcing power of 2 sizes for textures
Using hardware CLAMP_TO_ZERO mode
Opting in for HiDPI pixel scaling
Prism pipeline name = com.sun.prism.es2.ES2Pipeline
Loading ES2 native library ... prism_es2
    succeeded.
GLFactory using com.sun.prism.es2.X11GLFactory
(X) Got class = class com.sun.prism.es2.ES2Pipeline
Initialized prism pipeline: com.sun.prism.es2.ES2Pipeline
...
Graphics Vendor: Intel Open Source Technology Center
       Renderer: Mesa DRI Intel(R) Ivybridge Mobile 
        Version: 3.0 Mesa 19.3.2

está usando um renderizador acelerado por hardware Loading ES2 native library ... prism_es2

É possível forçar o uso do renderizador de software. Mudança nopom.xml

        <options>
            <option>-Dprism.verbose=true</option>
            <option>-Dprism.order=sw</option
        </options>

a saída é então

Prism pipeline init order: sw 
Using Double Precision Marlin Rasterizer
Using dirty region optimizations
Not using texture mask for primitives
Not forcing power of 2 sizes for textures
Using hardware CLAMP_TO_ZERO mode
Opting in for HiDPI pixel scaling
*** Fallback to Prism SW pipeline
Prism pipeline name = com.sun.prism.sw.SWPipeline
(X) Got class = class com.sun.prism.sw.SWPipeline
Initialized prism pipeline: com.sun.prism.sw.SWPipeline
 vsync: true vpipe: false

Está usando o renderizador de software Fallback to Prism SW pipeline.

versões usadas para os testes acima:

JDK

java version "11.0.2" 2019-01-15 LTS
Java(TM) SE Runtime Environment 18.9 (build 11.0.2+9-LTS)
Java HotSpot(TM) 64-Bit Server VM 18.9 (build 11.0.2+9-LTS, mixed mode)

Maven

Apache Maven 3.6.3 (cecedd343002696d0abb50b32b541b8a6ba2883f)
SubOptimal
fonte
obrigado por compartilhar, mas essa abordagem não resolveu o problema.
Satish Pahuja
11
@SatishPahuja Qual versão Java concreta java -versionvocê usa? Você tentou executar o lançamento em 11vez 11-ea+24do plugin org.openjfx:javafx-swing?
SubOptimal