- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我是 Android 和 Java 的新手。
我在 Windows 10 上使用最新的 Android Studio。
我只是创建了一个空 Activity 并粘贴了代码
https://developer.android.com/guide/topics/media/audio-capture.html
到我的 MainActivity。
根据它的评论,我还在我的 list 中添加了 uses-permission。
我已经阅读了所有问答,我相信 list 很好。
但是,在帖子末尾,我不断收到 setAudioSource 失败的调用堆栈。
错误在我的 Nexus 5 和我的 Nexus 5 虚拟设备上都是一样的。
你能帮帮我吗?谢谢!
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.kyang.myapplication">
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.RECORD_AUDIO" />
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:supportsRtl="true"
android:theme="@style/AppTheme">
<activity android:name=".MainActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
</manifest>
我的代码如下:
package com.example.kyang.myapplication;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.app.Activity;
import android.widget.LinearLayout;
import android.os.Bundle;
import android.os.Environment;
import android.view.ViewGroup;
import android.widget.Button;
import android.view.View;
import android.view.View.OnClickListener;
import android.content.Context;
import android.util.Log;
import android.media.MediaRecorder;
import android.media.MediaPlayer;
import java.io.IOException;
public class MainActivity extends Activity {
private static final String LOG_TAG = "AudioRecordTest";
private static String mFileName = null;
private RecordButton mRecordButton = null;
private MediaRecorder mRecorder = null;
private PlayButton mPlayButton = null;
private MediaPlayer mPlayer = null;
private void onRecord(boolean start) {
if (start) {
startRecording();
} else {
stopRecording();
}
}
private void onPlay(boolean start) {
if (start) {
startPlaying();
} else {
stopPlaying();
}
}
private void startPlaying() {
mPlayer = new MediaPlayer();
try {
mPlayer.setDataSource(mFileName);
mPlayer.prepare();
mPlayer.start();
} catch (IOException e) {
Log.e(LOG_TAG, "prepare() failed");
}
}
private void stopPlaying() {
mPlayer.release();
mPlayer = null;
}
private void startRecording() {
mRecorder = new MediaRecorder();
mRecorder.setAudioSource(MediaRecorder.AudioSource.MIC);
mRecorder.setOutputFormat(MediaRecorder.OutputFormat.THREE_GPP);
mRecorder.setOutputFile(mFileName);
mRecorder.setAudioEncoder(MediaRecorder.AudioEncoder.AMR_NB);
try {
mRecorder.prepare();
} catch (IOException e) {
Log.e(LOG_TAG, "prepare() failed");
}
mRecorder.start();
}
private void stopRecording() {
mRecorder.stop();
mRecorder.release();
mRecorder = null;
}
class RecordButton extends Button {
boolean mStartRecording = true;
OnClickListener clicker = new OnClickListener() {
public void onClick(View v) {
onRecord(mStartRecording);
if (mStartRecording) {
setText("Stop recording");
} else {
setText("Start recording");
}
mStartRecording = !mStartRecording;
}
};
public RecordButton(Context ctx) {
super(ctx);
setText("Start recording");
setOnClickListener(clicker);
}
}
class PlayButton extends Button {
boolean mStartPlaying = true;
OnClickListener clicker = new OnClickListener() {
public void onClick(View v) {
onPlay(mStartPlaying);
if (mStartPlaying) {
setText("Stop playing");
} else {
setText("Start playing");
}
mStartPlaying = !mStartPlaying;
}
};
public PlayButton(Context ctx) {
super(ctx);
setText("Start playing");
setOnClickListener(clicker);
}
}
public MainActivity() {
mFileName = Environment.getExternalStorageDirectory().getAbsolutePath();
mFileName += "/audiorecordtest.3gp";
}
@Override
public void onPause() {
super.onPause();
if (mRecorder != null) {
mRecorder.release();
mRecorder = null;
}
if (mPlayer != null) {
mPlayer.release();
mPlayer = null;
}
}
@Override
protected void onCreate(Bundle icicle) {
super.onCreate(icicle);
LinearLayout ll = new LinearLayout(this);
mRecordButton = new RecordButton(this);
ll.addView(mRecordButton,
new LinearLayout.LayoutParams(
ViewGroup.LayoutParams.WRAP_CONTENT,
ViewGroup.LayoutParams.WRAP_CONTENT,
0));
mPlayButton = new PlayButton(this);
ll.addView(mPlayButton,
new LinearLayout.LayoutParams(
ViewGroup.LayoutParams.WRAP_CONTENT,
ViewGroup.LayoutParams.WRAP_CONTENT,
0));
setContentView(ll);
}
}
Android Monitor Verbose 模式下的输出:
05-20 09:34:18.552 15335-15335/com.example.kyang.myapplication I/Process: Sending signal. PID: 15335 SIG: 9
05-20 09:35:07.850 16251-16251/com.example.kyang.myapplication W/ActivityThread: Application com.example.kyang.myapplication is waiting for the debugger on port 8100...
05-20 09:35:07.854 16251-16251/com.example.kyang.myapplication I/System.out: Sending WAIT chunk
05-20 09:35:08.273 16251-16257/com.example.kyang.myapplication I/art: Debugger is active
05-20 09:35:08.468 16251-16251/com.example.kyang.myapplication I/System.out: Debugger has connected
05-20 09:35:08.468 16251-16251/com.example.kyang.myapplication I/System.out: waiting for debugger to settle...
05-20 09:35:08.669 16251-16251/com.example.kyang.myapplication I/System.out: waiting for debugger to settle...
05-20 09:35:08.872 16251-16251/com.example.kyang.myapplication I/System.out: waiting for debugger to settle...
05-20 09:35:09.086 16251-16251/com.example.kyang.myapplication I/System.out: waiting for debugger to settle...
05-20 09:35:09.287 16251-16251/com.example.kyang.myapplication I/System.out: waiting for debugger to settle...
05-20 09:35:09.488 16251-16251/com.example.kyang.myapplication I/System.out: waiting for debugger to settle...
05-20 09:35:09.690 16251-16251/com.example.kyang.myapplication I/System.out: waiting for debugger to settle...
05-20 09:35:09.891 16251-16251/com.example.kyang.myapplication I/System.out: waiting for debugger to settle...
05-20 09:35:10.092 16251-16251/com.example.kyang.myapplication I/System.out: waiting for debugger to settle...
05-20 09:35:10.293 16251-16251/com.example.kyang.myapplication I/System.out: debugger has settled (1377)
05-20 09:35:10.310 16251-16251/com.example.kyang.myapplication W/System: ClassLoader referenced unknown path: /data/app/com.example.kyang.myapplication-2/lib/x86_64
05-20 09:35:10.571 16251-16251/com.example.kyang.myapplication W/System: ClassLoader referenced unknown path: /data/app/com.example.kyang.myapplication-2/lib/x86_64
05-20 09:35:10.883 16251-16304/com.example.kyang.myapplication D/OpenGLRenderer: Use EGL_SWAP_BEHAVIOR_PRESERVED: true
[ 05-20 09:35:10.893 16251:16251 D/ ]
HostConnection::get() New Host Connection established 0x7fdfb5ffea40, tid 16251
[ 05-20 09:35:10.940 16251:16304 D/ ]
HostConnection::get() New Host Connection established 0x7fdfb9ac6400, tid 16304
05-20 09:35:10.976 16251-16304/com.example.kyang.myapplication I/OpenGLRenderer: Initialized EGL, version 1.4
05-20 09:35:12.406 16251-16251/com.example.kyang.myapplication D/AndroidRuntime: Shutting down VM
--------- beginning of crash
05-20 09:35:12.410 16251-16251/com.example.kyang.myapplication E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.example.kyang.myapplication, PID: 16251
java.lang.RuntimeException: setAudioSource failed.
at android.media.MediaRecorder.setAudioSource(Native Method)
at com.example.kyang.myapplication.MainActivity.startRecording(MainActivity.java:65)
at com.example.kyang.myapplication.MainActivity.onRecord(MainActivity.java:33)
at com.example.kyang.myapplication.MainActivity.access$000(MainActivity.java:20)
at com.example.kyang.myapplication.MainActivity$RecordButton$1.onClick(MainActivity.java:90)
at android.view.View.performClick(View.java:5198)
at android.view.View$PerformClick.run(View.java:21147)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:148)
at android.app.ActivityThread.main(ActivityThread.java:5417)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
最佳答案
是的,有!您可以从 Activity 或 Fragment 中调用 requestPermissions()。这个例子适合来自 Activity 的调用
int YOUR_REQUEST_CODE = 200; // could be something else..
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) //check if permission request is necessary
{
ActivityCompat.requestPermissions(this, new String[] {android.Manifest.permission.RECORD_AUDIO, android.Manifest.permission.WRITE_EXTERNAL_STORAGE}, YOUR_REQUEST_CODE});
}
然后您可以检查 onRequestPermissionResult 是否已授予权限:
@Override
public void onRequestPermissionsResult(final int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
if (grantResults[0] == PackageManager.PERMISSION_GRANTED) {
if(requestCode == YOUR_REQUEST_CODE)
{
Log.i(TAG, "Permission granted");
//do what you wanted to do
}
} else {
Log.d(TAG, "Permission failed");
}
}
为了良好的实践,您应该检查是否已授予权限(以避免每次都询问而烦扰用户......)
if (PackageManager.PERMISSION_GRANTED == ActivityCompat.checkSelfPermission(getApplicationContext(),permissionString))
关于android - Android Studio 示例代码中的 setAudioSource 失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37351301/
我在使用以下代码时遇到问题: function http_file_exists($url){ $f=fopen($url,"r"); if($f){ fclose($f); retu
我已经通过 Git 部署到 Azure 几个月了,没有出现重大问题,但现在我似乎遇到了一个无法克服的错误。 我创建了一个新的 Azure 网站,为正在开发的项目创建单独的预览链接。我在新站点上设置了
我已经通过flutter创建了一个App并完成了它,我想在flutter文档中阅读时进行部署。 我收到此错误: FAILURE: Build failed with an exception. * W
我在Windows 10中使用一些简单的Powershell代码遇到了这个奇怪的问题,我认为这可能是我做错了,但我不是Powershell的天才。 我有这个: $ix = [System.Net.Dn
我正在尝试使用 RapidJSON 解析从服务器接收到的数据。以下是收到的确切字符串: [ { "Node": "9478149a08f9", "Address": "172.17
我尝试为 ios 编译 OpenCV。我总是收到这些错误。我用不同版本的opencv试了一下,结果都是一样的。 我运行这个:python 平台/ios/build_framework.py ios_o
我在一台机器上做基本的发布/订阅,我的客户端是 StackExchange-Redis 的 C# 客户端,我在同一台机器上运行基于 Windows 的 Redis 服务器(服务器版本 2.8.4) 当
我有这段代码,但无法执行,请帮我解决这个问题 连接 connect_error) { die ("connection failed: " . $terhubung->connect_erro
我在 tomcat 上运行并由 maven 编译的 Web 应用程序给出了以下警告和错误。我可以在本地存储库中看到所有 JAR,但有人可以帮忙吗。 WARNING: Failed to scan JA
我正在 Windows 8 上使用 Android Studio 开发一个 android 应用程序,我正在使用一些 native 代码。突然间我无法编译我的 C 文件。当我运行 ndk-build
下面的代码对类和结构的成员进行序列化和反序列化。序列化工作正常,但我在尝试使用 oarch >> BOOST_SERIALIZATION_NVP(outObj); 反序列化时遇到了以下错误; 代码中是
如果我运行此命令“rspec ./spec/requests/api/v1/password_reset_request_spec.rb”,此文件中的所有测试都会通过。 但是,当我运行“rspec”时
我在尝试执行测试以使用 Protractor 上传文件时出错,我的代码是这个 it('it should be possible to upload a file', function() {
System.loadLibrary("nativefaceswap"); 当我运行我的应用程序时,我在 Android Studio 中发现了此类错误。在logcat中显示: java.lang.U
我希望有人能帮助我!使用任何方法或命令行的任何 SSL/HTTPS 调用均无效。 我在 Windows 10 中使用 Ubuntu Server 18.04 作为子系统。我的问题是昨天才开始出现的,因
通过删除这两个值将日期字段从 null=True 和 Blank=True 更改为 required 时,使用 db.alter 命令时遇到问题。 当以下行被注释掉时,迁移运行不会出现问题。
我第一次使用 Heroku 尝试创建应用程序(使用 SendGrid 的 Inbound Parse Webhook"和 Twilio SMS 通过电子邮件发送和接收 SMS 消息)。通过 Virtu
我正在将我的 swift 项目更新到 Xcode 7 上的 Swift 2.0。xcode 在构建项目时报告了以下错误: 命令/Applications/Xcode.app/Contents/Deve
在我的代码中,SSL 库函数 SSL_library_init() 没有按预期返回 1。我如何才能看到它返回了什么错误? 我在 SSL_library_init() 之后调用了 SSL_load_er
我正在尝试运行在以下链接中找到的答案: Asynchronously Load the Contents of a Div 但是当我这样做时,我会遇到我不太理解的错误。 我的代码: $(documen
我是一名优秀的程序员,十分优秀!