所有类


javax.sound.sampled
接口 DataLine

所有超级接口:
Line
所有已知子接口:
Clip, SourceDataLine, TargetDataLine

public interface DataLine
   
   
   
   
   
extends Line

DataLine 将与介质相关的功能添加到其超接口 Line。此功能包括一些传输控制方法,这些方法可以启动、停止、消耗和刷新通过数据行传入的音频数据。数据行还可以报告介质的当前位置、音量和音频格式。数据行通过使用子接口 SourceDataLineClip 用于音频输出,这些子接口允许应用程序写入数据。类似地,音频输入由子接口 TargetDataLine 处理,该接口允许读取数据。

数据行有一个内部缓冲区,传入或传出数据在该缓冲区被加入队列。此内部缓冲区变空之前(通常因为已处理所有列队的数据),drain() 方法发生阻塞。flush() 方法将放弃内部缓冲区中的所有可用的已列队数据。

只要数据行开始还是停止数据的活动现象或数据的捕获,就会产生 STARTSTOP 事件。这些事件可能在响应特定请求时生成,也可能是不太直接的状态更改的结果。例如,如果对非活动数据行调用 start(),且数据可用于捕获或回放,则将在实际开始数据回放或捕获时生成 START 事件。或者,如果因为活动数据行的数据流受到限制而在数据呈现中发生间隙,则生成 STOP 事件。

混频器常常支持多条数据行的同步控制。可以通过混频器接口的 synchronize 方法来建立同步。关于更完整的描述,请参见 Mixer 接口的描述。

从以下版本开始:
1.3
另请参见:
LineEvent

嵌套类摘要
static class DataLine.Info
          除了继承自其超类的类信息之外,DataLine.Info 还提供特定于数据行的其他信息。
 
方法摘要
 int available()
          获得当前可用于数据行内部缓冲区中处理的应用程序的数据字节数。
 void drain()
          通过在清空数据行的内部缓冲区之前继续数据 I/O,排空数据行中的列队数据。
 void flush()
          刷新数据行中已列队的数据。
 int getBufferSize()
          获得将适合数据行的内部缓冲区的最大数据字节数。
 AudioFormat getFormat()
          获得数据行的音频数据的当前格式(编码、样本频率、信道数,等等)。
 int getFramePosition()
          获得音频数据中的当前位置(以样本帧为单位)。
 float getLevel()
          获得行的当前音量级别。
 long getLongFramePosition()
          获得音频数据中的当前位置(以样本帧为单位)。
 long getMicrosecondPosition()
          获得音频数据中的当前位置(以微秒为单位)。
 boolean isActive()
          指示该行是否正在进行活动 I/O(如回放或捕获)。
 boolean isRunning()
          指示该行是否正在运行。
 void start()
          允许某一数据行执行数据 I/O。
 void stop()
          停止行。
 
从接口 javax.sound.sampled.Line 继承的方法
addLineListener, close, getControl, getControls, getLineInfo, isControlSupported, isOpen, open, removeLineListener
 

方法详细信息

drain

void drain()
通过在清空数据行的内部缓冲区之前继续数据 I/O,排空数据行中的列队数据。在完成排空操作之前,此方法发生阻塞。因为这是一个阻塞方法,所以应小心使用它。如果在队列中有数据的终止行上调用 drain(),则在该行正在运行和数据队列变空之前,此方法将发生阻塞。如果通过一个线程调用 drain(),另一个线程继续填充数据队列,则该操作没有完成。此方法总是在关闭数据行时返回。

另请参见:
flush()

flush

void flush()
刷新数据行中已列队的数据。已刷新的数据将被丢弃。在某些情况下,不是所有已列队的数据都被丢弃。例如,混频器可以刷新特定输入行的缓冲区中的数据,但是输出缓冲区中尚未播放的数据(混合的结果)仍将被播放。如果想要在重新启动回放或捕获时跳过“陈旧的”数据,则可以在暂停某一数据行(正常情况)之后调用此方法。(刷新尚未停止的数据行是合法的,但在活动行上这样做很可能导致数据的间断,导致一个显而易见的单击。)

另请参见:
stop(), drain()

start

void start()
允许某一数据行执行数据 I/O。如果在已经运行的数据行上调用此方法,则此方法不执行任何操作。除非已刷新缓冲区中的数据,否则该行将从停止该数据行时未经处理的第一帧开始恢复 I/O。当开始音频捕获或回放时,生成 START 事件。

另请参见:
stop(), isRunning(), LineEvent

stop

void stop()
停止行。停止的行应该停止 I/O 活动。但是,如果行已被打开并且正在运行,它应该保留恢复活动所需的资源。停止的行应该保留其缓冲区中的任何音频数据而不是丢弃它,以便在恢复时,I/O 可以从原来停止的位置继续(如有可能)。(当然,此操作不保证在当前缓冲区之外永远不会有间断;如果停止的情况持续时间太长,则可能删除输入或输出示例。)如果需要,可以通过调用 flush 方法丢弃保留的数据。当音频捕获或回放停止时,生成 STOP 事件。

另请参见:
start(), isRunning(), flush(), LineEvent

isRunning

boolean isRunning()
指示该行是否正在运行。默认值为 false。打开的行将在响应调用 start 方法而呈现第一个数据时开始运行,并可持续到响应调用 stop 或因为回放结束而表现为停止状态时为止。

返回:
如果该行正在运行,则返回 true;否则返回 false
另请参见:
start(), stop()

isActive

boolean isActive()
指示该行是否正在进行活动 I/O(如回放或捕获)。当非活动行变得活动时,它会向其侦听器发送一个 START 事件。类似地,当活动行变得不活动时,它将发送 STOP 事件。

返回:
如果行将在活动情况下捕获或呈现声音,则返回 true;否则返回 false
另请参见:
Line.isOpen(), Line.addLineListener(javax.sound.sampled.LineListener), Line.removeLineListener(javax.sound.sampled.LineListener), LineEvent, LineListener

getFormat

AudioFormat getFormat()
获得数据行的音频数据的当前格式(编码、样本频率、信道数,等等)。

如果行未打开且从来没有打开过,则返回默认格式。默认格式是一个特定音频格式实现,如果 DataLine.Info 对象(用于检索此 DataLine)至少指定一个完全限定的音频格式,则将最后一个格式用作默认格式。打开具有特定音频格式(如 SourceDataLine.open(AudioFormat))的行将重写默认格式。

返回:
当前的音频数据格式
另请参见:
AudioFormat

微信小程序

微信扫一扫体验

微信公众账号

微信扫一扫加关注

发表
评论
返回
顶部