2

以下をコードに統合して、phonestatelistenerの登録を解除しようとしています

TelephonyManager mgr = (TelephonyManager) getSystemService(TELEPHONY_SERVICE); 
if(mgr != null) {
    mgr.listen(phoneStateListener, PhoneStateListener.LISTEN_NONE); 
} 

バックグラウンドで実行され、番号がブロッキングリストにあるかどうかをチェックするサービスがあります。はいの場合、それは呼び出しますPhonestateListener

TelephonyManager mTM = (TelephonyManager)this.getSystemService(Context.TELEPHONY_SERVICE);
mTM.listen(new phoneStateListener(NumberInbound,Msg_to_display,mTM), PhoneStateListener.LISTEN_CALL_STATE);

しかし、ブロックリストから番号を削除するときに、登録を解除したいと思いphonestatelistnerます。代わりに、それphonestatelistenerは常に登録されており、以前に削除したmsisdnはまだブロックされています。

手伝ってくれますか ?

のコードphonestatelistner

class phoneStateListener extends PhoneStateListener {

    String inbounda;
    int MessagetoDisplay;
    String msg;
    String reply;
    TelephonyManager myt;
    MyService calltoService;
    boolean mBound = false;
    private static final String TAG = "PHONELISTENER";

    phoneStateListener(String inbound,int Message,TelephonyManager t) {
        inbounda = inbound;
        MessagetoDisplay = Message;
        myt = t;
    }

    public void onCallStateChanged(int state, String incomingNumber) {

        if(!incomingNumber.equals(inbounda)){

        } else { 

            final String TAG = "Phone call"; 
            ITelephony telephonyService;
        //new code
            Log.v("Phone State", "state:"+state);

            switch (state) {
                case TelephonyManager.CALL_STATE_IDLE:
                   Log.v("Phone State", "incomingNumber:"+incomingNumber+" ended");
                    break;
                case TelephonyManager.CALL_STATE_OFFHOOK:
                    Log.v("Phone State", "incomingNumber:"+incomingNumber+" picked up");
                    break;
                case TelephonyManager.CALL_STATE_RINGING:
                    if(inbounda.equalsIgnoreCase(incomingNumber)){
                        Log.v("ARE THE SAME...............................", "incomingNumber:"+incomingNumber+ "inbound:"+ inbounda + "MSG TO DISPLAY" +msg);

                        try{
                            Class c = Class.forName(myt.getClass().getName());   
                            Method m = c.getDeclaredMethod("getITelephony");   
                            m.setAccessible(true);   
                            telephonyService = (ITelephony) m.invoke(myt);   
                            telephonyService.silenceRinger();   
                            telephonyService.endCall();
                        } catch (Exception e) {
                            e.printStackTrace();
                        }

                        try{
                            Thread.currentThread().sleep(4000);
                            replyChecker(MessagetoDisplay);
                        } catch(InterruptedException ie){

                        }
                    }
                    break;
                default:
                    break;
            }
        }
    }

    public String replyChecker(int Check) {
        SmsManager mySMS = SmsManager.getDefault();
        String destination = inbounda;     
        //open - to be extended to allow user to define own tailored message 
        String Meeting = "Sorry I am at a meeting. Graham  ";
        String Gym = "I am currently at the gym and will respond to you later. Graham ";
        String NewYearsEve = "Happy New Year to you and your loved ones. Graham ";

        if(Check == 1) {
            Log.v("HERE NOW1",":");
            reply  = Meeting;

            mySMS.sendTextMessage(destination, null, Meeting, null, null);
            return reply;
        } else if (Check == 2) {
            Log.v("HERE NOW2",":");
            reply = Gym;
            mySMS.sendTextMessage(destination, null, Gym, null, null);
            return reply;
        } else if (Check == 3) {
            Log.v("HERE NOW3",":");
            reply = NewYearsEve;
            mySMS.sendTextMessage(destination, null, NewYearsEve, null, null);
            return reply;
        }
        // TODO Auto-generated method stub
        return reply;
    }
}
4

2 に答える 2

1

実際、私はサービスに放送受信機を実装することでこの問題を回避しました。私が直面していた問題は、PowerManagerに関係するものではなく、サービスが着信電話をリッスンしていないことでした。

android.intent.action.PHONE_STATEをリッスンしている放送受信機が仕事をしました

ありがとうグラハム

于 2012-10-21T17:13:42.870 に答える
1

アプリケーション全体で複数のアクティビティがあり、電話がスタンバイになり、アクティビティ間でネイティブ化する場合に備えて、状態を維持する方法が必要です。

ユーザーがアプリを使用している間は電話がスタンバイ状態になることはありません。通常のアプリケーション フローに漠然と似ていると仮定すると、アクティビティの合間には確実にスタンバイ状態になることはありません。デバイスは非アクティブ後にのみスリープ状態になり、ユーザーが何かをタップしてあるアクティビティから次のアクティビティに移動すると、非アクティブ タイマーがリセットされます。

画面上で何らかのアクティビティが行われている間、デバイスを起動させておきたい場合は、android:keepScreenOnまたはsetKeepScreenOn()を使用Viewして、独自の をいじる必要はありませんWakeLock

于 2012-10-16T21:18:15.850 に答える