diff options
Diffstat (limited to 'InCallUI')
-rw-r--r-- | InCallUI/AndroidManifest.xml | 2 | ||||
-rw-r--r-- | InCallUI/src/com/android/incallui/CallMonitorService.java | 82 |
2 files changed, 62 insertions, 22 deletions
diff --git a/InCallUI/AndroidManifest.xml b/InCallUI/AndroidManifest.xml index b5c47609a..4ab4868bc 100644 --- a/InCallUI/AndroidManifest.xml +++ b/InCallUI/AndroidManifest.xml @@ -27,7 +27,7 @@ <service android:name="CallMonitorService"> <intent-filter> - <action android:name="com.android.telephony.common.ICallMonitorService" /> + <action android:name="com.android.services.telephony.common.ICallMonitorService" /> </intent-filter> </service> diff --git a/InCallUI/src/com/android/incallui/CallMonitorService.java b/InCallUI/src/com/android/incallui/CallMonitorService.java index c1325f8ae..7ac47785b 100644 --- a/InCallUI/src/com/android/incallui/CallMonitorService.java +++ b/InCallUI/src/com/android/incallui/CallMonitorService.java @@ -22,6 +22,8 @@ import android.content.Intent; import android.content.ServiceConnection; import android.os.Handler; import android.os.IBinder; +import android.os.Message; +import android.util.Log; import android.widget.Toast; import com.android.services.telephony.common.ICallMonitorService; @@ -31,30 +33,68 @@ import com.android.services.telephony.common.ICallMonitorService; */ public class CallMonitorService extends Service { - @Override - public void onCreate() { - super.onCreate(); - } + private static final String TAG = CallMonitorService.class.getSimpleName(); + private static final boolean DBG = false; // TODO: Have a shared location for this. + private MainHandler mMainHandler; - @Override - public void onDestroy() { - } + private static final int DO_SHOW_ALERT = 1; - @Override - public IBinder onBind(Intent intent) { - return mBinder; - } + @Override + public void onCreate() { + super.onCreate(); + mMainHandler = new MainHandler(); + } - private final ICallMonitorService.Stub mBinder = new ICallMonitorService.Stub() { - public void onIncomingCall(int callId) { - showAlert("New Call came in: " + callId); - } - }; + @Override + public void onDestroy() { + } - private void showAlert(String message) { - Context context = getApplicationContext(); - int duration = Toast.LENGTH_SHORT; + @Override + public IBinder onBind(Intent intent) { + return mBinder; + } - Toast.makeText(context, message, duration).show(); - } + private final ICallMonitorService.Stub mBinder = new ICallMonitorService.Stub() { + public void onIncomingCall(int callId) { + final Message msg = mMainHandler.obtainMessage(DO_SHOW_ALERT, 0, 0, + "Incoming call with call Id: " + callId); + mMainHandler.sendMessage(msg); + } + }; + + /** + * Handles messages from the Service methods so that they get called on the + * main thread. Service methods by default are handled in background threads. + */ + class MainHandler extends Handler { + MainHandler() { + super(getApplicationContext().getMainLooper(), null, true); + } + + @Override + public void handleMessage(Message msg) { + executeMessage(msg); + } + } + + private void showAlert(String message) { + Context context = getApplicationContext(); + int duration = Toast.LENGTH_SHORT; + + Toast.makeText(context, message, duration).show(); + } + + private void executeMessage(Message msg) { + if (DBG) { + Log.d(TAG, "executeMessage(" + msg.what + ")"); + } + switch (msg.what) { + case DO_SHOW_ALERT: + showAlert((String) msg.obj); + break; + default: + break; + + } + } } |