ByPass Print Dialog at Jasper Report

Buat teman-teman yang belum tahu bagaimana cara-nya mencetak laporan tanpa mengeluarkan print dialog di Jasper Report, mungkin tulisan ini bisa sedikit membantu teman-teman yang sedang kebingungan :) . Ok sebelum mulai latihannya, ada beberapa perlengkapan yang harus kita persiapkan dan perlengkapan yang digunakan pada tulisan kali ini yaitu :
1. JDK 1.6_06
2. NetBeans IDE 6.1
3. Jasper Report 3.0.0
4. MySQL 5.0.51a

Pada tulisan kali ini, kita akan mencoba menambahkan fasilitas by pass print dialog ini di aplikasi yang sudah pernah dibuat pada tutorial Membuat Master Detail Report kemarin.

Untuk teman-teman yang belum tahu bagaimana cara membuat report, silahkan baca dahulu tutorial kemarin. Dan untuk teman-teman yang sudah tahu, sekarang download-lah NetBeans Project dari tutorial kemarin disini. Setelah proses download selesai, sekarang ekstrak dan bukalah dari NetBeans IDE

Karena library jasper report tidak ikut di sertakan pada tutorial kemarin, maka ketika teman-teman membuka NetBeans Project dari tutorial kemarin akan mengeluarkan pesan error seperti gambar dibawah ini :
Resolve
Dialog Error Reference Problem

Agar tidak terdapat masalah pada proses penambahan library yang akan teman-teman lakukan, sekarang editlah dahulu file project.properties yang terdapat pada direktori NamaProject/nbproject/project.properties. Carilah baris seperti dibawah ini :

18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
excludes=
file.reference.commons-beanutils-1.7.jar=library/commons-beanutils-1.7.jar
file.reference.commons-collections-2.1.jar=library/commons-collections-2.1.jar
file.reference.commons-digester-1.7.jar=library/commons-digester-1.7.jar
file.reference.commons-javaflow-20060411.jar=library/commons-javaflow-20060411.jar
file.reference.commons-logging-1.0.2.jar=library/commons-logging-1.0.2.jar
file.reference.jasperreports-2.0.2.jar=library/jasperreports-2.0.2.jar
file.reference.jdt-compiler-3.1.1.jar=library/jdt-compiler-3.1.1.jar
file.reference.jfreechart-1.0.0.jar=library/jfreechart-1.0.0.jar
includes=**
jar.compress=false
javac.classpath=\
    ${libs.MySQLDriver.classpath}:\
    ${file.reference.commons-beanutils-1.7.jar}:\
    ${file.reference.commons-collections-2.1.jar}:\
    ${file.reference.commons-digester-1.7.jar}:\
    ${file.reference.commons-javaflow-20060411.jar}:\
    ${file.reference.jasperreports-2.0.2.jar}:\
    ${file.reference.jdt-compiler-3.1.1.jar}:\
    ${file.reference.commons-logging-1.0.2.jar}:\
    ${file.reference.jfreechart-1.0.0.jar}
# Space-separated list of extra javac options
javac.compilerargs=

Kemudian hapuslah seluruh reference ke library yang lama hingga menjadi seperti dibawah ini :

18
19
20
21
22
23
24
excludes=
includes=**
jar.compress=false
javac.classpath=\
    ${libs.MySQLDriver.classpath}:\
# Space-separated list of extra javac options
javac.compilerargs=

Setelah melakukan penyimpanan pada file project.properties, sekarang tambahkanlah library-library yang diperlukan dengan cara klik kanan node Library di Project Inspector kemudian pilih Add JAR/Folder seperti gambar dibawah ini:
AddLib
Menambahkan library jasper report ke dalam NetBeans IDE

Klo sudah, sekarang bukalah file FormReport kemudian tambahkanlah event pada button Print dengan cara klik kanan pada button Print kemudian pilih Events > Action > actionPerformed[jButton3ActionPerformed] seperti gambar dibawah ini :
AddEvent
Menambahkan event pada button print

Sekarang gantilah baris dibawah ini :

138
139
140
141
    private void jButton3ActionPerformed(java.awt.event.ActionEvent evt) {
        // TODO add your handling code here:
        JOptionPane.showMessageDialog(null, "Maaf fasilitas ini belum aktif !!");
    }

menjadi seperti ini :

138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
    private void jButton3ActionPerformed(java.awt.event.ActionEvent evt) {
        this.setCursor(Cursor.getPredefinedCursor(Cursor.WAIT_CURSOR));
 
        Properties systemProp = System.getProperties();
 
        // Ambil current dir
        String currentDir = systemProp.getProperty("user.dir");
 
        File dir = new File(currentDir);
        String reportName = "RptMaster.jrxml";
        String reportDirName = "Report";
 
        File fileRpt;
        String fullPath = "";
        if (dir.isDirectory()) {
            String[] isiDir = dir.list();
            for (int i = 0; i < isiDir.length; i++) {
                fileRpt = new File(currentDir + File.separatorChar + isiDir[i] + File.separatorChar +
                        reportDirName + File.separatorChar + reportName);
 
                if (fileRpt.isFile()) { // Cek apakah file RptMaster.jrxml ada
                    fullPath = fileRpt.toString();
                    System.out.println("Found Report File at : " + fullPath);
                } // end if
            } // end for i
        } // end if
 
        // Ambil Direktori tempat file RptMaster.jrxml berada
        String[] subRptDir = fullPath.split(reportName);
        String reportDir = subRptDir[0];
        System.out.println("Report Directory at : " + reportDir);
 
        // Ambil Kode Kategori
        final String paramKdKategori = jComboBox1.getSelectedItem().toString();
        Connection con = null;
        try {
            String jdbcDriver = "com.mysql.jdbc.Driver";
            Class.forName(jdbcDriver);
            String url = "jdbc:mysql://localhost/rptmasterdetail";
            String user = "root";
            String pass = "rahasia";
 
            con = (Connection) DriverManager.getConnection(url, user, pass);
            Statement stm = (Statement) con.createStatement();
 
            // Persiapkan parameter untuk Report
            Map<string, Object> parameters = new HashMap<string, Object>();
            parameters.put("PRM_KD_KATEGORI", paramKdKategori);
            parameters.put("SUBREPORT_DIR", reportDir);
 
            try {
                JasperReport JRpt = JasperCompileManager.compileReport(fullPath);
                JasperPrint JPrint = JasperFillManager.fillReport(JRpt, parameters, con);
                // JasperViewer.viewReport(JPrint, false);
                JasperPrintManager.printPage(JPrint, 0, false);
            } catch (Exception rptexcpt) {
                System.out.println("Report Can't view because : " + rptexcpt);
            }
        } catch (Exception e) {
            System.out.println(e);
        }
        this.setCursor(Cursor.getDefaultCursor());
    }

Note :

  • Sesuaikan konfigurasi koneksi database dengan konfigurasi yang terdapat pada komputer anda.
  • Tekan kombinasi tombol Ctrl+Shift+I untuk automatic import, jika terdapat baris kode yang berwarna merah
  • Setelah melakukan proses penyimpanan sekarang coba jalankanlah dengan menekan tombol F6 kemudian tekanlah tombol Print, dan jika tidak ada pesan kesalahan maka pada output Window akan menampilkan pesan seperti dibawah ini dan printer akan otomatis mencetak laporan kita tanpa mengeluarkan Print Dialog lagi :) :

    Found Report File at : /home/martin/Desktop/RptMasterDetail/dist/Report/RptMaster.jrxml
    Found Report File at : /home/martin/Desktop/RptMasterDetail/build/Report/RptMaster.jrxml
    Report Directory at : /home/martin/Desktop/RptMasterDetail/build/Report/
    

    Happy NetBeaning All :)

    Tags:

    27 Responses to “ByPass Print Dialog at Jasper Report”

    1. amhy says:

      Mas minta pencerahannya ,saya sedang membuat aplikasi pemesanan tiket dengan java menggunakan database system mysql
      bisa gak di contohkan bagaimana cara print tiket dengan menggunakan Ireport/jasper report??

    2. @Khairan: Biasanya sih utk proses seperti itu, saya lakuin dari java-nya :D dan report itu cuma sebagai viewer-nya aja :)

    3. khairan says:

      makasih mas akhirnya mau juga nampil laporannya…hehehehe… o y mas kalo kita mau buat perulangan di ireport bisa g’ mas, mis jika nilai huruf 3 nilai angkanya b nanti nilai 3 tersebut di kali dengan jmlah sks misalnya baru dapet bobot…kemarin di coba di letakin di parameter tapi error..hehehe, bisa diajarin ga caranya mas….makasih…

    4. khairan says:

      makasih y mas…saya coba dulu…

    5. @khairan: Jangan di jalankan di dalam direktori dist, tapi coba jalankan dari luar direktori dist. Jadi cara ngejalanin-nya spt ini :
      java -jar dist/*.jar

    6. khairan says:

      mas mohon pencerahannya…saya sedang belajar buat laporan di netbeans pake jasperreport, tapi pas saya clean and build projek laporan netbeans saya dan saya jalankan jar di folder distnya tidak bereaksi apa2, tetapi di jalankan di netbeansnya laporan yang saya buat tersebut mau keluar. saya udah baca dan coba juga saran mas untuk pandotic tapi karena kepanjangan jadi bingung..hehehehe maklum masih belajar,..kira2 apa masalahnya mas..? terima kasih untuk pencerahannya…

    Leave a Reply

    [+] adsenseid emoticons by Martinus Ady H. Modified from nartzco source code.