2016-11-25 33 views
0

pptx slideを画像に変換し、画像をスイングパネルに表示するコードがあります。Apache POI pptx to imageは処理に時間がかかります

Eclipseでコードを実行すると、パネルを表示するのに10秒かかりますが、同じコードをjarで実行すると、パネルを開くのに1分以上かかります。

ユーザーが最初に開いたときにのみ発生します。その後、より高速に読み込みます。

ご協力いただき、ありがとうございます。

は、ここで私は、コード

// currentPage - Slide number to display 
// source - pptx file path 
public void Display(int currentPage, String source) { 
    try { 

     FileInputStream is = new FileInputStream(source); 
     XMLSlideShow ppt = new XMLSlideShow(is); 
     is.close(); 

     double zoom = 1; // magnify it by 2 
     AffineTransform at = new AffineTransform(); 
     at.setToScale(zoom, zoom); 

     Dimension pgsize = ppt.getPageSize(); 

     XSLFSlide[] slides = ppt.getSlides(); 
     all = slides.length; 
     lblPage.setText(currentPage + "/" + all); 

     current = currentPage; 

     BufferedImage img = new BufferedImage(pgsize.width, pgsize.height, BufferedImage.TYPE_INT_RGB); 

     Graphics2D graphics = img.createGraphics(); 
     graphics.setRenderingHint(RenderingHints.KEY_COLOR_RENDERING, RenderingHints.VALUE_COLOR_RENDER_QUALITY); 
     graphics.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON); 
     graphics.setRenderingHint(RenderingHints.KEY_RENDERING, RenderingHints.VALUE_RENDER_QUALITY); 
     graphics.setRenderingHint(RenderingHints.KEY_INTERPOLATION, RenderingHints.VALUE_INTERPOLATION_BICUBIC); 
     graphics.setRenderingHint(RenderingHints.KEY_FRACTIONALMETRICS, RenderingHints.VALUE_FRACTIONALMETRICS_ON); 
     graphics.transform(at); 

     graphics.setColor(Color.white); 
     graphics.clearRect(0, 0, pgsize.width, pgsize.height); 
     graphics.fill(new Rectangle2D.Float(0, 0, pgsize.width, pgsize.height)); 

     System.out.println("Before draw: " + new Date()); 

     slides[currentPage - 1].draw(graphics); 

     System.out.println("After draw: " + new Date()); 

     // save the output 
     Image newImg = img.getScaledInstance(lblPresentasi.getWidth(), lblPresentasi.getHeight(), Image.SCALE_SMOOTH); 
     final ImageIcon icon = new ImageIcon(newImg); 
     lblPresentasi.setIcon(icon); 
     lblPresentasi.addComponentListener(new ComponentAdapter() { 
      @Override 
      public void componentResized(ComponentEvent e) { 
       JLabel label = (JLabel) e.getComponent(); 
       Dimension size = label.getSize(); 
       Image resized = icon.getImage().getScaledInstance(size.width-10, size.height-10, Image.SCALE_FAST); 
       label.setIcon(new ImageIcon(resized)); 
      } 
     }); 
     graphics.dispose(); 
     newImg.flush(); 
    } catch (Exception e) { 
     e.printStackTrace(); 
    } 
}// end of method Display() 
+2

レンダリングが初めて実行されるとき、プリセットシェイプのXML定義がロードされます。これには通常1-2秒かかります。しかし、1分。いくつかのスキーマがバックグラウンドで読み込まれているように見えます。ネットワークなしであなたの例を試してみてください。そうでない場合は、アプリケーションのプロファイルを作成する必要があります。必要に応じて、POIのbugzillaにあなたのサンプル(コード&ppt/x)を投稿することができます。 – kiwiwings

+0

@kiwiwings:私がEclipseで実行すると、問題はJARにあるのに対して、わずか4秒かかります。私はlib jarを参照するために1つのjarでJARを構築します。それは何かに影響しますか? – Tamil

答えて

0

を含め、この遅延は、ワンジャーカスタムクラスローダによって引き起こされました。最初に、依存関係ライブラリをロードしてクラスをロードするのに、より多くの時間がかかります。

したがって、1つのjarファイルを削除し、JarSpliceを使用して依存関係ライブラリクラスを読み込むと、うまくいきます。

関連する問題