diff --git a/MusicPlayer/build.xml b/MusicPlayer/build.xml
new file mode 100644
index 0000000..ce9d744
--- /dev/null
+++ b/MusicPlayer/build.xml
@@ -0,0 +1,73 @@
+
+
+
+
+
+
+
+
+
+
+ Builds, tests, and runs the project MusicPlayer.
+
+
+
diff --git a/MusicPlayer/build/classes/.netbeans_automatic_build b/MusicPlayer/build/classes/.netbeans_automatic_build
new file mode 100644
index 0000000..e69de29
diff --git a/MusicPlayer/build/classes/.netbeans_update_resources b/MusicPlayer/build/classes/.netbeans_update_resources
new file mode 100644
index 0000000..e69de29
diff --git a/MusicPlayer/build/classes/musicplayer/Controller.class b/MusicPlayer/build/classes/musicplayer/Controller.class
new file mode 100644
index 0000000..d4f47b5
Binary files /dev/null and b/MusicPlayer/build/classes/musicplayer/Controller.class differ
diff --git a/MusicPlayer/build/classes/musicplayer/Driver.class b/MusicPlayer/build/classes/musicplayer/Driver.class
new file mode 100644
index 0000000..716845e
Binary files /dev/null and b/MusicPlayer/build/classes/musicplayer/Driver.class differ
diff --git a/MusicPlayer/build/classes/musicplayer/PlayerGui$1.class b/MusicPlayer/build/classes/musicplayer/PlayerGui$1.class
new file mode 100644
index 0000000..900bcd6
Binary files /dev/null and b/MusicPlayer/build/classes/musicplayer/PlayerGui$1.class differ
diff --git a/MusicPlayer/build/classes/musicplayer/PlayerGui$2.class b/MusicPlayer/build/classes/musicplayer/PlayerGui$2.class
new file mode 100644
index 0000000..3905167
Binary files /dev/null and b/MusicPlayer/build/classes/musicplayer/PlayerGui$2.class differ
diff --git a/MusicPlayer/build/classes/musicplayer/PlayerGui.class b/MusicPlayer/build/classes/musicplayer/PlayerGui.class
new file mode 100644
index 0000000..558c8c6
Binary files /dev/null and b/MusicPlayer/build/classes/musicplayer/PlayerGui.class differ
diff --git a/MusicPlayer/build/classes/musicplayer/PlayerGui.form b/MusicPlayer/build/classes/musicplayer/PlayerGui.form
new file mode 100644
index 0000000..45ccba8
--- /dev/null
+++ b/MusicPlayer/build/classes/musicplayer/PlayerGui.form
@@ -0,0 +1,148 @@
+
+
+
diff --git a/MusicPlayer/build/classes/musicplayer/application$ThreadPlayer.class b/MusicPlayer/build/classes/musicplayer/application$ThreadPlayer.class
new file mode 100644
index 0000000..530b0cd
Binary files /dev/null and b/MusicPlayer/build/classes/musicplayer/application$ThreadPlayer.class differ
diff --git a/MusicPlayer/build/classes/musicplayer/application.class b/MusicPlayer/build/classes/musicplayer/application.class
new file mode 100644
index 0000000..974411a
Binary files /dev/null and b/MusicPlayer/build/classes/musicplayer/application.class differ
diff --git a/MusicPlayer/manifest.mf b/MusicPlayer/manifest.mf
new file mode 100644
index 0000000..328e8e5
--- /dev/null
+++ b/MusicPlayer/manifest.mf
@@ -0,0 +1,3 @@
+Manifest-Version: 1.0
+X-COMMENT: Main-Class will be added automatically by build
+
diff --git a/MusicPlayer/nbproject/build-impl.xml b/MusicPlayer/nbproject/build-impl.xml
new file mode 100644
index 0000000..400c05c
--- /dev/null
+++ b/MusicPlayer/nbproject/build-impl.xml
@@ -0,0 +1,1419 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Must set src.dir
+ Must set test.src.dir
+ Must set build.dir
+ Must set dist.dir
+ Must set build.classes.dir
+ Must set dist.javadoc.dir
+ Must set build.test.classes.dir
+ Must set build.test.results.dir
+ Must set build.classes.excludes
+ Must set dist.jar
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Must set javac.includes
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ No tests executed.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Must set JVM to use for profiling in profiler.info.jvm
+ Must set profiler agent JVM arguments in profiler.info.jvmargs.agent
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Must select some files in the IDE or set javac.includes
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ To run this application from the command line without Ant, try:
+
+ java -jar "${dist.jar.resolved}"
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Must select one file in the IDE or set run.class
+
+
+
+ Must select one file in the IDE or set run.class
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Must select one file in the IDE or set debug.class
+
+
+
+
+ Must select one file in the IDE or set debug.class
+
+
+
+
+ Must set fix.includes
+
+
+
+
+
+
+
+
+
+ This target only works when run from inside the NetBeans IDE.
+
+
+
+
+
+
+
+
+ Must select one file in the IDE or set profile.class
+ This target only works when run from inside the NetBeans IDE.
+
+
+
+
+
+
+
+
+ This target only works when run from inside the NetBeans IDE.
+
+
+
+
+
+
+
+
+
+
+
+
+ This target only works when run from inside the NetBeans IDE.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Must select one file in the IDE or set run.class
+
+
+
+
+
+ Must select some files in the IDE or set test.includes
+
+
+
+
+ Must select one file in the IDE or set run.class
+
+
+
+
+ Must select one file in the IDE or set applet.url
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Must select some files in the IDE or set javac.includes
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Some tests failed; see details above.
+
+
+
+
+
+
+
+
+ Must select some files in the IDE or set test.includes
+
+
+
+ Some tests failed; see details above.
+
+
+
+ Must select some files in the IDE or set test.class
+ Must select some method in the IDE or set test.method
+
+
+
+ Some tests failed; see details above.
+
+
+
+
+ Must select one file in the IDE or set test.class
+
+
+
+ Must select one file in the IDE or set test.class
+ Must select some method in the IDE or set test.method
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Must select one file in the IDE or set applet.url
+
+
+
+
+
+
+
+
+ Must select one file in the IDE or set applet.url
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/MusicPlayer/nbproject/genfiles.properties b/MusicPlayer/nbproject/genfiles.properties
new file mode 100644
index 0000000..ddf7ee4
--- /dev/null
+++ b/MusicPlayer/nbproject/genfiles.properties
@@ -0,0 +1,8 @@
+build.xml.data.CRC32=6ea9cd52
+build.xml.script.CRC32=1fe043b5
+build.xml.stylesheet.CRC32=8064a381@1.79.1.48
+# This file is used by a NetBeans-based IDE to track changes in generated files such as build-impl.xml.
+# Do not edit this file. You may delete it but then the IDE will never regenerate such files for you.
+nbproject/build-impl.xml.data.CRC32=6ea9cd52
+nbproject/build-impl.xml.script.CRC32=47c5a6bd
+nbproject/build-impl.xml.stylesheet.CRC32=05530350@1.79.1.48
diff --git a/MusicPlayer/nbproject/private/config.properties b/MusicPlayer/nbproject/private/config.properties
new file mode 100644
index 0000000..e69de29
diff --git a/MusicPlayer/nbproject/private/private.properties b/MusicPlayer/nbproject/private/private.properties
new file mode 100644
index 0000000..729e907
--- /dev/null
+++ b/MusicPlayer/nbproject/private/private.properties
@@ -0,0 +1,6 @@
+compile.on.save=true
+do.depend=false
+do.jar=true
+javac.debug=true
+javadoc.preview=true
+user.properties.file=C:\\Users\\Asus\\AppData\\Roaming\\NetBeans\\8.1\\build.properties
diff --git a/MusicPlayer/nbproject/private/private.xml b/MusicPlayer/nbproject/private/private.xml
new file mode 100644
index 0000000..6cb6f41
--- /dev/null
+++ b/MusicPlayer/nbproject/private/private.xml
@@ -0,0 +1,11 @@
+
+
+
+
+
+ file:/C:/Users/Asus/Google%20Drive/Telkom%20University😊/4th/APPL/MusicPlayer/src/musicplayer/application.java
+ file:/C:/Users/Asus/Google%20Drive/Telkom%20University😊/4th/APPL/MusicPlayer/src/musicplayer/Controller.java
+ file:/C:/Users/Asus/Google%20Drive/Telkom%20University😊/4th/APPL/MusicPlayer/src/musicplayer/Driver.java
+
+
+
diff --git a/MusicPlayer/nbproject/project.properties b/MusicPlayer/nbproject/project.properties
new file mode 100644
index 0000000..32f9c99
--- /dev/null
+++ b/MusicPlayer/nbproject/project.properties
@@ -0,0 +1,78 @@
+annotation.processing.enabled=true
+annotation.processing.enabled.in.editor=false
+annotation.processing.processors.list=
+annotation.processing.run.all.processors=true
+annotation.processing.source.output=${build.generated.sources.dir}/ap-source-output
+application.title=MusicPlayer
+application.vendor=Asus
+build.classes.dir=${build.dir}/classes
+build.classes.excludes=**/*.java,**/*.form
+# This directory is removed when the project is cleaned:
+build.dir=build
+build.generated.dir=${build.dir}/generated
+build.generated.sources.dir=${build.dir}/generated-sources
+# Only compile against the classpath explicitly listed here:
+build.sysclasspath=ignore
+build.test.classes.dir=${build.dir}/test/classes
+build.test.results.dir=${build.dir}/test/results
+# Uncomment to specify the preferred debugger connection transport:
+#debug.transport=dt_socket
+debug.classpath=\
+ ${run.classpath}
+debug.test.classpath=\
+ ${run.test.classpath}
+# Files in build.classes.dir which should be excluded from distribution jar
+dist.archive.excludes=
+# This directory is removed when the project is cleaned:
+dist.dir=dist
+dist.jar=${dist.dir}/MusicPlayer.jar
+dist.javadoc.dir=${dist.dir}/javadoc
+endorsed.classpath=
+excludes=
+file.reference.jl1.0.1.jar=C:\\Users\\Asus\\Downloads\\JLayer1.0.1\\jl1.0.1.jar
+includes=**
+jar.compress=false
+javac.classpath=\
+ ${file.reference.jl1.0.1.jar}
+# Space-separated list of extra javac options
+javac.compilerargs=
+javac.deprecation=false
+javac.external.vm=true
+javac.processorpath=\
+ ${javac.classpath}
+javac.source=1.8
+javac.target=1.8
+javac.test.classpath=\
+ ${javac.classpath}:\
+ ${build.classes.dir}
+javac.test.processorpath=\
+ ${javac.test.classpath}
+javadoc.additionalparam=
+javadoc.author=false
+javadoc.encoding=${source.encoding}
+javadoc.noindex=false
+javadoc.nonavbar=false
+javadoc.notree=false
+javadoc.private=false
+javadoc.splitindex=true
+javadoc.use=true
+javadoc.version=false
+javadoc.windowtitle=
+main.class=musicplayer.Driver
+manifest.file=manifest.mf
+meta.inf.dir=${src.dir}/META-INF
+mkdist.disabled=false
+platform.active=default_platform
+run.classpath=\
+ ${javac.classpath}:\
+ ${build.classes.dir}
+# Space-separated list of JVM arguments used when running the project.
+# You may also define separate properties like run-sys-prop.name=value instead of -Dname=value.
+# To set system properties for unit tests define test-sys-prop.name=value:
+run.jvmargs=
+run.test.classpath=\
+ ${javac.test.classpath}:\
+ ${build.test.classes.dir}
+source.encoding=UTF-8
+src.dir=src
+test.src.dir=test
diff --git a/MusicPlayer/nbproject/project.xml b/MusicPlayer/nbproject/project.xml
new file mode 100644
index 0000000..858374d
--- /dev/null
+++ b/MusicPlayer/nbproject/project.xml
@@ -0,0 +1,15 @@
+
+
+ org.netbeans.modules.java.j2seproject
+
+
+ MusicPlayer
+
+
+
+
+
+
+
+
+
diff --git a/MusicPlayer/src/musicplayer/Controller.java b/MusicPlayer/src/musicplayer/Controller.java
new file mode 100644
index 0000000..bcbf3b6
--- /dev/null
+++ b/MusicPlayer/src/musicplayer/Controller.java
@@ -0,0 +1,88 @@
+/*
+ * To change this license header, choose License Headers in Project Properties.
+ * To change this template file, choose Tools | Templates
+ * and open the template in the editor.
+ */
+
+//Elvaretta Dian Detiana Yucky - 1301154446 - IF 3912
+
+package musicplayer;
+
+import java.awt.event.ActionEvent;
+import java.awt.event.ActionListener;
+import java.awt.event.ActionListener;
+import javax.swing.JOptionPane;
+import javax.swing.JFileChooser;
+import javax.swing.filechooser.FileNameExtensionFilter;
+
+/**
+ *
+ * @author Asus
+ */
+public class Controller implements ActionListener{
+ private application app;
+ private PlayerGui view;
+
+ public Controller()
+ {
+ app = new application();
+ view = new PlayerGui();
+ view.setVisible(true);
+ view.addListener(this);
+ view.setListMusic(app.getMusicList());
+ }
+
+ @Override
+ public void actionPerformed(ActionEvent ae) {
+ Object source = ae.getSource();
+
+ try
+ {
+ if(source.equals(view.getBtnAdd()))
+ {
+ JFileChooser fc = new JFileChooser();
+ FileNameExtensionFilter filter = new FileNameExtensionFilter("mp3 Files", "mp3", "mp3");
+ fc.setFileFilter(filter);
+ int returnVal = fc.showOpenDialog(view);
+
+ if(returnVal == JFileChooser.APPROVE_OPTION){
+ String path = fc.getSelectedFile().getAbsolutePath();
+ app.addMusic(path);
+ view.setListMusic(app.getMusicList());
+ }
+ }
+ else if(source.equals(view.getBtnDelete()))
+ {
+ int selected = view.getSelectedMusic();
+ app.removeMusic(selected);
+ view.setListMusic(app.getMusicList());
+ }
+ else if(source.equals(view.getBtnPlay()))
+ {
+ int selected = view.getSelectedMusic();
+ app.stop();
+ app.play(selected);
+ view.setTxFieldPlaying(app.getNowPlayed());
+ }
+ else if(source.equals(view.getBtnStop()))
+ {
+ app.stop();
+ view.setTxFieldPlaying("");
+ }
+ else if (source.equals(view.getBtnNext()))
+ {
+ app.next();
+ view.setTxFieldPlaying(app.getNowPlayed());
+ }
+ else if(source.equals(view.getBtnPrev()))
+ {
+ app.prev();
+ view.setTxFieldPlaying(app.getNowPlayed());
+ }
+ }
+ catch (Exception e)
+ {
+ JOptionPane.showMessageDialog(view, e.getMessage());
+ }
+}
+}
diff --git a/MusicPlayer/src/musicplayer/Driver.java b/MusicPlayer/src/musicplayer/Driver.java
new file mode 100644
index 0000000..705cc1b
--- /dev/null
+++ b/MusicPlayer/src/musicplayer/Driver.java
@@ -0,0 +1,18 @@
+/*
+ * To change this license header, choose License Headers in Project Properties.
+ * To change this template file, choose Tools | Templates
+ * and open the template in the editor.
+ */
+
+// Elvaretta Dian Detiana Yucky - 1301154446 - IF 3912
+package musicplayer;
+
+/**
+ *
+ * @author Asus
+ */
+public class Driver {
+ public static void main(String[] args) {
+ Controller c = new Controller();
+}
+}
diff --git a/MusicPlayer/src/musicplayer/PlayerGui.form b/MusicPlayer/src/musicplayer/PlayerGui.form
new file mode 100644
index 0000000..45ccba8
--- /dev/null
+++ b/MusicPlayer/src/musicplayer/PlayerGui.form
@@ -0,0 +1,148 @@
+
+
+
diff --git a/MusicPlayer/src/musicplayer/PlayerGui.java b/MusicPlayer/src/musicplayer/PlayerGui.java
new file mode 100644
index 0000000..63062b0
--- /dev/null
+++ b/MusicPlayer/src/musicplayer/PlayerGui.java
@@ -0,0 +1,201 @@
+/*
+ * To change this license header, choose License Headers in Project Properties.
+ * To change this template file, choose Tools | Templates
+ * and open the template in the editor.
+ */
+
+// Elvaretta Dian Detiana Yucky - 1301154446 - IF 3912
+package musicplayer;
+
+import java.awt.event.ActionListener;
+
+/**
+ *
+ * @author Asus
+ */
+public class PlayerGui extends javax.swing.JFrame {
+
+ /**
+ * Creates new form PlayerGui
+ */
+ public PlayerGui() {
+ initComponents();
+ }
+
+ /**
+ * This method is called from within the constructor to initialize the form.
+ * WARNING: Do NOT modify this code. The content of this method is always
+ * regenerated by the Form Editor.
+ */
+ @SuppressWarnings("unchecked")
+ // //GEN-BEGIN:initComponents
+ private void initComponents() {
+
+ jScrollPane1 = new javax.swing.JScrollPane();
+ listMusic = new javax.swing.JList<>();
+ txFieldPlaying = new javax.swing.JTextField();
+ NowPlaying = new javax.swing.JLabel();
+ btnAdd = new javax.swing.JButton();
+ btnDelete = new javax.swing.JButton();
+ btnPrev = new javax.swing.JButton();
+ btnPlay = new javax.swing.JButton();
+ btnStop = new javax.swing.JButton();
+ btnNext = new javax.swing.JButton();
+
+ setDefaultCloseOperation(javax.swing.WindowConstants.EXIT_ON_CLOSE);
+
+ listMusic.setModel(new javax.swing.AbstractListModel() {
+ String[] strings = { "Item 1", "Item 2", "Item 3", "Item 4", "Item 5" };
+ public int getSize() { return strings.length; }
+ public String getElementAt(int i) { return strings[i]; }
+ });
+ jScrollPane1.setViewportView(listMusic);
+
+ txFieldPlaying.setEditable(false);
+
+ NowPlaying.setText("Now Playing");
+
+ btnAdd.setText("Add");
+
+ btnDelete.setText("Delete");
+ btnDelete.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ btnDeleteActionPerformed(evt);
+ }
+ });
+
+ btnPrev.setText("<<");
+
+ btnPlay.setText("Play");
+
+ btnStop.setText("Stop");
+
+ btnNext.setText(">>");
+
+ javax.swing.GroupLayout layout = new javax.swing.GroupLayout(getContentPane());
+ getContentPane().setLayout(layout);
+ layout.setHorizontalGroup(
+ layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(layout.createSequentialGroup()
+ .addContainerGap()
+ .addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addComponent(jScrollPane1)
+ .addGroup(layout.createSequentialGroup()
+ .addComponent(NowPlaying)
+ .addGap(18, 18, 18)
+ .addComponent(txFieldPlaying))
+ .addGroup(layout.createSequentialGroup()
+ .addComponent(btnAdd, javax.swing.GroupLayout.PREFERRED_SIZE, 69, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addGap(18, 18, 18)
+ .addComponent(btnDelete)
+ .addGap(18, 18, 18)
+ .addComponent(btnPrev)
+ .addGap(24, 24, 24)
+ .addComponent(btnPlay)
+ .addGap(18, 18, 18)
+ .addComponent(btnStop)
+ .addGap(18, 18, 18)
+ .addComponent(btnNext)
+ .addGap(0, 9, Short.MAX_VALUE)))
+ .addContainerGap())
+ );
+ layout.setVerticalGroup(
+ layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(layout.createSequentialGroup()
+ .addContainerGap()
+ .addComponent(jScrollPane1, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addGap(18, 18, 18)
+ .addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(txFieldPlaying, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(NowPlaying))
+ .addGap(18, 18, 18)
+ .addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(btnAdd)
+ .addComponent(btnDelete)
+ .addComponent(btnPrev)
+ .addComponent(btnPlay)
+ .addComponent(btnStop)
+ .addComponent(btnNext))
+ .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
+ );
+
+ pack();
+ }// //GEN-END:initComponents
+
+ private void btnDeleteActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_btnDeleteActionPerformed
+ // TODO add your handling code here:
+ }//GEN-LAST:event_btnDeleteActionPerformed
+
+ public Object getBtnAdd()
+ {
+ return btnAdd;
+ }
+
+ public Object getBtnDelete()
+ {
+ return btnDelete;
+ }
+
+ public Object getBtnNext()
+ {
+ return btnNext;
+ }
+
+ public Object getBtnPlay()
+ {
+ return btnPlay;
+ }
+
+ public Object getBtnPrev()
+ {
+ return btnPrev;
+ }
+
+ public Object getBtnStop()
+ {
+ return btnStop;
+ }
+
+ public void setListMusic(String[] musicList)
+ {
+ listMusic.setListData(musicList);
+ }
+
+ public void setTxFieldPlaying (String filename)
+ {
+ txFieldPlaying.setText(filename);
+ }
+
+ public int getSelectedMusic()
+ {
+ if(listMusic.getSelectedIndex() == -1)
+ {
+ throw new IllegalStateException("Please select any music");
+ }
+ return listMusic.getSelectedIndex();
+ }
+
+ public void addListener(ActionListener e)
+ {
+ btnAdd.addActionListener(e);
+ btnDelete.addActionListener(e);
+ btnNext.addActionListener(e);
+ btnPlay.addActionListener(e);
+ btnPrev.addActionListener(e);
+ btnStop.addActionListener(e);
+ }
+
+
+ // Variables declaration - do not modify//GEN-BEGIN:variables
+ private javax.swing.JLabel NowPlaying;
+ private javax.swing.JButton btnAdd;
+ private javax.swing.JButton btnDelete;
+ private javax.swing.JButton btnNext;
+ private javax.swing.JButton btnPlay;
+ private javax.swing.JButton btnPrev;
+ private javax.swing.JButton btnStop;
+ private javax.swing.JScrollPane jScrollPane1;
+ private javax.swing.JList listMusic;
+ private javax.swing.JTextField txFieldPlaying;
+ // End of variables declaration//GEN-END:variables
+}
diff --git a/MusicPlayer/src/musicplayer/application.java b/MusicPlayer/src/musicplayer/application.java
new file mode 100644
index 0000000..47c7773
--- /dev/null
+++ b/MusicPlayer/src/musicplayer/application.java
@@ -0,0 +1,112 @@
+/*
+ * To change this license header, choose License Headers in Project Properties.
+ * To change this template file, choose Tools | Templates
+ * and open the template in the editor.
+ */
+
+// Elvaretta Dian Detiana Yucky - 1301154446 - IF 3912
+
+package musicplayer;
+
+/**
+ *
+ * @author Asus
+ */
+
+import java.io.FileInputStream;
+import java.io.FileNotFoundException;
+import java.util.ArrayList;
+import javazoom.jl.decoder.JavaLayerException;
+import javazoom.jl.player.Player;
+
+public class application {
+
+ private ArrayList musicList;
+ private ThreadPlayer thread;
+ private int nowPlaying;
+
+ public application()
+ {
+ musicList = new ArrayList();
+ }
+
+ public void addMusic (String path)
+ {
+ musicList.add(path);
+ }
+
+ public String[] getMusicList()
+ {
+ return (String[]) musicList.toArray(new String[0]);
+ }
+
+ public String getNowPlayed()
+ {
+ return musicList.get(nowPlaying);
+ }
+
+ public void removeMusic(int i)
+ {
+ musicList.remove(i);
+ }
+
+ public void play(int i)
+ {
+ nowPlaying = i;
+ String filepath = musicList.get(i);
+ thread = new ThreadPlayer(filepath);
+ thread.start();
+ }
+
+ public void stop(){
+ if(thread != null){
+ thread.stop();
+ }
+ }
+
+ public void next(){
+ if(nowPlaying < musicList.size() - 1){
+ stop();
+ play(nowPlaying + 1);
+ }
+ }
+
+ public void prev(){
+ if(nowPlaying != 0){
+ stop();
+ play(nowPlaying - 1);
+ }
+ }
+
+ private class ThreadPlayer extends Thread {
+ private String filepath;
+ private Player player;
+
+ public ThreadPlayer (String filepath)
+ {
+ this.filepath = filepath;
+ }
+
+ @Override
+ public void run()
+ {
+ try
+ {
+ FileInputStream fis = new FileInputStream(filepath);
+ player = new Player(fis);
+ player.play();
+ }
+ catch (FileNotFoundException exc)
+ {
+ throw new IllegalStateException ("File " + filepath + " not Found");
+ }
+ catch (JavaLayerException exc)
+ {
+ throw new IllegalStateException ("ERROR while playing file ");
+ }
+ }
+ }
+}
+
+
+