1 import java.awt.image.SampleModel;
\r
3 import FileOutputStream;
\r
6 * 11/19/04 1.0 moved to LGPL.
\r
7 * 29/01/00 Initial version. mdm@techie.com
\r
8 *-----------------------------------------------------------------------
\r
9 * This program is free software; you can redistribute it and/or modify
\r
10 * it under the terms of the GNU Library General Public License as published
\r
11 * by the Free Software Foundation; either version 2 of the License, or
\r
12 * (at your option) any later version.
\r
14 * This program is distributed in the hope that it will be useful,
\r
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
\r
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
\r
17 * GNU Library General Public License for more details.
\r
19 * You should have received a copy of the GNU Library General Public
\r
20 * License along with this program; if not, write to the Free Software
\r
21 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
\r
22 *----------------------------------------------------------------------
\r
26 * The <code>Player</code> class implements a simple player for playback of an
\r
27 * MPEG audio stream.
\r
29 * @author Mat McGowan
\r
33 // REVIEW: the audio device should not be opened until the
\r
34 // first MPEG audio frame has been decoded.
\r
35 @LATTICE("B<DE,DE<ST,DE<HE,HE<ST,ST<FR")
\r
36 public class Player {
\r
38 * The current frame number.
\r
41 private int frame = 0;
\r
44 * The MPEG audio bitstream.
\r
46 // private Bitstream bitstream;
\r
49 * The MPEG audio decoder.
\r
51 /* final */@LOC("DE")
\r
52 private Decoder decoder;
\r
55 * The AudioDevice the audio samples are written to.
\r
57 // private AudioDevice audio;
\r
60 * Has the player been closed?
\r
63 private boolean closed = false;
\r
66 * Has the player played back all frames from the stream?
\r
69 private boolean complete = false;
\r
72 private int lastPosition = 0;
\r
75 * Creates a new <code>Player</code> instance.
\r
77 public Player() throws JavaLayerException {
\r
81 public Player(AudioDevice device) throws JavaLayerException {
\r
82 // bitstream = new Bitstream(stream);
\r
83 decoder = new Decoder();
\r
85 // if (device!=null)
\r
91 // FactoryRegistry r = FactoryRegistry.systemRegistry();
\r
92 // audio = r.createAudioDevice();
\r
95 device.open(decoder);
\r
98 public void play() throws JavaLayerException {
\r
99 play(Integer.MAX_VALUE);
\r
103 * Plays a number of MPEG audio frames.
\r
106 * The number of frames to play.
\r
107 * @return true if the last frame was played, or false if there are more
\r
110 @LATTICE("OUT<THIS,THIS<IN,IN*,THISLOC=THIS")
\r
112 public boolean play(@LOC("IN") int frames) throws JavaLayerException {
\r
113 @LOC("OUT") boolean ret = true;
\r
115 // initialization before ssjava loop
\r
116 @LOC("THIS,Player.FR") boolean init = true;
\r
117 @LOC("THIS,Player.ST") Header h = BitstreamWrapper.readFrame();
\r
120 @LOC("IN") int count = 0;
\r
121 SSJAVA: while (count++ < 2147483646) {
\r
125 ret = decodeFrame(init, h);
\r
129 h = BitstreamWrapper.readFrame();
\r
133 * if (!ret) { // last frame, ensure all data flushed to the audio device.
\r
134 * AudioDevice out = audio; if (out!=null) { out.flush(); synchronized
\r
135 * (this) { complete = (!closed); close(); } } }
\r
141 * Cloases this player. Any audio currently playing is stopped immediately.
\r
144 public synchronized void close() {
\r
146 * AudioDevice out = audio; if (out!=null) { closed = true; audio = null; //
\r
147 * this may fail, so ensure object state is set up before // calling this
\r
148 * method. out.close(); lastPosition = out.getPosition(); try {
\r
149 * bitstream.close(); } catch (BitstreamException ex) { } }
\r
154 * Returns the completed status of this player.
\r
156 * @return true if all available MPEG audio frames have been decoded, or false
\r
159 public synchronized boolean isComplete() {
\r
164 * Retrieves the position in milliseconds of the current audio sample being
\r
165 * played. This method delegates to the <code>
\r
166 * AudioDevice</code> that is used by this player to sound the decoded audio
\r
169 public int getPosition() {
\r
170 // int position = lastPosition;
\r
172 // AudioDevice out = audio;
\r
175 // position = out.getPosition();
\r
177 // return position;
\r
182 * Decodes a single frame.
\r
184 * @return true if there are no more frames to decode, false otherwise.
\r
186 @LATTICE("C<THIS,O<THIS,THIS<IN,C*,THISLOC=THIS,RETURNLOC=O,GLOBALLOC=THIS")
\r
187 protected boolean decodeFrame(@LOC("THIS,Player.FR") boolean init, @LOC("THIS,Player.ST") Header h)
\r
188 throws JavaLayerException {
\r
190 // AudioDevice out = audio;
\r
194 // Header h = bitstream.readFrame();
\r
200 // @LOC("O") SampleBuffer output = (SampleBuffer) decoder.decodeFrame(h);
\r
201 decoder.decodeFrame(h);
\r
204 @LOC("C") int sum = 0;
\r
205 @LOC("C") short[] outbuf = SampleBufferWrapper.getBuffer();
\r
206 // short[] outbuf = output.getBuffer();
\r
207 TERMINATE: for (@LOC("C") int i = 0; i < SampleBufferWrapper.getBufferLength(); i++) {
\r
208 // System.out.println(outbuf[i]);
\r
211 System.out.println(sum);
\r
214 // synchronized (this)
\r
219 // out.write(output.getBuffer(), 0, output.getBufferLength());
\r
223 // bitstream.closeFrame();
\r
224 } catch (RuntimeException ex) {
\r
225 throw new JavaLayerException("Exception decoding audio frame", ex);
\r
228 * catch (IOException ex) {
\r
229 * System.out.println("exception decoding audio frame: "+ex); return false;
\r
230 * } catch (BitstreamException bitex) {
\r
231 * System.out.println("exception decoding audio frame: "+bitex); return
\r
232 * false; } catch (DecoderException decex) {
\r
233 * System.out.println("exception decoding audio frame: "+decex); return
\r