java pcm16位_Java C.ENCODING_PCM_16BIT属性代码示例

@Override

public void queueInput(ByteBuffer inputBuffer) {

// Prepare the output buffer.

int position = inputBuffer.position();

int limit = inputBuffer.limit();

int size = limit - position;

int resampledSize;

switch (encoding) {

case C.ENCODING_PCM_8BIT:

resampledSize = size * 2;

break;

case C.ENCODING_PCM_24BIT:

resampledSize = (size / 3) * 2;

break;

case C.ENCODING_PCM_32BIT:

resampledSize = size / 2;

break;

case C.ENCODING_PCM_16BIT:

case C.ENCODING_INVALID:

case Format.NO_VALUE:

default:

throw new IllegalStateException();

}

if (buffer.capacity() < resampledSize) {

buffer = ByteBuffer.allocateDirect(resampledSize).order(ByteOrder.nativeOrder());

} else {

buffer.clear();

}

// Resample the little endian input and update the input/output buffers.

switch (encoding) {

case C.ENCODING_PCM_8BIT:

// 8->16 bit resampling. Shift each byte from [0, 256) to [-128, 128) and scale up.

for (int i = position; i < limit; i++) {

buffer.put((byte) 0);

buffer.put((byte) ((inputBuffer.get(i) & 0xFF) - 128));

}

break;

case C.ENCODING_PCM_24BIT:

// 24->16 bit resampling. Drop the least significant byte.

for (int i = position; i < limit; i += 3) {

buffer.put(inputBuffer.get(i + 1));

buffer.put(inputBuffer.get(i + 2));

}

break;

case C.ENCODING_PCM_32BIT:

// 32->16 bit resampling. Drop the two least significant bytes.

for (int i = position; i < limit; i += 4) {

buffer.put(inputBuffer.get(i + 2));

buffer.put(inputBuffer.get(i + 3));

}

break;

case C.ENCODING_PCM_16BIT:

case C.ENCODING_INVALID:

case Format.NO_VALUE:

default:

// Never happens.

throw new IllegalStateException();

}

inputBuffer.position(inputBuffer.limit());

buffer.flip();

outputBuffer = buffer;

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值