- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
应用程序简要描述:
用户将单击 MainActivity.java 上的启动按钮,该按钮将定向到 FirstWord.java。在 FirstWord.java 上,用户可以通过单击录制按钮来录制自己所说的单词。有一个文本到语音实例将输出单词的发音。
问题出现在 MediaRecorder 上。一旦用户单击 recordButton,应用程序就会崩溃。
FirstWord.java
文本到语音实例工作正常,但我发布了所有内容,以防 textToSpeech 导致 MediaRecorder 失败。
package com.example.learnwords;
import java.io.IOException;
import java.util.Locale;
import android.app.Activity;
import android.content.Intent;
import android.content.pm.PackageManager;
import android.media.MediaPlayer;
import android.media.MediaRecorder;
import android.os.Bundle;
import android.os.Environment;
import android.speech.tts.TextToSpeech;
import android.speech.tts.TextToSpeech.OnInitListener;
import android.view.Menu;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;
import android.widget.Toast;
public class FirstWord extends Activity implements OnInitListener {
private TextToSpeech myTTS;
private int MY_DATA_CHECK_CODE = 0;
private static MediaRecorder mediaRecorder = new MediaRecorder();
private static MediaPlayer mediaPlayer = new MediaPlayer();
private static String audioFilePath;
private static Button stopButton;
private static Button playButton;
private static Button recordButton;
private boolean isRecording = false;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_first_word);
Intent checkTTSIntent = new Intent();
checkTTSIntent.setAction(TextToSpeech.Engine.ACTION_CHECK_TTS_DATA);
startActivityForResult(checkTTSIntent, MY_DATA_CHECK_CODE);
recordButton = (Button) findViewById(R.id.recordButton);
playButton = (Button) findViewById(R.id.playButton);
stopButton = (Button) findViewById(R.id.stopButton);
if (!hasMicrophone()) //calling hasMicrophone
{
stopButton.setEnabled(false);
playButton.setEnabled(false);
recordButton.setEnabled(false);
} else {
playButton.setEnabled(false);
stopButton.setEnabled(false);
}
audioFilePath =
Environment.getExternalStorageDirectory().getAbsolutePath()
+ "/myaudio.3gp";
}
protected boolean hasMicrophone() {
PackageManager pmanager = this.getPackageManager();
return pmanager.hasSystemFeature(
PackageManager.FEATURE_MICROPHONE);
}
public void recordAudio(View view)throws Exception{
isRecording = true;
stopButton.setEnabled(true);
playButton.setEnabled(false);
recordButton.setEnabled(false);
try {
mediaRecorder = new MediaRecorder();
mediaRecorder.setAudioSource(MediaRecorder.AudioSource.MIC);
mediaRecorder.setOutputFormat(MediaRecorder.OutputFormat.THREE_GPP);
mediaRecorder.setOutputFile(audioFilePath);
mediaRecorder.setAudioEncoder(MediaRecorder.AudioEncoder.AMR_NB);
mediaRecorder.prepare();
} catch (Exception e) {
e.printStackTrace();
}
mediaRecorder.start();
}
public void stopClicked (View view)
{
stopButton.setEnabled(false);
playButton.setEnabled(true);
if (isRecording)
{
recordButton.setEnabled(false);
mediaRecorder.stop();
mediaRecorder.release();
mediaRecorder = null;
isRecording = false;
} else {
mediaPlayer.release();
mediaPlayer = null;
recordButton.setEnabled(true);
}
}
public void playAudio (View view) throws IOException
{
playButton.setEnabled(false);
recordButton.setEnabled(false);
stopButton.setEnabled(true);
mediaPlayer = new MediaPlayer();
mediaPlayer.setDataSource(audioFilePath);
mediaPlayer.prepare();
mediaPlayer.start();
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
private void speakWords(String speech) {
//speak straight away
myTTS.speak(speech, TextToSpeech.QUEUE_FLUSH, null);
}
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
if (requestCode == MY_DATA_CHECK_CODE) {
if (resultCode == TextToSpeech.Engine.CHECK_VOICE_DATA_PASS) {
//the user has the necessary data - create the TTS
myTTS = new TextToSpeech(this, this);
}
else {
//no data - install it now
Intent installTTSIntent = new Intent();
installTTSIntent.setAction(TextToSpeech.Engine.ACTION_INSTALL_TTS_DATA);
startActivity(installTTSIntent);
}
}
}
//setup TTS
public void onInit(int initStatus) {
//check for successful instantiation
if (initStatus == TextToSpeech.SUCCESS) {
if(myTTS.isLanguageAvailable(Locale.US)==TextToSpeech.LANG_AVAILABLE)
myTTS.setLanguage(Locale.US);
}
else if (initStatus == TextToSpeech.ERROR) {
Toast.makeText(this, "Sorry! Text To Speech failed...", Toast.LENGTH_LONG).show();
}
}
public void proClicked(View view) {
TextView textView = (TextView)findViewById(R.id.textView1);
String word = textView.getText().toString();
speakWords(word);
}
}
日志猫
09-19 11:17:20.229: D/ActivityThread(4603): setTargetHeapUtilization:0.25
09-19 11:17:20.229: D/ActivityThread(4603): setTargetHeapIdealFree:8388608
09-19 11:17:20.229: D/ActivityThread(4603): setTargetHeapConcurrentStart:2097152
09-19 11:17:20.680: I/Adreno200-EGLSUB(4603): <ConfigWindowMatch:2087>: Format RGBA_8888.
09-19 11:17:20.720: E/(4603): <s3dReadConfigFile:75>: Can't open file for reading
09-19 11:17:20.720: E/(4603): <s3dReadConfigFile:75>: Can't open file for reading
09-19 11:17:22.061: V/MediaPlayer(4603): constructor
09-19 11:17:22.061: V/MediaPlayer(4603): setListener
09-19 11:17:22.241: I/Adreno200-EGLSUB(4603): <ConfigWindowMatch:2087>: Format RGBA_8888.
09-19 11:17:24.363: I/TextToSpeech(4603): Sucessfully bound to com.google.android.tts
09-19 11:17:24.373: E/SpannableStringBuilder(4603): SPAN_EXCLUSIVE_EXCLUSIVE spans cannot have a zero length
09-19 11:17:24.373: E/SpannableStringBuilder(4603): SPAN_EXCLUSIVE_EXCLUSIVE spans cannot have a zero length
09-19 11:17:24.373: I/TextToSpeech(4603): Connected to ComponentInfo{com.google.android.tts/com.google.android.tts.GoogleTTSService}
09-19 11:17:28.998: W/System.err(4603): java.lang.RuntimeException: setAudioSource failed.
09-19 11:17:29.018: W/System.err(4603): at android.media.MediaRecorder._setAudioSource(Native Method)
09-19 11:17:29.018: W/System.err(4603): at android.media.MediaRecorder.setAudioSource(MediaRecorder.java:330)
09-19 11:17:29.018: W/System.err(4603): at com.example.learnwords.FirstWord.recordAudio(FirstWord.java:75)
09-19 11:17:29.018: W/System.err(4603): at java.lang.reflect.Method.invokeNative(Native Method)
09-19 11:17:29.018: W/System.err(4603): at java.lang.reflect.Method.invoke(Method.java:511)
09-19 11:17:29.018: W/System.err(4603): at android.view.View$1.onClick(View.java:3674)
09-19 11:17:29.018: W/System.err(4603): at android.view.View.performClick(View.java:4203)
09-19 11:17:29.018: W/System.err(4603): at android.view.View$PerformClick.run(View.java:17189)
09-19 11:17:29.018: W/System.err(4603): at android.os.Handler.handleCallback(Handler.java:615)
09-19 11:17:29.018: W/System.err(4603): at android.os.Handler.dispatchMessage(Handler.java:92)
09-19 11:17:29.018: W/System.err(4603): at android.os.Looper.loop(Looper.java:137)
09-19 11:17:29.018: W/System.err(4603): at android.app.ActivityThread.main(ActivityThread.java:4950)
09-19 11:17:29.018: W/System.err(4603): at java.lang.reflect.Method.invokeNative(Native Method)
09-19 11:17:29.018: W/System.err(4603): at java.lang.reflect.Method.invoke(Method.java:511)
09-19 11:17:29.028: W/System.err(4603): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1004)
09-19 11:17:29.028: W/System.err(4603): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:771)
09-19 11:17:29.028: W/System.err(4603): at dalvik.system.NativeStart.main(Native Method)
09-19 11:17:29.028: E/MediaRecorder(4603): start called in an invalid state: 0
09-19 11:17:29.028: W/dalvikvm(4603): threadid=1: thread exiting with uncaught exception (group=0x4196f438)
09-19 11:17:29.038: E/AndroidRuntime(4603): FATAL EXCEPTION: main
09-19 11:17:29.038: E/AndroidRuntime(4603): java.lang.IllegalStateException: Could not execute method of the activity
09-19 11:17:29.038: E/AndroidRuntime(4603): at android.view.View$1.onClick(View.java:3679)
09-19 11:17:29.038: E/AndroidRuntime(4603): at android.view.View.performClick(View.java:4203)
09-19 11:17:29.038: E/AndroidRuntime(4603): at android.view.View$PerformClick.run(View.java:17189)
09-19 11:17:29.038: E/AndroidRuntime(4603): at android.os.Handler.handleCallback(Handler.java:615)
09-19 11:17:29.038: E/AndroidRuntime(4603): at android.os.Handler.dispatchMessage(Handler.java:92)
09-19 11:17:29.038: E/AndroidRuntime(4603): at android.os.Looper.loop(Looper.java:137)
09-19 11:17:29.038: E/AndroidRuntime(4603): at android.app.ActivityThread.main(ActivityThread.java:4950)
09-19 11:17:29.038: E/AndroidRuntime(4603): at java.lang.reflect.Method.invokeNative(Native Method)
09-19 11:17:29.038: E/AndroidRuntime(4603): at java.lang.reflect.Method.invoke(Method.java:511)
09-19 11:17:29.038: E/AndroidRuntime(4603): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1004)
09-19 11:17:29.038: E/AndroidRuntime(4603): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:771)
09-19 11:17:29.038: E/AndroidRuntime(4603): at dalvik.system.NativeStart.main(Native Method)
09-19 11:17:29.038: E/AndroidRuntime(4603): Caused by: java.lang.reflect.InvocationTargetException
09-19 11:17:29.038: E/AndroidRuntime(4603): at java.lang.reflect.Method.invokeNative(Native Method)
09-19 11:17:29.038: E/AndroidRuntime(4603): at java.lang.reflect.Method.invoke(Method.java:511)
09-19 11:17:29.038: E/AndroidRuntime(4603): at android.view.View$1.onClick(View.java:3674)
09-19 11:17:29.038: E/AndroidRuntime(4603): ... 11 more
09-19 11:17:29.038: E/AndroidRuntime(4603): Caused by: java.lang.IllegalStateException
09-19 11:17:29.038: E/AndroidRuntime(4603): at android.media.MediaRecorder.start(Native Method)
09-19 11:17:29.038: E/AndroidRuntime(4603): at com.example.learnwords.FirstWord.recordAudio(FirstWord.java:83)
09-19 11:17:29.038: E/AndroidRuntime(4603): ... 14 more
AndroidManifest.XML
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.learnwords"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk
android:minSdkVersion="8"
android:targetSdkVersion="17" />
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<activity
android:name="com.example.learnwords.MainActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity
android:name="com.example.learnwords.FirstWord"
android:label="@string/title_activity_first_word"
android:parentActivityName="com.example.learnwords.MainActivity" >
<meta-data
android:name="android.support.PARENT_ACTIVITY"
android:value="com.example.myfirstapp.MainActivity" />
</activity>
</application>
</manifest>
我认为这些是相关文件。如果需要其他文件,请评论。
有什么想法吗?谢谢。
最佳答案
我发现了我的错误。我的 AndroidManifest.XML 中缺少权限声明。
<uses-permission
android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.RECORD_AUDIO" />
这两行至关重要。
关于java - MediaRecorder 启动在无效状态下调用 : 0,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18898894/
我正在为 chrome 商店构建一个屏幕录像机插件。我是 将麦克风的音轨添加到媒体流 包含( 屏幕的视频轨道 + 系统音频轨道 )。所以最终流包含 2 个音轨,一个是麦克风,另一个是系统音频。 当我将
当我尝试在我的程序中制作摄像机时,出现此错误: E/MediaRecorder﹕ start failed: -19 代码是 try { final SurfaceView sv = (Sur
const [rec, setRec] = useState({}); const [onRec, setOnRec] = useState(true); useEffect(() => {
这段代码在 Debug模式下工作得很好,但当不是 Debug模式时它总是抛出运行时异常。 mMediaRecorder.stop(); 根据 Java 文档: Stops recordin
当我尝试为我的 MediaRecorder 设置视频大小时,我在启动方法中收到 RuntimeException。 mRecorder.setAudioSource(MediaRecorder.Aud
录制音频是一个很长的操作,所以我启动mRecorder?.start()在服务内的协程中,您可以看到 RecordService.kt。 我调用 suspend fun startRecord(){.
使用媒体记录器,我可以在 azure 上上传和附加视频 blob。但是无法使用以下代码在下载时查找组合视频 - var chunks =[]; var mediaRecorder = new Medi
我在我的应用程序中集成了摄像头。当用户单击捕获按钮时,我隐藏了工具栏,以便摄像头预览屏幕尺寸增加。这会导致应用程序在停止在线录制时崩溃 - mMediaRecorder.stop(); 。 java.
我想在按住按钮时使用 MediaRecorder 开始录制语音消息。尝试在 onLongClickListener 中开始录制时出现 IllegalStateException。 如堆栈跟踪中所述,我
我的应用需要录制最长 8 秒的视频。这已经通过 MediaRecorder.setMaxDuration(long milliseconds) 实现。该应用还需要顶部的进度条和带有剩余时间倒计时的标签
使用时 CanvasCaptureMediaStream和 MediaRecorder,有没有办法在每一帧上获取一个事件? 我需要的和 requestAnimationFrame() 没什么不同,但我
我正在尝试使用媒体录音机来录制音频。我让它工作,以便我能够录制和播放。唯一的问题是我无法记录程序第二次崩溃的情况。我有一个单独的方法来重置 MediaRecorder,但无论我将它放在哪里,它都不起作
我正在使用 MediaRecorder 录制视频,但似乎无论我使用什么设置,帧率都令人震惊(~ 1fps) 这是我的代码: recorder.setAudioSource(MediaRecor
如果我使用 MediaRecorder.AudioSource.MIC 声音会正常录制。如果 MediaRecorder.AudioSource.VOICE_DOWNLINK 声音以慢速播放。我需要它
我查看了其他人遇到的这个问题,但没有找到合适的解决方案。像他们一样,我遵循了相机功能教程:http://developer.android.com/guide/topics/media/camera.
我正在准备一个小型 Android 应用程序,用于捕获用户的照片和录音。用户会用他的相机拍照,然后在查看该照片时添加音频评论。 为了捕捉音频,我正在使用 MediaRecorder [因为 andro
我想录制通话语音,但我收到 MediaRecorder:start failed : -2147483648 这是我的通话记录代码块 public void SesKayitBaslat(Str
我的应用程序录制了一个音频 fragment ,并在录制完成后使用 Retrofit2 将 fragment 发送到服务器。服务器接收到文件,但是文件损坏了,我说的损坏是无法播放。我使用以下 URL(
我尝试实现的方法如下所示。 它保存了文件,音频没问题,但视频全是绿色线条。 我做错了什么? camera.unlock(); mediaRecorder = new MediaRecorder();
我首先尝试创建 SurfaceView: SurfaceView sv = new SurfaceView(context); // Get a surface surfaceHolder = sv.
我是一名优秀的程序员,十分优秀!