Final Project EAS
Pemrograman Berorientasi Objek
Risky
Aswi Narni 05111740000014
I
nyoman Yoga Mahottama 05111740000159
a. Pengertian
JavaFX
adalah kumpulan package graphic dan media yang memungkinkan
developer untuk membuat aplikasi desktop. JavaFX dirilis untuk menggantikan
Swing sebagai pustaka standar GUI untuk Java SE. JavaFX
menyediakan pengaturan grafis dan media API dan memanfaatkan Graphical
Processing Unit modern melalui akselerasi perangkat keras grafis. JavaFX juga
menyediakan interface yang dapat digunakan pengembang untuk menggabungkan
animasi grafis dan UI controls.
Penggunaan JavaFX dengan teknologi berbasis JVM seperti Java, Groovy dan
JRuby. Jika pengembang memilih untuk JavaFX, tidak ada kebutuhan untuk belajar
teknologi tambahan, seperti pengetahuan sebelumnya dari salah satu teknologi
yang disebutkan di atas akan cukup baik untuk mengembangkan RIA menggunakan
JavaFX.
b. Implementasi
Pembuatan
Aplikasi “Toko Mandiri” Menggunakan 4 class yaitu penjualan, pembelian,
Database, Bukti
Memiliki
fitur -fitur:
a.
Aplikasi kasir
b.
Input ke Database
c.
Hapus data
d.
Update Data
c. Sourcode
-pembelian
3. Sistem menghitung jumlah Hargaimport javafx.application.Application; import javafx.application.Platform; import javafx.event.ActionEvent; import javafx.event.EventHandler; import javafx.geometry.Insets; import javafx.geometry.Pos; import javafx.scene.Scene; import javafx.scene.control.*; import javafx.scene.layout.*; import javafx.scene.text.Font; import javafx.scene.text.Text; import javafx.stage.Stage; import javafx.scene.layout.StackPane; import javafx.collections.*; import javafx.scene.paint.*; import javafx.scene.text.*; import javafx.scene.Group; import java.util.Random; import javafx.scene.image.Image; import javafx.scene.image.ImageView; import java.io.FileInputStream; public class Pembelian extends Application { Text textDaftar = new Text("Daftar: "); Text textKasir = new Text("Kasir :"); Text KodeBarang = new Text(""); Text textBiaya = new Text(""); Text textJumlah = new Text(""); Text textTotalBayar = new Text(""); Text NamaBarang = new Text(""); Text BiayaBarang = new Text(""); Text TotalBiayaText = new Text(""); TextField textFieldJumlah = new TextField (); ObservableList
optionsKasir = FXCollections.observableArrayList( "Awin", "Yoga" ); final ComboBox comboBoxKasir = new ComboBox(optionsKasir); ObservableList optionsBarang = FXCollections.observableArrayList( "1", "2", "3", "4", "5" ); final ComboBox comboBoxBarang = new ComboBox(optionsBarang); private int TotalBiaya; private int Biaya; @Override public void start(Stage stage) throws Exception { Scene scene = new Scene(new Group(), 500, 350); stage.setTitle("Toko Mandiri"); textDaftar.setFont(Font.font(18)); textKasir.setFont(Font.font(18)); KodeBarang.setFont(Font.font(18)); textBiaya.setFont(Font.font(18)); textJumlah.setFont(Font.font(18)); textTotalBayar.setFont(Font.font(18)); GridPane grid = new GridPane(); grid.setVgap(10); grid.setHgap(10); grid.setPadding(new Insets(10, 10, 10, 10)); grid.add(new Label("Menyediakan: "), 0, 0); Button buttong = new Button("Lihat"); grid.add(buttong, 1,0); buttong.setOnAction(this::buttonClicks); grid.add(new Label("Petugas: "), 0, 1); grid.add(comboBoxKasir, 1,1); grid.add(new Label("Id: "), 0, 2); grid.add(comboBoxBarang, 1,2); EventHandler event = new EventHandler () { public void handle(ActionEvent e) { if(comboBoxBarang.getValue() == "1") { NamaBarang.setText("Lolipop"); BiayaBarang.setText("Rp2500"); Biaya = 2500; } else if(comboBoxBarang.getValue() == "2") { NamaBarang.setText("Air Mineral"); BiayaBarang.setText("Rp3000"); Biaya = 3000; } else if(comboBoxBarang.getValue() == "3") { NamaBarang.setText("Chiki"); BiayaBarang.setText("Rp3000"); Biaya = 3000; } else if(comboBoxBarang.getValue() == "4") { NamaBarang.setText("Permen"); BiayaBarang.setText("Rp500"); Biaya = 500; } else if(comboBoxBarang.getValue() == "5") { NamaBarang.setText("Choclate"); BiayaBarang.setText("Rp3000"); Biaya = 3000; } } }; comboBoxBarang.setOnAction(event); grid.add(new Label("Nama Barang: "), 0, 3); grid.add(NamaBarang, 1,3); grid.add(new Label("Harga Barang: "), 0, 4); grid.add(BiayaBarang, 1,4); grid.add(new Label("Jumlah Barang: "), 0, 5); grid.add(textFieldJumlah, 1,5); EventHandler eventJumlah = new EventHandler () { public void handle(ActionEvent e) { TotalBiaya = Integer.parseInt(textFieldJumlah.getText()) * Biaya; TotalBiayaText.setText("Rp"+Integer.toString(TotalBiaya)); } }; textFieldJumlah.setOnAction(eventJumlah); grid.add(new Label("Total Bayar: "), 0, 6); grid.add(TotalBiayaText, 1,6); Text title=new Text("toko Mandiri"); title.setFont(Font.font(36)); Button buttons = new Button("cetak"); grid.add(buttons, 3,7); buttons.setOnAction(this::buttonClick); Group root = (Group)scene.getRoot(); root.getChildren().add(grid); stage.setScene(scene); stage.show(); buttong.setOnAction(new EventHandler () { @Override public void handle(ActionEvent ee){ Penjualan p = new Penjualan(); p.setVisible(true); } }); } public static void main(String[] args) { Application.launch(args); } private void buttonClicks(ActionEvent ee) { Penjualan p = new Penjualan(); } private void buttonClick(ActionEvent event) { Bukti c = new Bukti(NamaBarang, textFieldJumlah.getText(), TotalBiayaText); c.show(); } }
-penjualanimport java.awt.Component; import java.awt.Dimension; import java.awt.HeadlessException; import java.awt.Toolkit; import java.sql.Connection; import java.sql.DriverManager; import java.sql.Statement; import java.sql.ResultSet; import java.sql.SQLException; import javax.swing.JOptionPane; import javax.swing.table.DefaultTableModel; public class Penjualan extends javax.swing.JFrame { private ResultSet result; private Connection conek; private Statement state; public void koneksi() { try { Class.forName("com.mysql.jdbc.Driver"); conek=DriverManager.getConnection("jdbc:mysql://localhost:3306/daftarbarangg", "root", ""); state=conek.createStatement(); } catch (ClassNotFoundException | SQLException e) { JOptionPane.showMessageDialog(null, e); } } public Penjualan() { setTitle("Toko Mandiri"); Dimension screenSize = Toolkit.getDefaultToolkit().getScreenSize(); Dimension frameSize = getSize(); setLocation( (screenSize.width - frameSize.width) / 2, (screenSize.height - frameSize.height) / 2); Display(); koneksi(); tabel(); } private void empty() { id.setText(""); nama.setText(""); merk.setText(""); stok.setText(""); hrg.setText(""); id.requestFocus(); } public void tabel(){ DefaultTableModel x = new DefaultTableModel (); x.addColumn("ID Barang"); x.addColumn("Nama Barang"); x.addColumn("Merk"); x.addColumn("Stok"); x.addColumn("Harga"); tbl.setModel(x); try { result=state.executeQuery("select * from barang"); while (result.next()) { x.addRow(new Object[]{ result.getString("ID_Barang"), result.getString("Nama_Barang"), result.getString("Merk"), result.getString("Stok"), result.getString("Harga") } ); } }catch (SQLException e) { JOptionPane.showMessageDialog(null, e); } } private void Display() { id= new javax.swing.JTextField(); nama= new javax.swing.JTextField(); merk= new javax.swing.JTextField(); stok= new javax.swing.JTextField(); hrg= new javax.swing.JTextField(); Cari = new javax.swing.JButton(); Reset = new javax.swing.JButton(); Simpan = new javax.swing.JButton(); Hapus = new javax.swing.JButton(); jScrollPane1 = new javax.swing.JScrollPane(); tbl = new javax.swing.JTable(); Ganti = new javax.swing.JButton(); jLabel5 = new javax.swing.JLabel(); jLabel6 = new javax.swing.JLabel(); jLabel7 = new javax.swing.JLabel(); setDefaultCloseOperation(javax.swing.WindowConstants.EXIT_ON_CLOSE); jLabel1 = new javax.swing.JLabel(); jLabel2 = new javax.swing.JLabel(); jLabel3 = new javax.swing.JLabel(); jLabel4 = new javax.swing.JLabel(); jLabel8 = new javax.swing.JLabel(); jLabel1.setText("ID Barang"); jLabel2.setText("Nama Barang"); jLabel3.setText("Brand"); jLabel4.setText("Stok"); jLabel8.setText("Harga"); Simpan.setText("Simpan"); Simpan.addActionListener(new java.awt.event.ActionListener() { public void actionPerformed(java.awt.event.ActionEvent evt){ SimpanActionPerformed(evt); } } ); Hapus.setText("Hapus"); Hapus.addActionListener(new java.awt.event.ActionListener() { public void actionPerformed(java.awt.event.ActionEvent evt) { HapusActionPerformed(evt); } } ); tbl.setGridColor(new java.awt.Color(0, 0, 0)); jScrollPane1.setViewportView(tbl); Ganti.setText("Ganti"); Ganti.addActionListener(new java.awt.event.ActionListener() { public void actionPerformed(java.awt.event.ActionEvent evt) { GantiActionPerformed(evt); } } ); javax.swing.GroupLayout layout = new javax.swing.GroupLayout(getContentPane()); getContentPane().setLayout(layout); layout.setHorizontalGroup( layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING) .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, layout.createSequentialGroup() .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE) .addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING, false) .addComponent(jScrollPane1, javax.swing.GroupLayout.DEFAULT_SIZE, 554, Short.MAX_VALUE) .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING) .addGroup(layout.createSequentialGroup() .addComponent(Simpan) .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.UNRELATED) .addComponent(Ganti) .addGap(14, 14, 14) .addComponent(Hapus)) .addGroup(layout.createSequentialGroup() .addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.TRAILING, false) .addComponent(jLabel3, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE) .addComponent(jLabel1, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE) .addComponent(jLabel2, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE) .addComponent(jLabel4, javax.swing.GroupLayout.DEFAULT_SIZE, 43, Short.MAX_VALUE) .addComponent(jLabel8, javax.swing.GroupLayout.DEFAULT_SIZE, 43, Short.MAX_VALUE)) .addGap(18, 18, 18) .addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING, false) .addComponent(id, javax.swing.GroupLayout.DEFAULT_SIZE, 120, Short.MAX_VALUE) .addComponent(nama) .addComponent(merk) .addComponent(stok) .addComponent(hrg)) .addGap(18, 18, 18) .addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING, false) .addComponent(Reset, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE) .addComponent(Cari, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)) .addGap(0,0,0) .addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING) .addComponent(jLabel6, javax.swing.GroupLayout.PREFERRED_SIZE, 276, javax.swing.GroupLayout.PREFERRED_SIZE) .addComponent(jLabel7, javax.swing.GroupLayout.PREFERRED_SIZE, 276, javax.swing.GroupLayout.PREFERRED_SIZE) .addComponent(jLabel5, javax.swing.GroupLayout.PREFERRED_SIZE, 276, javax.swing.GroupLayout.PREFERRED_SIZE))))) .addContainerGap()) ); layout.setVerticalGroup( layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING) .addGroup(layout.createSequentialGroup() .addGap(17, 17, 17) .addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE) .addComponent(jLabel1) .addComponent(id, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE) .addComponent(Cari) .addComponent(jLabel5, javax.swing.GroupLayout.PREFERRED_SIZE, 23, javax.swing.GroupLayout.PREFERRED_SIZE)) .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED) .addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING) .addGroup(layout.createSequentialGroup() .addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE) .addComponent(jLabel2) .addComponent(nama, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE) .addComponent(Reset)) .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.UNRELATED) .addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE) .addComponent(jLabel3) .addComponent(merk, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)) .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.UNRELATED) .addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE) .addComponent(jLabel4) .addComponent(stok, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)) .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.UNRELATED) .addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE) .addComponent(jLabel8) .addComponent(hrg, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)) ) .addGroup(layout.createSequentialGroup() .addComponent(jLabel6, javax.swing.GroupLayout.PREFERRED_SIZE, 22, javax.swing.GroupLayout.PREFERRED_SIZE) .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED) .addComponent(jLabel7))) .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.UNRELATED) .addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE) .addComponent(Simpan) .addComponent(Hapus) .addComponent(Ganti)) .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.UNRELATED) .addComponent(jScrollPane1, javax.swing.GroupLayout.PREFERRED_SIZE, 229, javax.swing.GroupLayout.PREFERRED_SIZE) .addGap(24, 24, 24)) ); pack(); } private void ResetActionPerformed(java.awt.event.ActionEvent evt) { empty(); } private void GantiActionPerformed(java.awt.event.ActionEvent evt) { koneksi(); try { state.executeUpdate("update barang set" +" ID_Barang='"+id.getText()+"'," +" Nama_Barang='"+nama.getText()+"'," +" Merk='"+merk.getText()+"'," + "Stok='"+stok.getText()+"'," + "Harga='"+hrg.getText()+"'" + " where " + "ID_Barang='"+id.getText()+"'" ); empty(); tabel(); JOptionPane.showMessageDialog(null, "Data Terupdate"); }catch (SQLException | HeadlessException e) { JOptionPane.showMessageDialog(null, "Data Belum Lengkap : "+e); } } private void HapusActionPerformed(java.awt.event.ActionEvent evt) { koneksi(); try { state.executeUpdate("delete from barang where " + "ID_Barang='"+id.getText() +"'" ); empty(); tabel(); JOptionPane.showMessageDialog(null, "Berhasil Dihapus"); } catch (HeadlessException | SQLException e) { JOptionPane.showMessageDialog(null, "Gagal Dihapus/Koneksi Terputus "+e); } } private void SimpanActionPerformed(java.awt.event.ActionEvent evt) { koneksi(); try { state.executeUpdate("insert into barang values (" + "'" + id.getText()+"'," + "'" + nama.getText()+"'," + "'" + merk.getText()+"'," + "'" + stok.getText()+ "'," + "'" + hrg.getText()+ "')" ); empty(); tabel(); JOptionPane.showMessageDialog(null, "Data Tersimpan"); } catch (SQLException | HeadlessException e) { JOptionPane.showMessageDialog(null, "Data KurangLengkap"); } } public static void main(String args[]) { try { for (javax.swing.UIManager.LookAndFeelInfo info : javax.swing.UIManager.getInstalledLookAndFeels()) { if ("Nimbus".equals(info.getName())) { javax.swing.UIManager.setLookAndFeel(info.getClassName()); break; } } } catch (ClassNotFoundException ex) { java.util.logging.Logger.getLogger(Penjualan.class.getName()).log(java.util.logging.Level.SEVERE, null, ex); } catch (InstantiationException ex) { java.util.logging.Logger.getLogger(Penjualan.class.getName()).log(java.util.logging.Level.SEVERE, null, ex); } catch (IllegalAccessException ex) { java.util.logging.Logger.getLogger(Penjualan.class.getName()).log(java.util.logging.Level.SEVERE, null, ex); } catch (javax.swing.UnsupportedLookAndFeelException ex) { java.util.logging.Logger.getLogger(Penjualan.class.getName()).log(java.util.logging.Level.SEVERE, null, ex); } java.awt.EventQueue.invokeLater(new Runnable() { public void run() { new Penjualan().setVisible(true); } }); } private javax.swing.JButton Cari; private javax.swing.JButton Ganti; private javax.swing.JButton Hapus; private javax.swing.JButton Reset; private javax.swing.JButton Simpan; private javax.swing.JLabel jLabel1; private javax.swing.JLabel jLabel2; private javax.swing.JLabel jLabel3; private javax.swing.JLabel jLabel4; private javax.swing.JLabel jLabel5; private javax.swing.JLabel jLabel6; private javax.swing.JLabel jLabel7; private javax.swing.JLabel jLabel8; private javax.swing.JScrollPane jScrollPane1; private javax.swing.JTextField id; private javax.swing.JTextField nama; private javax.swing.JTextField merk; private javax.swing.JTable tbl; private javax.swing.JTextField stok; private javax.swing.JTextField hrg; }
2. Kasir menginput jumlah barang
-bukti-Databaseimport javafx.application.Application; import javafx.application.Platform; import javafx.event.ActionEvent; import javafx.event.EventHandler; import javafx.geometry.Insets; import javafx.geometry.Pos; import javafx.scene.Scene; import javafx.scene.control.*; import javafx.scene.layout.*; import javafx.scene.text.Font; import javafx.scene.text.Text; import javafx.stage.Stage; import javafx.scene.layout.StackPane; import javafx.collections.*; import javafx.scene.paint.*; import javafx.scene.text.*; import javafx.scene.Group; import java.util.Random; public class Bukti { private Text NamaBarang = new Text(""),TotalHargaText = new Text(""); private String jumlahBeli; public Bukti(Text namaBarang, String jumlah, Text TotalHarga) { NamaBarang = namaBarang; TotalHargaText = TotalHarga; jumlahBeli = jumlah; } public void show() { Stage stage = new Stage(); Scene scene = new Scene(new Group(), 500,500); stage.setTitle("Nota Pembelian"); GridPane grid = new GridPane(); grid.setVgap(10); grid.setHgap(15); grid.setPadding(new Insets(10, 10, 10, 10)); grid.add(new Label("Toko Mandiri"),0,0); grid.add(NamaBarang,0,1); grid.add(new Label(jumlahBeli),1,1); grid.add(new Label("Harga"),0,2); grid.add(TotalHargaText,1,2); Group root = (Group)scene.getRoot(); root.getChildren().add(grid); stage.setScene(scene); stage.show(); } }
import java.sql.*; import java.sql.DriverManager; import java.sql.Connection; import java.sql.SQLException; public class Database { static final String JDBC_DRIVER = "com.mysql.jdbc.Driver"; static final String DB_URL = "jdbc:mysql://localhost/"; static final String USER = "root"; static final String PASS = ""; public static void main(String[] args) { Connection conn = null; Statement stmt = null; try{ //STEP 2: Daftarkan JDBC driver Class.forName("com.mysql.jdbc.Driver"); //driver JDBC //STEP 3: Koneksi ke database System.out.println("Koneksi ke database..."); conn = DriverManager.getConnection("jdbc:mysql://localhost/","root", ""); //STEP 4: tambahkan ke Query System.out.println("Membuat database..."); stmt = conn.createStatement(); //STEP 5 : membuat database String sql = "CREATE DATABASE daftarbarangg"; stmt.executeUpdate(sql); System.out.println("Database berhasil dibuat..."); //membuat table pada database yang dibuat //STEP 1: mengkoneksikan database yang telah dibuat diatas System.out.println("Sedang koneksi ke database yang terpilih..."); conn = DriverManager.getConnection("jdbc:mysql://localhost/daftarbarangg","root" ,""); System.out.println("Koneksi ke database berhasil..."); //STEP 2: Tambahkan ke Query System.out.println("Membuat Table pada Database..."); stmt = conn.createStatement(); //STEP 3: Membuat Field-Field pada Table barang String tab = "CREATE TABLE barang " + "(ID_Barang INTEGER not NULL, " + //Field id barnang type Integer " Nama_Barang VARCHAR(255), " + //field nama barang type VARCHAR Lenght 255 " Merk VARCHAR(255), " + //field merk type Varchar lenght 255 " Stok INTEGER, " + //field stok type integez " Harga INTEGER, " +//field harga type integez " PRIMARY KEY ( ID_Barang ))"; //id barang sebagai Primary Key stmt.executeUpdate(tab); System.out.println("Table berhasil dibuat pada database yang terpilih..."); }catch(SQLException se){ //Menangani kesalahan untuk JDBC se.printStackTrace(); }catch(Exception e){ //Menangani kesalahan pada Class.forName e.printStackTrace(); }finally{ //akhir dari program yang digunakan try{ if(stmt!=null) stmt.close(); }catch(SQLException se2){ } try{ if(conn!=null) conn.close(); }catch(SQLException se){ se.printStackTrace(); } } System.out.println("Selesai"); } }
d.Langkah kerja
1. Run Program menampilka halaman yang diakses kasir
5. Klik lihat untuk menampilkan halaman admin mengedit, delete, menambah
Tidak ada komentar:
Posting Komentar