質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

Eclipse

Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。

Q&A

3回答

2589閲覧

NullPointerExceptionが起こる理由が分かりません。

soccerkozo

総合スコア12

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

Eclipse

Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。

0グッド

0クリップ

投稿2015/08/06 12:03

イタリックテキスト```public class MainActivity extends Activity {
private static final String TAG = "AR";
private int RECORDER_BPP;
private static final String AUDIO_RECORDER_FILE_EXT_WAV = ".wav";
private static final String AUDIO_RECORDER_TEMP_FILE = "record_temp.raw";
private int RECORDER_SAMPLERATE;
private AudioRecord recorder = null;
private int bufferSize = 0;
private Thread recordingThread = null;
private boolean isRecording = false;
final int[] sampleRates = new int[] {44100, 22050, 11025, 8000};
final short[] audioFormats = new short[] {AudioFormat.ENCODING_PCM_16BIT, AudioFormat.ENCODING_PCM_8BIT};
final short[] channelConfigs = new short[] {AudioFormat.CHANNEL_IN_STEREO, AudioFormat.CHANNEL_IN_MONO};

@Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); recorder = findAudioRecord(); setButtonHandlers(); enableButtons(false); } private void setButtonHandlers() { ((Button)findViewById(R.id.btnStart)).setOnClickListener(btnClick); ((Button)findViewById(R.id.btnStop)).setOnClickListener(btnClick); } private void enableButton(int id,boolean isEnable){ ((Button)findViewById(id)).setEnabled(isEnable); } private void enableButtons(boolean isRecording) { enableButton(R.id.btnStart,!isRecording); enableButton(R.id.btnStop,isRecording); } private String getFilename(){ String filepath = Environment.getExternalStorageDirectory().getPath(); File file = new File(filepath,System.currentTimeMillis() + AUDIO_RECORDER_FILE_EXT_WAV/*AUDIO_RECORDER_FOLDER*/); if(!file.exists()){ file.mkdirs(); } return (filepath + "/" + System.currentTimeMillis() + AUDIO_RECORDER_FILE_EXT_WAV); } private String getTempFilename(){ String filepath = Environment.getExternalStorageDirectory().getPath(); File tempFile = new File(filepath,AUDIO_RECORDER_TEMP_FILE); if(tempFile.exists()){ tempFile.delete(); } tempFile.mkdirs(); return (filepath + "/" +AUDIO_RECORDER_TEMP_FILE); } private void startRecording(){ /*int i = recorder.getState(); if(i==1)*/ recorder.startRecording(); isRecording = true; recordingThread = new Thread(new Runnable() { @Override public void run() { writeAudioDataToFile(); } },"AudioRecorder Thread"); recordingThread.start(); } private void writeAudioDataToFile(){ byte data[] = new byte[bufferSize]; String filename = getTempFilename(); FileOutputStream os = null; try { os = new FileOutputStream(filename); } catch (FileNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } int read = 0; if(null != os){ while(isRecording){ read = recorder.read(data, 0, bufferSize); if(AudioRecord.ERROR_INVALID_OPERATION != read){ try { os.write(data); } catch (IOException e) { e.printStackTrace(); } } } try { os.close(); } catch (IOException e) { e.printStackTrace(); } } } private void stopRecording(){ if(null != recorder){ isRecording = false; int i = recorder.getState(); if(i==1) recorder.stop(); recorder.release(); recorder = null; recordingThread = null; } copyWaveFile(getTempFilename(),getFilename()); deleteTempFile(); } private void deleteTempFile() { File file = new File(getTempFilename()); file.delete(); } private void copyWaveFile(String inFilename,String outFilename){ FileInputStream in = null; FileOutputStream out = null; long totalAudioLen = 0; long totalDataLen = totalAudioLen + 36; long longSampleRate = RECORDER_SAMPLERATE; int channels = 1; long byteRate = RECORDER_BPP * RECORDER_SAMPLERATE * channels/8; byte[] data = new byte[bufferSize]; try { in = new FileInputStream(inFilename); out = new FileOutputStream(outFilename); totalAudioLen = in.getChannel().size(); totalDataLen = totalAudioLen + 36; WriteWaveFileHeader(out, totalAudioLen, totalDataLen, longSampleRate, channels, byteRate); while(in.read(data) != -1){ out.write(data); } in.close(); out.close(); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } private void WriteWaveFileHeader( FileOutputStream out, long totalAudioLen, long totalDataLen, long longSampleRate, int channels, long byteRate) throws IOException { byte[] header = new byte[44]; header[0] = 'R'; // RIFF/WAVE header header[1] = 'I'; header[2] = 'F'; header[3] = 'F'; header[4] = (byte) (totalDataLen & 0xff); header[5] = (byte) ((totalDataLen >> 8) & 0xff); header[6] = (byte) ((totalDataLen >> 16) & 0xff); header[7] = (byte) ((totalDataLen >> 24) & 0xff); header[8] = 'W'; header[9] = 'A'; header[10] = 'V'; header[11] = 'E'; header[12] = 'f'; // ‘fmt ‘ chunk header[13] = 'm'; header[14] = 't'; header[15] = ' '; header[16] = 16; // 4 bytes: size of ‘fmt ‘ chunk header[17] = 0; header[18] = 0; header[19] = 0; header[20] = 1; // format = 1 header[21] = 0; header[22] = (byte) channels; header[23] = 0; header[24] = (byte) (longSampleRate & 0xff); header[25] = (byte) ((longSampleRate >> 8) & 0xff); header[26] = (byte) ((longSampleRate >> 16) & 0xff); header[27] = (byte) ((longSampleRate >> 24) & 0xff); header[28] = (byte) (byteRate & 0xff); header[29] = (byte) ((byteRate >> 8) & 0xff); header[30] = (byte) ((byteRate >> 16) & 0xff); header[31] = (byte) ((byteRate >> 24) & 0xff); header[32] = (byte) (2 * 16 / 8); // block align header[33] = 0; header[34] = (byte) RECORDER_BPP; // bits per sample header[35] = 0; header[36] = 'd'; header[37] = 'a'; header[38] = 't'; header[39] = 'a'; header[40] = (byte) (totalAudioLen & 0xff); header[41] = (byte) ((totalAudioLen >> 8) & 0xff); header[42] = (byte) ((totalAudioLen >> 16) & 0xff); header[43] = (byte) ((totalAudioLen >> 24) & 0xff); out.write(header, 0, 44); } public AudioRecord findAudioRecord() { for (int rate : sampleRates) { for (short audioFormat : audioFormats) { for (short channelConfig : channelConfigs) { try { Log.d(TAG, "Attempting rate " + rate + "Hz, bits: " + audioFormat + ", channel: " + channelConfig); bufferSize = AudioRecord.getMinBufferSize(rate, channelConfig, audioFormat); if(audioFormat==AudioFormat.ENCODING_PCM_16BIT){ RECORDER_BPP = 16; } else if(audioFormat==AudioFormat.ENCODING_PCM_8BIT){ RECORDER_BPP = 8; } RECORDER_SAMPLERATE = rate; if (bufferSize != AudioRecord.ERROR_BAD_VALUE) { recorder = new AudioRecord(AudioSource.DEFAULT, rate, channelConfig, audioFormat, bufferSize); if (recorder.getState() == AudioRecord.STATE_INITIALIZED) return recorder; } } catch (Exception e) { Log.e(TAG, rate + "Exception, keep trying.",e); } } } } return null; } private View.OnClickListener btnClick = new View.OnClickListener() { @Override public void onClick(View v) { switch(v.getId()){ case R.id.btnStart:{ enableButtons(true); startRecording();

コード

E/AndroidRuntime(10700): FATAL EXCEPTION: main E/AndroidRuntime(10700): java.lang.NullPointerException E/AndroidRuntime(10700): at com.example.s3033051.jissen2samp1.MainActivity.startRecording(MainActivity.java:90) E/AndroidRuntime(10700): at com.example.s3033051.jissen2samp1.MainActivity.access$1(MainActivity.java:86) E/AndroidRuntime(10700): at com.example.s3033051.jissen2samp1.MainActivity$1.onClick(MainActivity.java:292) E/AndroidRuntime(10700): at android.view.View.performClick(View.java:4204) E/AndroidRuntime(10700): at android.view.View$PerformClick.run(View.java:17355) E/AndroidRuntime(10700): at android.os.Handler.handleCallback(Handler.java:725) E/AndroidRuntime(10700): at android.os.Handler.dispatchMessage(Handler.java:92) E/AndroidRuntime(10700): at android.os.Looper.loop(Looper.java:137) E/AndroidRuntime(10700): at android.app.ActivityThread.main(ActivityThread.java:5292) E/AndroidRuntime(10700): at java.lang.reflect.Method.invokeNative(Native Method) E/AndroidRuntime(10700): at java.lang.reflect.Method.invoke(Method.java:511) E/AndroidRuntime(10700): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1031) E/AndroidRuntime(10700): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:798) E/AndroidRuntime(10700): at dalvik.system.NativeStart.main(Native Method)

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

recorderがおそらくnullです。
recorderに代入している部分
recorder = findAudioRecord();
ですが
findAudioRecord()がnullを返しているのでは?

投稿2015/08/06 12:37

編集2015/08/06 12:38
ozwk

総合スコア13521

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

soccerkozo

2015/08/06 13:02

public AudioRecord findAudioRecord() { for (int rate : sampleRates) { for (short audioFormat : audioFormats) { for (short channelConfig : channelConfigs) { try { Log.d(TAG, "Attempting rate " + rate + "Hz, bits: " + audioFormat + ", channel: " + channelConfig); bufferSize = AudioRecord.getMinBufferSize(rate, channelConfig, audioFormat); if(audioFormat==AudioFormat.ENCODING_PCM_16BIT){ RECORDER_BPP = 16; } else if(audioFormat==AudioFormat.ENCODING_PCM_8BIT){ RECORDER_BPP = 8; } RECORDER_SAMPLERATE = rate; if (bufferSize != AudioRecord.ERROR_BAD_VALUE) { recorder = new AudioRecord(AudioSource.DEFAULT, rate, channelConfig, audioFormat, bufferSize); if (recorder.getState() == AudioRecord.STATE_INITIALIZED) return recorder; } } catch (Exception e) { Log.e(TAG, rate + "Exception, keep trying.",e); } } } } return null; } 使える周波数などの時にはrecorderを返すという風にしているつもりなのですが、どこを変えればよいと思いますか? 図々しくて申し訳ありません。
ozwk

2015/08/06 13:16

デバッガ使ってどういう分岐通っているか調べればいいと思います。
shanxia

2015/08/27 15:01

AudioRecord.getMinBufferSize()がAudioRecord.ERROR_BAD_VALUEを返してきているか、recorder.getState()がAudioRecord.STATE_INITIALIZEDを返しているか、もしくはそのどちらかがExceptionをthrowしているか、でしょう。 なんとなくステータスか、Exceptionの様な気がします。 AudioRecordのコンストラクタがどうなっているか、調べてみると良いと思います。
guest

0

出力を見れば分かる通り、例外はstartRecordingで発生していると思われます。
startRecordingコール時にNullPointerExceptionが発生する可能性がある行は、

Java

1recorder.startRecording(); 2// OR 3recordingThread.start();

この2つ。
直前でインスタンス生成を行っている後者の可能性は低いので、recorder.startRecording();が原因だと思います。
recordernullなのでは?

投稿2015/08/06 12:30

shiolier

総合スコア1156

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

soccerkozo

2015/08/06 13:03

public AudioRecord findAudioRecord() { for (int rate : sampleRates) { for (short audioFormat : audioFormats) { for (short channelConfig : channelConfigs) { try { Log.d(TAG, "Attempting rate " + rate + "Hz, bits: " + audioFormat + ", channel: " + channelConfig); bufferSize = AudioRecord.getMinBufferSize(rate, channelConfig, audioFormat); if(audioFormat==AudioFormat.ENCODING_PCM_16BIT){ RECORDER_BPP = 16; } else if(audioFormat==AudioFormat.ENCODING_PCM_8BIT){ RECORDER_BPP = 8; } RECORDER_SAMPLERATE = rate; if (bufferSize != AudioRecord.ERROR_BAD_VALUE) { recorder = new AudioRecord(AudioSource.DEFAULT, rate, channelConfig, audioFormat, bufferSize); if (recorder.getState() == AudioRecord.STATE_INITIALIZED) return recorder; } } catch (Exception e) { Log.e(TAG, rate + "Exception, keep trying.",e); } } } } return null; } 使える周波数などの時にはrecorderを返すという風にしているつもりなのですが、どこを変えればよいと思いますか? 図々しくて申し訳ありません。
guest

0

findAudioRecord()がNullを返している可能性があります。findAudioRecord()内についていくつか指摘いたします。

  • ENCODING_PCM_16BIT は確実に実装されているようですが、ENCODING_PCM_8BITは端末次第のようです。
  • recorder = new AudioRecord(AudioSource.DEFAULT, rate, channelConfig, audioFormat, bufferSize);

上記の箇所で第一引数をAudioSource.DEFAULTにしているのはなぜでしょうか。録音するのであればAudioSource.MICを指定するのが妥当だと思われます。

  • AudioRecord.getMinBufferSize(rate, channelConfig, audioFormat)

上記のメソッドはERRORも返却する可能性があります。

投稿2015/08/27 15:54

yona

総合スコア18155

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問