如何使用android.telecom.InCallService实现呼叫合并,等待和呼叫会议



我在我的一个项目中使用了android.telecom.InCallService。它很好地提供了所有电话状态,但是一旦您实现了此服务,您需要创建自己的拨号器,它可以处理所有呼叫功能,即呼叫合并,会议,呼叫等待等。

任何实现呼叫等待,合并和会议的链接或建议都将有很大帮助。

我只在这个存储库中找到了如何保持呼叫: 自定义电话拨号器。请参阅InCallService,在方法onCallAdded(覆盖)上创建一个新的OnGoingCall。

    onCallAdded(Call call){
    ....
    new OngoingCall().setCall(call)
    ....
    }

在OncontinuCall类中,您需要创建要在活动中使用的方法,例如回答,拒绝等。你们中的一个需要,按住/取消保持:

public class OngoingCall {
public static BehaviorSubject<Integer> state = BehaviorSubject.create();
private static Call call;
private Object callback = new Call.Callback() {
    @Override
    public void onStateChanged(Call call, int newState) {
        super.onStateChanged(call, newState);
        state.onNext(newState);
    }
};
public final void setCall(@Nullable Call value) {
    if (call != null) {
        call.unregisterCallback((Call.Callback)callback);
    }
    if (value != null) {
        value.registerCallback((Call.Callback)callback);
        state.onNext(value.getState());
    }
    call = value;
}
public void answer() {
    assert call != null;
    call.answer(VideoProfile.STATE_AUDIO_ONLY);
}
public void hangup() {
    assert call != null;
    call.disconnect();
}
public void hold(){
    assert call != null;
    call.hold();
}
public void unHold(){
    assert call != null;
    call.unhold();
}
....
}

在活动中,在按钮侦听器中使用以下方法:

private OngoingCall ongoingCall;
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_call);
    ButterKnife.bind(this);
    ongoingCall = new OngoingCall();
    disposables = new CompositeDisposable();
    getWindow().addFlags(WindowManager.LayoutParams.FLAG_SHOW_WHEN_LOCKED
            | WindowManager.LayoutParams.FLAG_DISMISS_KEYGUARD
            | WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON
            | WindowManager.LayoutParams.FLAG_TURN_SCREEN_ON);
    number = Objects.requireNonNull(getIntent().getData()).getSchemeSpecificPart();
}
@OnClick(R.id.answer)
public void onAnswerClicked() {
    ongoingCall.answer();
}
@OnClick(R.id.hangup)
public void onHangupClicked() {
    ongoingCall.hangup();
}
@OnClick(R.id.hold)
public void onHoldClicked(){
    ongoingCall.hold();
}
@OnClick(R.id.unhold)
public void onUnHoldClicked(){
    ongoingCall.unHold();
}
}

最新更新