FileDocCategorySizeDatePackage
RecordControl.javaAPI DocphoneME MR2 API (J2ME)10160Wed May 02 16:47:14 BST 2007javax.microedition.media.control

RecordControl

public interface RecordControl implements javax.microedition.media.Control
RecordControl controls the recording of media from a Player. RecordControl records what's currently being played by the Player.

Example

try {
// Create a Player that captures live audio.
Player p = Manager.createPlayer("capture://audio");
p.realize();
// Get the RecordControl, set the record stream,
// start the Player and record for 5 seconds.
RecordControl rc = (RecordControl)p.getControl("RecordControl");
ByteArrayOutputStream output = new ByteArrayOutputStream();
rc.setRecordStream(output);
rc.startRecord();
p.start();
Thread.currentThread().sleep(5000);
rc.commit();
p.close();
} catch (IOException ioe) {
} catch (MediaException me) {
} catch (InterruptedException ie) { }
see
javax.microedition.media.Player

Fields Summary
Constructors Summary
Methods Summary
public voidcommit()
Complete the current recording.

If the recording is in progress, commit will implicitly call stopRecord.

To record again after commit has been called, setRecordLocation or setRecordStream must be called.

exception
IOException Thrown if an I/O error occurs during commit. The current recording is not valid. To record again, setRecordLocation or setRecordStream must be called.

public java.lang.StringgetContentType()
Return the content type of the recorded media. The content type is given in the content type syntax.

return
The content type of the media.

public voidreset()
Erase the current recording.

If the recording is in progress, reset will implicitly call stopRecord.

Calling reset after commit will have no effect on the current recording.

If the Player that is associated with this RecordControl is closed, reset will be called implicitly.

exception
IOException Thrown if the current recording cannot be erased. The current recording is not valid. To record again, setRecordLocation or setRecordStream must be called.

public voidsetRecordLocation(java.lang.String locator)
Set the output location where the data will be recorded.

Whenever possible, the recording format is the same as the format of the input media. In some cases, the recording format may be different from the input format if the input format is not a recordable format, e.g. streaming media data. An application can query the recorded format by calling the getContentType method.

param
locator The locator specifying where the recorded media will be saved. The locator must be specified as a URL.
exception
IllegalStateException Thrown if one of the following conditions is true:
  • startRecord has been called and commit has not been called.
  • setRecordStream has been called and commit has not been called.
exception
IllegalArgumentException Thrown if locator is null.
exception
IOException Thrown if protocol is valid but the media cannot be created at the specified location.
exception
MediaException Thrown if the locator is not in URL syntax or it specifies a protocol that is not supported.
exception
SecurityException Thrown if the caller does not have security permission to set the record location.

public intsetRecordSizeLimit(int size)
Set the record size limit. This limits the size of the recorded media to the number of bytes specified.

When recording is in progress, commit will be called implicitly in the following cases:

  • Record size limit is reached
  • If the requested size is less than the already recorded size
  • No more space is available.

Once a record size limit has been set, it will remain so for future recordings until it is changed by another setRecordSizeLimit call.

To remove the record size limit, set it to Integer.MAX_VALUE. By default, the record size limit is not set.

Only positive values can be set. Zero or negative values are invalid and an IllegalArgumentException will be thrown.

param
size The record size limit in number of bytes.
return
The actual size limit set.
exception
IllegalArgumentException Thrown if the given size is invalid.
exception
MediaException Thrown if setting the record size limit is not supported.

public voidsetRecordStream(java.io.OutputStream stream)
Set the output stream where the data will be recorded.

Whenever possible, the recording format is the same as the format of the input media. In some cases, the recording format may be different from the input format if the input format is not a recordable format, e.g. streaming media data. An application can query the recorded format by calling the getContentType method.

param
stream The output stream where the data will be recorded.
exception
IllegalStateException Thrown if one of the following conditions is true:
  • startRecord has been called and commit has not been called.
  • setRecordLocation has been called and commit has not been called.
exception
IllegalArgumentException Thrown if stream is null.
exception
SecurityException Thrown if the caller does not have security permission to set the record stream.

public voidstartRecord()
Start recording the media.

If the Player is already started, startRecord will immediately start the recording. If the Player is not already started, startRecord will not record any media. It will put the recording in a "standby" mode. As soon as the Player is started, the recording will start right away.

If startRecord is called when the recording has already started, it will be ignored.

When startRecord returns, the recording has started and a RECORD_STARTED event will be delivered through the PlayerListener.

If an error occurs while recording is in progress, RECORD_ERROR event will be delivered via the PlayerListener.

exception
IllegalStateException Thrown if any of the following conditions is true:
  • if setRecordLocation or setRecordStream has not been called for the first time.
  • If commit has been called and setRecordLocation or setRecordStream has not been called.

public voidstopRecord()
Stop recording the media. stopRecord will not automatically stop the Player. It only stops the recording.

Stopping the Player does not imply a stopRecord. Rather, the recording will be put into a "standby" mode. Once the Player is re-started, the recording will resume automatically.

After stopRecord, startRecord can be called to resume the recording.

If stopRecord is called when the recording has already stopped, it will be ignored.

When stopRecord returns, the recording has stopped and a RECORD_STOPPED event will be delivered through the PlayerListener.