我正在拨打一个电话录音应用程序,去话正在录音,但来电没有录音。我也测试了不同的手机,但问题是一样的。我已经测试了不同的方法,如“mediarcorder.audiosource.mic
”、“mediarcorder.audiosource.voice_call
”和“mediarcorder.audiosource.voice_communication
”。在尝试了不同的方法之后
myRecorder.setAudioSource(MediaRecorder.AudioSource.VOICE_UPLINK+ MediaRecorder.AudioSource.VOICE_DOWNLINK);
Main MainActivity代码
public class MainActivity extends AppCompatActivity {
Button start_rec, stop_rec;
TextView status;
MediaRecorder myRecorder;
SimpleDateFormat dateFormat;
String currentTimeStamp;
File outputFile;
private static final int REQUEST_CODE = 0;
private DevicePolicyManager mDPM;
private ComponentName mAdminName;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
start_rec = findViewById(R.id.start_rec);
stop_rec = findViewById(R.id.stop_rec);
status = findViewById(R.id.status);
try {
// Initiate DevicePolicyManager.
mDPM = (DevicePolicyManager) getSystemService(Context.DEVICE_POLICY_SERVICE);
mAdminName = new ComponentName(this, DeviceAdminDemo.class);
if (!mDPM.isAdminActive(mAdminName)) {
Intent intent = new Intent(DevicePolicyManager.ACTION_ADD_DEVICE_ADMIN);
intent.putExtra(DevicePolicyManager.EXTRA_DEVICE_ADMIN, mAdminName);
intent.putExtra(DevicePolicyManager.EXTRA_ADD_EXPLANATION, "Click on Activate button to secure your application.");
startActivityForResult(intent, REQUEST_CODE);
} else {
// mDPM.lockNow();
// Intent intent = new Intent(MainActivity.this,
// TrackDeviceService.class);
// startService(intent);
}
} catch (Exception e) {
e.printStackTrace();
}
start_rec.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
File sampleDir = new File(Environment.getExternalStorageDirectory().getAbsolutePath() + "/rec2");
File data = Environment.getDataDirectory();
boolean success = true;
if (!sampleDir.exists()) {
sampleDir.mkdirs();
success = sampleDir.mkdirs();
}
if (success) {
outputFile = new File(sampleDir, getCurrentTimeStamp() + ".mp3");
myRecorder = new MediaRecorder();
myRecorder.setAudioSource(MediaRecorder.AudioSource.VOICE_UPLINK + MediaRecorder.AudioSource.VOICE_DOWNLINK);
myRecorder.setOutputFormat(MediaRecorder.OutputFormat.THREE_GPP);
myRecorder.setAudioEncoder(MediaRecorder.OutputFormat.AMR_NB);
myRecorder.setAudioEncodingBitRate(16);
myRecorder.setAudioSamplingRate(44100);
myRecorder.setOutputFile(outputFile.getAbsolutePath());
try {
myRecorder.prepare();
myRecorder.start();
} catch (IllegalStateException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
status.setText("Recording");
status.setTextColor(Color.GREEN);
Toast.makeText(getApplicationContext(), "Recording...", Toast.LENGTH_SHORT).show();
}
}
});
stop_rec.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
try {
myRecorder.stop();
myRecorder.reset();
myRecorder.release();
myRecorder = null;
} catch (IllegalStateException e) {
e.printStackTrace();
} catch (RuntimeException e) {
// no valid audio/video data has been received
e.printStackTrace();
}
status.setText("Recording Stopped");
status.setTextColor(Color.RED);
Toast.makeText(getApplicationContext(), "Recording Stopped", Toast.LENGTH_SHORT).show();
// refresh();
}
});
}
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (REQUEST_CODE == requestCode) {
// Intent intent = new Intent(MainActivity.this, TService.class);
// startService(intent);
}
}
public void refresh() {
Intent intent = getIntent();
finish();
startActivity(intent);
}
public String getCurrentTimeStamp() {
try {
dateFormat = new SimpleDateFormat("yyyy-MM-dd HH-mm-ss");
currentTimeStamp = dateFormat.format(new Date()); // Find todays date
return currentTimeStamp;
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
}
设备管理代码
public class DeviceAdminDemo extends DeviceAdminReceiver {
@Override
public void onReceive(Context context, Intent intent) {
super.onReceive(context, intent);
}
public void onEnabled(Context context, Intent intent) {
};
public void onDisabled(Context context, Intent intent) {
};
}
清单代码
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
package="waceem.virk.voicerecording">
<uses-permission android:name="android.permission.RECORD_AUDIO" />
<uses-permission android:name="android.permission.CAPTURE_AUDIO_OUTPUT"
tools:ignore="ProtectedPermissions" />
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.read_external_storage" />
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:requestLegacyExternalStorage="true"
android:roundIcon="@mipmap/ic_launcher_round"
android:supportsRtl="true"
android:theme="@style/Theme.VoiceRecording">
<activity android:name=".MainActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<receiver
android:name=".DeviceAdminDemo"
android:permission="android.permission.BIND_DEVICE_ADMIN" >
<meta-data
android:name="android.app.device_admin"
android:resource="@xml/my_admin" />
<intent-filter>
<action android:name="android.app.action.DEVICE_ADMIN_ENABLED" />
<action android:name="android.app.action.DEVICE_ADMIN_DISABLED" />
<action android:name="android.app.action.DEVICE_ADMIN_DISABLE_REQUESTED" />
<action android:name="android.intent.action.BOOT_COMPLETED" />
<category android:name="android.intent.category.HOME" />
</intent-filter>
</receiver>
</application>
</manifest>
要使用它,您需要Manifest.permission.capture_Audio_Output权限,这是一个系统权限。这意味着你需要由OEM预装,或者用户需要根他们的设备,并知道如何使你的应用程序成为一个系统应用程序。
基本上Android不允许你这么做。你能做的最多就是让它用普通的麦克风捕捉,希望来电者大声说话,或者让用户把它放在免持话筒上。
我正在开发一个用于录制通话的应用程序。这是我的代码片段。 这适用于android 7以下的设备,但当我使用Android 7移动设备时,我只能听到传出的声音,但听不到传入的声音。 有人能帮我修理它吗?
当完成时,我有一个segue被5种不同的方法调用。我发现,如果我只调用一次segue(仅为一个设置动画),一切都可以正常工作,但通过调用多个,会出现以下错误: 完成块(所有动画相同) 因此,当所有五个动画都完成(并满足条件)时,它会调用segue 5次并创建错误(我非常确定,因为我做了很多测试) 我想要的是,当动画(并满足条件)完成时,可以毫无错误地过渡到。有什么帮助吗?
在Twilio中实现语音信箱。如果来电者在录音开始前挂断电话,我如何获得回拨? 传入呼叫的超时后,回调URL将以以下方式响应: 我似乎遇到的问题是,如果调用方在谓词执行时挂断,谓词将永远不会执行,因此应用程序永远不会收到回调。 在这种情况下有可能接到回电吗?如果是这样,我该如何做到这一点?
请大家对我的问题解释如下。 我的java web应用程序使用org.apache.log4j. Logger库。 我把这样的命令:log.info("这是log4j输出") 我又放了一个类似S的命令ystem.out.println("这是system out put") 好的,我通过tomcat服务器部署Web应用程序。 现在,我正在跟踪catalina的日志。出来我的问题是: 在应用程序运行期
当我试图使用方法从应用程序传递param时,我无法在twiML应用程序上获得这些param。但是当我试图用FormData从POSTMAN传递相同的数据时,它工作得很好,也成功地能够创建调用。 请您帮助我如何使用从iOS应用程序传递到twiML的param PHP中的TwiML应用程序: 引用TwiML应用程序代码 https://github.com/twilio/voice-quickstar
我有一个音乐播放器活动来控制歌曲的播放。我已经阅读了有关管理音频焦点的文档,并在