48

私たちが必要とすることの 1 つは、発信呼び出しを制御することであり、少なくともアプリケーションから停止できるようにするアプリケーションを開発しています。

Intent.ACTION_CALL既存のアクティビティから使用してみました:

Intent callIntent = new Intent(Intent.ACTION_CALL, Uri.parse("tel:" + phoneNumber)); 
startActivity(callIntent); 

ただし、呼び出しを停止することは、API では許可されていないようです。

回避策を提案できますか?

例: 通話中に機内モードを有効にしますか? ほんの一例です。このハックは私にはうまくいきませんでした。

4

8 に答える 8

31

で発信通話をキャプチャするBroadcastReceiverことについては言及されていますが、ダイヤルする前に通話を終了したい場合は、これが間違いなく最善の方法です。

ただし、ダイヤルまたは通話中になると、その手法は機能しなくなります。これまでに遭遇した電話を切る唯一の方法は、 Java Reflectionを介して電話を切ることです。これはパブリック API の一部ではないため、慎重に使用し、依存しないようにする必要があります。Android の内部構成を変更すると、アプリケーションが効果的に機能しなくなります。

Prasanta Paul のブログは、それをどのように達成できるかを示しています。以下に要約します。

ITelephonyオブジェクトの取得:

TelephonyManager tm = (TelephonyManager) context
        .getSystemService(Context.TELEPHONY_SERVICE);
try {
    // Java reflection to gain access to TelephonyManager's
    // ITelephony getter
    Log.v(TAG, "Get getTeleService...");
    Class c = Class.forName(tm.getClass().getName());
    Method m = c.getDeclaredMethod("getITelephony");
    m.setAccessible(true);
    com.android.internal.telephony.ITelephony telephonyService =
            (ITelephony) m.invoke(tm);
} catch (Exception e) {
    e.printStackTrace();
    Log.e(TAG,
            "FATAL ERROR: could not connect to telephony subsystem");
    Log.e(TAG, "Exception object: " + e);
}

通話を終了する:

telephonyService.endCall();
于 2011-03-15T15:54:51.503 に答える
28

編集: Android P 以降については、 https ://stackoverflow.com/a/51121175/450148 を参照してください。

これを試して:

( Reflection を使用して、高度なテレフォニー機能にアクセスし、何かを変更しました)

// required permission <uses-permission android:name="android.permission.CALL_PHONE"/>

try {
    //String serviceManagerName = "android.os.IServiceManager";
    String serviceManagerName = "android.os.ServiceManager";
    String serviceManagerNativeName = "android.os.ServiceManagerNative";
    String telephonyName = "com.android.internal.telephony.ITelephony";

    Class telephonyClass;
    Class telephonyStubClass;
    Class serviceManagerClass;
    Class serviceManagerStubClass;
    Class serviceManagerNativeClass;
    Class serviceManagerNativeStubClass;

    Method telephonyCall;
    Method telephonyEndCall;
    Method telephonyAnswerCall;
    Method getDefault;

    Method[] temps;
    Constructor[] serviceManagerConstructor;

    // Method getService;
    Object telephonyObject;
    Object serviceManagerObject;

    telephonyClass = Class.forName(telephonyName);
    telephonyStubClass = telephonyClass.getClasses()[0];
    serviceManagerClass = Class.forName(serviceManagerName);
    serviceManagerNativeClass = Class.forName(serviceManagerNativeName);

    Method getService = // getDefaults[29];
    serviceManagerClass.getMethod("getService", String.class);

    Method tempInterfaceMethod = serviceManagerNativeClass.getMethod(
                "asInterface", IBinder.class);

    Binder tmpBinder = new Binder();
    tmpBinder.attachInterface(null, "fake");

    serviceManagerObject = tempInterfaceMethod.invoke(null, tmpBinder);
    IBinder retbinder = (IBinder) getService.invoke(serviceManagerObject, "phone");
    Method serviceMethod = telephonyStubClass.getMethod("asInterface", IBinder.class);

    telephonyObject = serviceMethod.invoke(null, retbinder);
    //telephonyCall = telephonyClass.getMethod("call", String.class);
    telephonyEndCall = telephonyClass.getMethod("endCall");
    //telephonyAnswerCall = telephonyClass.getMethod("answerRingingCall");

    telephonyEndCall.invoke(telephonyObject);

} catch (Exception e) {
    e.printStackTrace();
    Log.error(DialerActivity.this,
                "FATAL ERROR: could not connect to telephony subsystem");
    Log.error(DialerActivity.this, "Exception object: " + e);
}
于 2011-12-05T02:33:14.323 に答える
21
  1. BroadcastReceiver優先度0でを作成します。
  2. BCでは、そのメソッドのACTION_NEW_OUTGOING_CALL意図を傍受しますonReceive
  3. setResultData(null)同じメソッドで呼び出す

これにより、通話が開始されなくなります(受信者が最後にインテントを処理した場合に限ります)

于 2009-03-12T03:44:13.313 に答える
5

機内モードを有効にしてから無効にすることができます。

android.provider.Settings.System.putInt(getContentResolver(),
        android.provider.Settings.System.AIRPLANE_MODE_ON, 1);

Intent intent = new Intent(Intent.ACTION_AIRPLANE_MODE_CHANGED);
intent.putExtra("state", 1);
sendBroadcast(new Intent("android.intent.action.AIRPLANE_MODE"));
sendBroadcast(intent);
android.provider.Settings.System.putInt(getContentResolver(),
        android.provider.Settings.System.AIRPLANE_MODE_ON, 0);

intent.putExtra("state", 0);
sendBroadcast(new Intent("android.intent.action.AIRPLANE_MODE"));
sendBroadcast(intent);
于 2010-06-18T08:44:27.993 に答える
4

イラナの場合:

public class ilanasReceiver extends BroadcastReceiver {
    public void onReceive(Context context, Intent intent) {
        if (intent.getAction().equals(Intent.ACTION_NEW_OUTGOING_CALL)) {
            if (getResultData()!=null) {
                String number = "123456";
                setResultData(number);
            }
        }
    }
}

さらに、マニフェストのパッケージセクションに入れます:

<uses-permission android:name="android.permission.PROCESS_OUTGOING_CALLS" />

それだけです。

于 2010-08-31T20:16:57.260 に答える
3

素晴らしいいたずらの可能性を考えると、これが許されれば私は驚きます。

このスレッドは、APIが呼び出しを終了できないことを明確に示しています。他の人は試しました。

于 2009-03-01T20:08:48.530 に答える
0

ACTION_NEW_OUTGOING_CALLのドキュメントによると

インテントには、次の追加の値があります。

EXTRA_PHONE_NUMBER-元々ダイヤルされることを意図した電話番号。

ブロードキャストが終了すると、resultDataが実際に呼び出す番号として使用されます。nullの場合、呼び出しは行われません。

于 2010-07-31T02:48:14.557 に答える