Android 통화 자동 녹음 실현
휴대 전화 통화 상 태 를 감청 하고 받 을 때 녹음 을 시작 해 녹음 을 중단 하 는 것 이 주 된 사고 다.
AndroidManifest 설정
<!-- -->
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.PROCESS_OUTGOING_CALLS" />
<uses-permission android:name="android.permission.RECORD_AUDIO" />
<uses-permission android:name="android.permission.VIBRATE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.READ_CONTACTS" />
<uses-permission android:name="android.permission.WRITE_CONTACTS" />
<uses-permission android:name="com.android.launcher.permission.READ_SETTINGS" />
<uses-permission android:name="android.permission.READ_CALL_LOG" />
<uses-permission android:name="android.permission.CALL_PHONE" />
<uses-permission android:name="android.permission.WRITE_CALL_LOG" />
<uses-permission android:name="android.permission.MANAGE_ACCOUNTS" />
<uses-permission android:name="android.permission.GET_ACCOUNTS" />
<uses-permission android:name="android.permission.MODIFY_AUDIO_SETTINGS" />
그럼요.리스트 파일 에 서 비 스 를 등록 해 야 돼 요.
public abstract class CommonAdapter<T> extends BaseAdapter{
protected Context mContext;
protected List<T> mList;
protected int mLayoutId;
public CommonAdapter(Context context, List<T> list, int layoutId) {
mContext=context;
mList=list;
mLayoutId=layoutId;
}
//
public void refresh(List<T> list){
mList=list;
notifyDataSetChanged();
}
@Override
public int getCount() {
return mList.size();
}
@Override
public T getItem(int position) {
return mList.get(position);
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder = ViewHolder.getHolder(mContext, mLayoutId, convertView, parent);
convertView(holder,mList.get(position));
return holder.getConvertView();
}
public abstract void convertView(ViewHolder holder,T t);
}
public class RBOutPhoneCallState {
Context ctx;
public RBOutPhoneCallState(Context ctx) {
this.ctx = ctx;
}
/**
*
*
*/
public static final class ForeGroundCallState {
public static final String DIALING =
"com.sdvdxl.phonerecorder.FORE_GROUND_DIALING";
public static final String ALERTING =
"com.sdvdxl.phonerecorder.FORE_GROUND_ALERTING";
public static final String ACTIVE =
"com.sdvdxl.phonerecorder.FORE_GROUND_ACTIVE";
public static final String IDLE =
"com.sdvdxl.phonerecorder.FORE_GROUND_IDLE";
public static final String DISCONNECTED =
"com.sdvdxl.phonerecorder.FORE_GROUND_DISCONNECTED";
}
/**
* ,
*
*/
public void startListen() {
new RBReadPhoneLog(ctx).start();
Log.d("Recorder", " , ");
}
}
public class RBPhoneListener extends PhoneStateListener {
public RBRecorder recorder;
@Override
public void onCallStateChanged(int state, String incomingNumber) {
super.onCallStateChanged(state, incomingNumber);
switch (state) {
case TelephonyManager.CALL_STATE_IDLE: // ,
Log.i("TelephoneState", "IDLE");
//
if (recorder != null && !recorder.isCommingNumber() && recorder.isStarted()) {
Log.i("TelephoneState", "STOP RECORDER");
recorder.stop();
}
break;
case TelephonyManager.CALL_STATE_RINGING: //
Log.i("TelephoneState", "RINGING");
//
break;
case TelephonyManager.CALL_STATE_OFFHOOK: // ,
Log.i("TelephoneState", "OFFHOOK");
//
if (recorder == null) {
recorder = new RBRecorder();
}
if (!recorder.isStarted()) {
Log.i("TelephoneState", "START RECORDER");
if (incomingNumber != null && incomingNumber.length() >= 8) {
//CALLID
recorder.setPhoneNumber(String.valueOf(incomingNumber));
}
if (!recorder.isCommingNumber() && !recorder.isStarted()) {
recorder.start();
}
}
break;
}
Log.i("TelephoneState", String.valueOf(incomingNumber));
}
}
public class RBReadPhoneLog extends Thread {
private Context ctx;
private int logCount;
private static final String TAG = "LogInfo OutGoing Call";
/**
*
*
*/
private static class CallViewState {
public static final String FORE_GROUND_CALL_STATE = "mForeground";
}
/**
*
*
*/
private static class CallState {
public static final String DIALING = "DIALING";
public static final String ALERTING = "ALERTING";
public static final String ACTIVE = "ACTIVE";
public static final String IDLE = "IDLE";
public static final String DISCONNECTED = "DISCONNECTED";
}
public RBReadPhoneLog(Context ctx) {
this.ctx = ctx;
}
/**
* Log
* log
*
*/
@Override
public void run() {
Log.d(TAG, " ");
String[] catchParams = {"logcat", "InCallScreen *:s"};
String[] clearParams = {"logcat", "-c"};
try {
Process process=Runtime.getRuntime().exec(catchParams);
InputStream is = process.getInputStream();
BufferedReader reader = new BufferedReader(new InputStreamReader(is));
String line = null;
while ((line=reader.readLine())!=null) {
logCount++;
//
Log.v(TAG, line);
// 512
if (logCount>512) {
//
Runtime.getRuntime().exec(clearParams)
.destroy();// ,
logCount = 0;
Log.v(TAG, "----------- ---------------");
}
/*--------------------------------- -----------------------*/
//
if (line.contains(RBReadPhoneLog.CallViewState.FORE_GROUND_CALL_STATE)
&& line.contains(RBReadPhoneLog.CallState.IDLE)) {
Log.d(TAG, RBReadPhoneLog.CallState.IDLE);
}
// , , , ,
if (line.contains(RBReadPhoneLog.CallViewState.FORE_GROUND_CALL_STATE)
&& line.contains(RBReadPhoneLog.CallState.DIALING)) {
//
Intent dialingIntent = new Intent();
dialingIntent.setAction(RBOutPhoneCallState.ForeGroundCallState.DIALING);
ctx.sendBroadcast(dialingIntent);
Log.d(TAG, RBReadPhoneLog.CallState.DIALING);
}
//
if (line.contains(RBReadPhoneLog.CallViewState.FORE_GROUND_CALL_STATE)
&& line.contains(RBReadPhoneLog.CallState.ALERTING)) {
//
Intent dialingIntent = new Intent();
dialingIntent.setAction(RBOutPhoneCallState.ForeGroundCallState.ALERTING);
ctx.sendBroadcast(dialingIntent);
Log.d(TAG, RBReadPhoneLog.CallState.ALERTING);
}
// ,
if (line.contains(RBReadPhoneLog.CallViewState.FORE_GROUND_CALL_STATE)
&& line.contains(RBReadPhoneLog.CallState.ACTIVE)) {
//
Intent dialingIntent = new Intent();
dialingIntent.setAction(RBOutPhoneCallState.ForeGroundCallState.ACTIVE);
ctx.sendBroadcast(dialingIntent);
Log.d(TAG, RBReadPhoneLog.CallState.ACTIVE);
}
// ,
if (line.contains(RBReadPhoneLog.CallViewState.FORE_GROUND_CALL_STATE)
&& line.contains(RBReadPhoneLog.CallState.DISCONNECTED)) {
//
Intent dialingIntent = new Intent();
dialingIntent.setAction(RBOutPhoneCallState.ForeGroundCallState.DISCONNECTED);
ctx.sendBroadcast(dialingIntent);
Log.d(TAG, RBReadPhoneLog.CallState.DISCONNECTED);
}
}
} catch (IOException e) {
e.printStackTrace();
}
}
public class RBRecorder {
private String phoneNumber;
private MediaRecorder mrecorder;
private boolean started = false; //
private boolean isCommingNumber = false;//
private String TAG = "Recorder";
public RBRecorder(String phoneNumber) {
this.setPhoneNumber(phoneNumber);
}
public RBRecorder() {
}
public void start() {
started = true;
mrecorder = new MediaRecorder();
String fileName = new SimpleDateFormat("yy-MM-dd_HH-mm-ss")
.format(new Date(System.currentTimeMillis())) + ".mp3";
String fileSavePath = getFilePath(fileName);
File recordName = new File(fileSavePath);
try {
recordName.createNewFile();
Log.d("recorder", " " + recordName.getName());
} catch (IOException e) {
e.printStackTrace();
}
mrecorder.setAudioSource(MediaRecorder.AudioSource.DEFAULT);
mrecorder.setOutputFormat(MediaRecorder.OutputFormat.DEFAULT);
mrecorder.setAudioEncoder(MediaRecorder.AudioEncoder.DEFAULT);
mrecorder.setOutputFile(recordName.getAbsolutePath());
try {
mrecorder.prepare();
} catch (IllegalStateException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
mrecorder.start();
started = true;
Log.d(TAG, " ");
}
public void stop() {
try {
if (mrecorder != null) {
mrecorder.stop();
// reset
mrecorder.release();
mrecorder = null;
}
started = false;
} catch (IllegalStateException e) {
e.printStackTrace();
}
Log.d(TAG, " ");
}
public void pause() {
}
public String getPhoneNumber() {
return phoneNumber;
}
public void setPhoneNumber(String phoneNumber) {
this.phoneNumber = phoneNumber;
}
public boolean isStarted() {
return started;
}
public void setStarted(boolean hasStarted) {
this.started = hasStarted;
}
public boolean isCommingNumber() {
return isCommingNumber;
}
public void setIsCommingNumber(boolean isCommingNumber) {
this.isCommingNumber = isCommingNumber;
}
private String getFilePath(String fileName) {
File sdcardDir = null;
boolean sdcardExist = Environment.getExternalStorageState().equals(
android.os.Environment.MEDIA_MOUNTED);
if (sdcardExist) {
sdcardDir = Environment.getExternalStorageDirectory();
}
String filePath = sdcardDir.toString() + "/Recorder/Recorder";
File file = new File(filePath);
if (!file.exists()) {
file.mkdirs();
}
return filePath + "/" + fileName;
}
}
이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Bitrise에서 배포 어플리케이션 설정 테스트하기이 글은 Bitrise 광고 달력의 23일째 글입니다. 자체 또는 당사 등에서 Bitrise 구축 서비스를 사용합니다. 그나저나 며칠 전 Bitrise User Group Meetup #3에서 아래 슬라이드를 발표했...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.