Android检测来电?

时间:2013-06-04 22:48:44

标签: java android android-intent

我正在尝试开发一个应用程序,如果有人在一段时间内连续多次呼叫你,它会打开你的铃声。这是我的第一个真正的应用程序,所以我有点卡住了。

如果在内部列表中收到呼叫,我将如何记录?这需要一个始终运行的服务,还是只能通过接收拨号器应用程序的意图在普通的应用程序中工作?

如果这个问题有点含糊,我道歉。

2 个答案:

答案 0 :(得分:4)

最好的方法是,通过在清单中声明广播接收器,这将导致每次触发事件时都会执行BroadcastReceiver类上的代码,而无需在后台运行所有服务时间,让操作系统为您处理观察部分......

<receiver android:name=".ReceiverExample">
  <intent-filter>
    <action android:name="android.intent.action.PHONE_STATE" />
  </intent-filter>
</receiver>

现在,在您的broadcastreceiver类“ReceiverExample”中,创建一个SharedPreference来存储进入呼叫的数量,并根据该数量,您可以验证是否有时间做其他事情......

  public class ReceiverExample extends BroadcastReceiver {
    @Override
    public void onReceive(Context context, Intent intent) {
     //Logic to listen incoming calls, and keep track of them using Shared Preferences..
    }
  }

服务适用于长期任务,但其自身的操作系统非常适合监控/观察事件(如电话事件,例如Incomming呼叫...),尽量不要通过创建服务来重新执行操作系统工作已知事件......

此致

答案 1 :(得分:0)

use single Tone Class for recording 


public class Recording {

    private static MediaRecorder recorder;
    private File audiofile;

    private static Recording mInstance;

    public MediaRecorder getRecorder() {
        System.out.println("From singleton..!!!");
        return recorder;
    }

    public static Recording getInstance(Context context) {
        return mInstance == null ? (mInstance = new Recording(context))
                : mInstance;
    }

    private Recording(Context context) {
        System.out.println("Again initiated object");
        File sampleDir = Environment.getExternalStorageDirectory();
        try {
            audiofile = File.createTempFile("" + new Date().getTime(), ".amr",
                    sampleDir);
        } catch (IOException e) {
            e.printStackTrace();
            return;
        }

        recorder = new MediaRecorder();
        recorder.setAudioSource(MediaRecorder.AudioSource.MIC);
        recorder.setOutputFormat(MediaRecorder.OutputFormat.AMR_NB);
        recorder.setAudioEncoder(MediaRecorder.AudioEncoder.AMR_NB);
        recorder.setOutputFile(audiofile.getAbsolutePath());
    }
}