// from https://stackoverflow.com/questions/27614987/is-it-possible-to-record-the-voice-from-bluetooth-headset-and-play-on-android-sp public static final int SAMPLE_RATE = 16000; private AudioRecord mRecorder; private File mRecording; private short[] mBuffer; private boolean mIsRecording = false; float iGain = 1.0f; CheckBox gain; Button showPref; OnBluetoothRecording bluetoothRecording; protected int bitsPerSamples = 16; p { initRecorder(); Button bluetooth = (Button)findViewById(R.id.blue); showPref.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { startActivity(new Intent(getApplicationContext(),BluetoothPreferenceActivity.class)); } }); final Button button = (Button) findViewById(R.id.start); button.setText(startRecordingLabel); bluetooth.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { // TODO Auto-generated method stub Intent i = new Intent(""); } }); gain.setOnCheckedChangeListener(new OnCheckedChangeListener() { @Override public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) { if (gain.isChecked()) { iGain = 5.0f; } else { iGain = 2.0f; } } }); button.setOnClickListener(new OnClickListener() { @Override public void onClick(final View v) { BluetoothRecordingManager.checkAndRecord(getApplicationContext(), new OnBluetoothRecording() { @Override public void onStartRecording(boolean state, boolean bluetoothFlag) { Log.d("CallBack","starting Recording"); if (!mIsRecording) { button.setText(stopRecordingLabel); mIsRecording = true; mRecorder.startRecording(); mRecording = getFile("raw"); startBufferedWrite(mRecording); } else { button.setText(startRecordingLabel); mIsRecording = false; mRecorder.stop(); File waveFile = getFile("wav"); try { rawToWave(mRecording, waveFile); } catch (IOException e) { Toast.makeText(MainActivity.this, e.getMessage(), Toast.LENGTH_SHORT).show(); } Toast.makeText(MainActivity.this, "Recorded to " + waveFile.getName(), Toast.LENGTH_SHORT).show(); } } @Override public void onCancelRecording() { } }, true); } }); } svoid cleanMeUp() { mRecorder.release(); } private void initRecorder() { int bufferSize = AudioRecord.getMinBufferSize(SAMPLE_RATE, AudioFormat.CHANNEL_IN_MONO, AudioFormat.ENCODING_PCM_16BIT); mBuffer = new short[bufferSize]; mRecorder = new AudioRecord(MediaRecorder.AudioSource.MIC, SAMPLE_RATE, AudioFormat.CHANNEL_IN_MONO, AudioFormat.ENCODING_PCM_16BIT, bufferSize); } private void startBufferedWrite(final File file) { new Thread(new Runnable() { @Override public void run() { DataOutputStream output = null; try { output = new DataOutputStream(new BufferedOutputStream( new FileOutputStream(file))); while (mIsRecording) { double sum = 0; int readSize = mRecorder.read(mBuffer, 0, mBuffer.length); final int bytesPerSample = bitsPerSamples / 8; final int emptySpace = 64 - bitsPerSamples; int byteIndex = 0; int byteIndex2 = 0; int temp = 0; int mLeftTemp = 0; int mRightTemp = 0; int a = 0; int x = 0; for (int frameIndex = 0; frameIndex < readSize; frameIndex++) { for (int c = 0; c < 1; c++) { if (iGain != 1) { long accumulator = 0; for (int b = 0; b < bytesPerSample; b++) { accumulator += ((long) (mBuffer[byteIndex++] & 0xFF)) << (b * 8 + emptySpace); } double sample = ((double) accumulator / (double) Long.MAX_VALUE); sample *= iGain; int intValue = (int) ((double) sample * (double) Integer.MAX_VALUE); for (int i = 0; i < bytesPerSample; i++) { mBuffer[i + byteIndex2] = (byte) (intValue >>> ((i + 2) * 8) & 0xff); } byteIndex2 += bytesPerSample; } }// end for(channel) // mBuffer[frameIndex] *=iGain; if (mBuffer[frameIndex] > 32765) { mBuffer[frameIndex] = 32767; } else if (mBuffer[frameIndex] < -32767) { mBuffer[frameIndex] = -32767; } output.writeShort(mBuffer[frameIndex]); sum += mBuffer[frameIndex] * mBuffer[frameIndex]; } if (readSize > 0) { final double amplitude = sum / readSize; mProgressBar.setProgress((int) Math.sqrt(amplitude)); } } } catch (IOException e) { Toast.makeText(MainActivity.this, e.getMessage(), Toast.LENGTH_SHORT).show(); } finally { mProgressBar.setProgress(0); if (output != null) { try { output.flush(); } catch (IOException e) { Toast.makeText(MainActivity.this, e.getMessage(), Toast.LENGTH_SHORT).show(); } finally { try { output.close(); } catch (IOException e) { Toast.makeText(MainActivity.this, e.getMessage(), Toast.LENGTH_SHORT).show(); } } } } } }).start(); } private void rawToWave(final File rawFile, final File waveFile) throws IOException { byte[] rawData = new byte[(int) rawFile.length()]; DataInputStream input = null; try { input = new DataInputStream(new FileInputStream(rawFile)); input.read(rawData); } finally { if (input != null) { input.close(); } } DataOutputStream output = null; try { output = new DataOutputStream(new FileOutputStream(waveFile)); // WAVE header // see http://ccrma.stanford.edu/courses/422/projects/WaveFormat/ writeString(output, "RIFF"); // chunk id writeInt(output, 36 + rawData.length); // chunk size writeString(output, "WAVE"); // format writeString(output, "fmt "); // subchunk 1 id writeInt(output, 16); // subchunk 1 size writeShort(output, (short) 1); // audio format (1 = PCM) writeShort(output, (short) 1); // number of channels writeInt(output, SAMPLE_RATE); // sample rate writeInt(output, SAMPLE_RATE * 2); // byte rate writeShort(output, (short) 2); // block align writeShort(output, (short) 16); // bits per sample writeString(output, "data"); // subchunk 2 id writeInt(output, rawData.length); // subchunk 2 size // Audio data (conversion big endian -> little endian) short[] shorts = new short[rawData.length / 2]; ByteBuffer.wrap(rawData).order(ByteOrder.LITTLE_ENDIAN) .asShortBuffer().get(shorts); ByteBuffer bytes = ByteBuffer.allocate(shorts.length * 2); for (short s : shorts) { // Apply Gain /* * s *= iGain; if(s>32767) { s=32767; } else if(s<-32768) { * s=-32768; } */ bytes.putShort(s); } output.write(bytes.array()); } finally { if (output != null) { output.close(); } } } private File getFile(final String suffix) { Time time = new Time(); time.setToNow(); return new File(Environment.getExternalStorageDirectory(), time.format("%Y%m%d%H%M%S") + "." + suffix); } private void writeInt(final DataOutputStream output, final int value) throws IOException { output.write(value >> 0); output.write(value >> 8); output.write(value >> 16); output.write(value >> 24); } private void writeShort(final DataOutputStream output, final short value) throws IOException { output.write(value >> 0); output.write(value >> 8); } private void writeString(final DataOutputStream output, final String value) throws IOException { for (int i = 0; i < value.length(); i++) { output.write(value.charAt(i)); } }
download show line numbers debug dex old transpilations
Travelled to 7 computer(s): bhatertpkbcr, mqqgnosmbjvj, pyentgdyhuwx, pzhvpgtvlbxg, tvejysmllsmz, vouqrxazstgt, xrpafgyirdlv
No comments. add comment
Snippet ID: | #1027049 |
Snippet name: | Android AudioRecord Test [dev.] |
Eternal ID of this version: | #1027049/2 |
Text MD5: | 6b34464e707c96816d32ea8b9c511738 |
Author: | stefan |
Category: | javax / stefan's os |
Type: | JavaX source code (desktop) |
Public (visible to everyone): | Yes |
Archived (hidden from active list): | No |
Created/modified: | 2020-02-15 12:09:20 |
Source code size: | 10184 bytes / 279 lines |
Pitched / IR pitched: | No / No |
Views / Downloads: | 377 / 564 |
Version history: | 1 change(s) |
Referenced in: | [show references] |