Loading InCallUI/src/com/android/incallui/Call.java +7 −0 Original line number Diff line number Diff line Loading @@ -401,6 +401,7 @@ public class Call { private String mCallSubject; private PhoneAccountHandle mPhoneAccountHandle; private long mBaseChronometerTime = 0; private boolean mIsOutgoing = false; /** * Indicates whether the phone account associated with this call supports specifying a call Loading Loading @@ -691,9 +692,15 @@ public class Call { } else if (mState == State.DISCONNECTED) { mLogState.duration = getConnectTimeMillis() == 0 ? 0: System.currentTimeMillis() - getConnectTimeMillis(); } else if (mState == State.DIALING || mState == State.CONNECTING) { mIsOutgoing = true; } } public boolean isOutgoing() { return mIsOutgoing; } public int getNumberPresentation() { return mTelecomCall == null ? null : mTelecomCall.getDetails().getHandlePresentation(); } Loading InCallUI/src/com/android/incallui/InCallPresenter.java +8 −0 Original line number Diff line number Diff line Loading @@ -114,6 +114,7 @@ public class InCallPresenter implements CallList.Listener, private AudioModeProvider mAudioModeProvider; private StatusBarNotifier mStatusBarNotifier; private ExternalCallNotifier mExternalCallNotifier; private InCallVibrationHandler mInCallVibrationHandler; private ContactInfoCache mContactInfoCache; private Context mContext; private CallList mCallList; Loading Loading @@ -331,6 +332,9 @@ public class InCallPresenter implements CallList.Listener, mExternalCallNotifier = externalCallNotifier; addListener(mStatusBarNotifier); mInCallVibrationHandler = new InCallVibrationHandler(context); addListener(mInCallVibrationHandler); mAudioModeProvider = audioModeProvider; mProximitySensor = proximitySensor; Loading Loading @@ -1694,6 +1698,10 @@ public class InCallPresenter implements CallList.Listener, mStatusBarNotifier = null; InCallCsRedialHandler.getInstance().tearDown(); if (mInCallVibrationHandler != null) { removeListener(mInCallVibrationHandler); } mInCallVibrationHandler = null; if (mCallList != null) { mCallList.removeListener(this); Loading InCallUI/src/com/android/incallui/InCallVibrationHandler.java 0 → 100644 +140 −0 Original line number Diff line number Diff line /* * Copyright (C) 2014 The CyanogenMod Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.android.incallui; import android.content.Context; import android.content.SharedPreferences; import android.os.Handler; import android.os.Message; import android.os.Vibrator; import android.preference.PreferenceManager; import android.telecom.DisconnectCause; import com.android.incallui.InCallPresenter.InCallState; public class InCallVibrationHandler extends Handler implements InCallPresenter.InCallStateListener { private static final int MSG_VIBRATE_45_SEC = 1; private static final String KEY_VIBRATE_CALL_WAITING = "incall_vibrate_call_waiting"; private static final String KEY_VIBRATE_OUTGOING = "incall_vibrate_outgoing"; private static final String KEY_VIBRATE_45SECS = "incall_vibrate_45secs"; private static final String KEY_VIBRATE_HANGUP = "incall_vibrate_hangup"; private SharedPreferences mPrefs; private Vibrator mVibrator; private Call mActiveCall; public InCallVibrationHandler(Context context) { mPrefs = PreferenceManager.getDefaultSharedPreferences(context); mVibrator = (Vibrator) context.getSystemService(Context.VIBRATOR_SERVICE); } @Override public void handleMessage(Message msg) { switch (msg.what) { case MSG_VIBRATE_45_SEC: vibrate(70, 0, 0); sendEmptyMessageDelayed(MSG_VIBRATE_45_SEC, 60000); break; } } @Override public void onStateChange(InCallState oldState, InCallState newState, CallList callList) { Call activeCall = callList.getActiveCall(); if (activeCall != null && mActiveCall == null) { Log.d(this, "Transition to active call " + activeCall); if (activeCall.isOutgoing()) { handleOutgoingCallVibration(activeCall); } mActiveCall = activeCall; } else if (activeCall != null && callList.getIncomingCall() != null && !callList.getIncomingCall().equals(activeCall)) { Log.d(this, "New incoming call" + callList.getIncomingCall()); handleCallWaitingVibration(activeCall); } else if (activeCall == null && mActiveCall != null) { Log.d(this, "Transition from active call " + mActiveCall); handleCallEnd(mActiveCall); mActiveCall = null; } } private void handleOutgoingCallVibration(Call call) { long durationMillis = System.currentTimeMillis() - call.getConnectTimeMillis(); Log.d(this, "Start outgoing call: duration = " + durationMillis); if (mPrefs.getBoolean(KEY_VIBRATE_OUTGOING, false) && durationMillis < 200) { vibrate(100, 200, 0); } if (mPrefs.getBoolean(KEY_VIBRATE_45SECS, false)) { start45SecondVibration(durationMillis); } } private void handleCallWaitingVibration(Call call) { Log.d(this, "Start call waiting vibration"); if (mPrefs.getBoolean(KEY_VIBRATE_CALL_WAITING, false)) { vibrate(200, 300, 500); } } private void handleCallEnd(Call call) { long durationMillis = System.currentTimeMillis() - call.getConnectTimeMillis(); DisconnectCause cause = call.getDisconnectCause(); boolean localDisconnect = // Disconnection not yet processed call.getState() == Call.State.DISCONNECTING || // Disconnection already processed (cause != null && cause.getCode() == DisconnectCause.LOCAL); Log.d(this, "Ending active call: duration = " + durationMillis + ", locally disconnected = " + localDisconnect); if (mPrefs.getBoolean(KEY_VIBRATE_HANGUP, false) && !localDisconnect && durationMillis > 500) { vibrate(50, 100, 50); } // Stop 45-second vibration removeMessages(MSG_VIBRATE_45_SEC); } private void start45SecondVibration(long callDurationMillis) { callDurationMillis = callDurationMillis % 60000; Log.d(this, "vibrate start @" + callDurationMillis); removeMessages(MSG_VIBRATE_45_SEC); long timer; if (callDurationMillis > 45000) { // Schedule the alarm at the next minute + 45 secs timer = 45000 + 60000 - callDurationMillis; } else { // Schedule the alarm at the first 45 second mark timer = 45000 - callDurationMillis; } sendEmptyMessageDelayed(MSG_VIBRATE_45_SEC, timer); } private void vibrate(int v1, int p1, int v2) { long[] pattern = new long[] { 0, v1, p1, v2 }; mVibrator.vibrate(pattern, -1); } } res/values/cm_strings.xml 0 → 100644 +25 −0 Original line number Diff line number Diff line <?xml version="1.0" encoding="utf-8"?> <!-- Copyright (C) 2013-2014 The CyanogenMod Project Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. --> <resources xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2"> <string name="incall_vibration_category_key" translatable="false">dialer_general_incall_vibration_category_key</string> <string name="incall_vibration_category_title">In-call vibration</string> <string name="incall_vibrate_outgoing_title">Vibrate on answer</string> <string name="incall_vibrate_call_waiting_title">Vibrate on call waiting</string> <string name="incall_vibrate_hangup_title">Vibrate on hang up</string> <string name="incall_vibrate_45_title">Vibrate every minute</string> <string name="incall_vibrate_45_summary">Vibrates at the 45 second mark of every minute during outgoing calls</string> </resources> res/xml/sound_settings.xml +23 −0 Original line number Diff line number Diff line Loading @@ -43,4 +43,27 @@ android:entries="@array/dtmf_tone_length_entries" android:entryValues="@array/dtmf_tone_length_entry_values" /> <PreferenceCategory android:key="@string/incall_vibration_category_key" android:title="@string/incall_vibration_category_title"> <CheckBoxPreference android:key="incall_vibrate_outgoing" android:title="@string/incall_vibrate_outgoing_title" /> <CheckBoxPreference android:key="incall_vibrate_call_waiting" android:title="@string/incall_vibrate_call_waiting_title" /> <CheckBoxPreference android:key="incall_vibrate_hangup" android:title="@string/incall_vibrate_hangup_title" /> <CheckBoxPreference android:key="incall_vibrate_45secs" android:title="@string/incall_vibrate_45_title" android:summary="@string/incall_vibrate_45_summary" /> </PreferenceCategory> </PreferenceScreen> Loading
InCallUI/src/com/android/incallui/Call.java +7 −0 Original line number Diff line number Diff line Loading @@ -401,6 +401,7 @@ public class Call { private String mCallSubject; private PhoneAccountHandle mPhoneAccountHandle; private long mBaseChronometerTime = 0; private boolean mIsOutgoing = false; /** * Indicates whether the phone account associated with this call supports specifying a call Loading Loading @@ -691,9 +692,15 @@ public class Call { } else if (mState == State.DISCONNECTED) { mLogState.duration = getConnectTimeMillis() == 0 ? 0: System.currentTimeMillis() - getConnectTimeMillis(); } else if (mState == State.DIALING || mState == State.CONNECTING) { mIsOutgoing = true; } } public boolean isOutgoing() { return mIsOutgoing; } public int getNumberPresentation() { return mTelecomCall == null ? null : mTelecomCall.getDetails().getHandlePresentation(); } Loading
InCallUI/src/com/android/incallui/InCallPresenter.java +8 −0 Original line number Diff line number Diff line Loading @@ -114,6 +114,7 @@ public class InCallPresenter implements CallList.Listener, private AudioModeProvider mAudioModeProvider; private StatusBarNotifier mStatusBarNotifier; private ExternalCallNotifier mExternalCallNotifier; private InCallVibrationHandler mInCallVibrationHandler; private ContactInfoCache mContactInfoCache; private Context mContext; private CallList mCallList; Loading Loading @@ -331,6 +332,9 @@ public class InCallPresenter implements CallList.Listener, mExternalCallNotifier = externalCallNotifier; addListener(mStatusBarNotifier); mInCallVibrationHandler = new InCallVibrationHandler(context); addListener(mInCallVibrationHandler); mAudioModeProvider = audioModeProvider; mProximitySensor = proximitySensor; Loading Loading @@ -1694,6 +1698,10 @@ public class InCallPresenter implements CallList.Listener, mStatusBarNotifier = null; InCallCsRedialHandler.getInstance().tearDown(); if (mInCallVibrationHandler != null) { removeListener(mInCallVibrationHandler); } mInCallVibrationHandler = null; if (mCallList != null) { mCallList.removeListener(this); Loading
InCallUI/src/com/android/incallui/InCallVibrationHandler.java 0 → 100644 +140 −0 Original line number Diff line number Diff line /* * Copyright (C) 2014 The CyanogenMod Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.android.incallui; import android.content.Context; import android.content.SharedPreferences; import android.os.Handler; import android.os.Message; import android.os.Vibrator; import android.preference.PreferenceManager; import android.telecom.DisconnectCause; import com.android.incallui.InCallPresenter.InCallState; public class InCallVibrationHandler extends Handler implements InCallPresenter.InCallStateListener { private static final int MSG_VIBRATE_45_SEC = 1; private static final String KEY_VIBRATE_CALL_WAITING = "incall_vibrate_call_waiting"; private static final String KEY_VIBRATE_OUTGOING = "incall_vibrate_outgoing"; private static final String KEY_VIBRATE_45SECS = "incall_vibrate_45secs"; private static final String KEY_VIBRATE_HANGUP = "incall_vibrate_hangup"; private SharedPreferences mPrefs; private Vibrator mVibrator; private Call mActiveCall; public InCallVibrationHandler(Context context) { mPrefs = PreferenceManager.getDefaultSharedPreferences(context); mVibrator = (Vibrator) context.getSystemService(Context.VIBRATOR_SERVICE); } @Override public void handleMessage(Message msg) { switch (msg.what) { case MSG_VIBRATE_45_SEC: vibrate(70, 0, 0); sendEmptyMessageDelayed(MSG_VIBRATE_45_SEC, 60000); break; } } @Override public void onStateChange(InCallState oldState, InCallState newState, CallList callList) { Call activeCall = callList.getActiveCall(); if (activeCall != null && mActiveCall == null) { Log.d(this, "Transition to active call " + activeCall); if (activeCall.isOutgoing()) { handleOutgoingCallVibration(activeCall); } mActiveCall = activeCall; } else if (activeCall != null && callList.getIncomingCall() != null && !callList.getIncomingCall().equals(activeCall)) { Log.d(this, "New incoming call" + callList.getIncomingCall()); handleCallWaitingVibration(activeCall); } else if (activeCall == null && mActiveCall != null) { Log.d(this, "Transition from active call " + mActiveCall); handleCallEnd(mActiveCall); mActiveCall = null; } } private void handleOutgoingCallVibration(Call call) { long durationMillis = System.currentTimeMillis() - call.getConnectTimeMillis(); Log.d(this, "Start outgoing call: duration = " + durationMillis); if (mPrefs.getBoolean(KEY_VIBRATE_OUTGOING, false) && durationMillis < 200) { vibrate(100, 200, 0); } if (mPrefs.getBoolean(KEY_VIBRATE_45SECS, false)) { start45SecondVibration(durationMillis); } } private void handleCallWaitingVibration(Call call) { Log.d(this, "Start call waiting vibration"); if (mPrefs.getBoolean(KEY_VIBRATE_CALL_WAITING, false)) { vibrate(200, 300, 500); } } private void handleCallEnd(Call call) { long durationMillis = System.currentTimeMillis() - call.getConnectTimeMillis(); DisconnectCause cause = call.getDisconnectCause(); boolean localDisconnect = // Disconnection not yet processed call.getState() == Call.State.DISCONNECTING || // Disconnection already processed (cause != null && cause.getCode() == DisconnectCause.LOCAL); Log.d(this, "Ending active call: duration = " + durationMillis + ", locally disconnected = " + localDisconnect); if (mPrefs.getBoolean(KEY_VIBRATE_HANGUP, false) && !localDisconnect && durationMillis > 500) { vibrate(50, 100, 50); } // Stop 45-second vibration removeMessages(MSG_VIBRATE_45_SEC); } private void start45SecondVibration(long callDurationMillis) { callDurationMillis = callDurationMillis % 60000; Log.d(this, "vibrate start @" + callDurationMillis); removeMessages(MSG_VIBRATE_45_SEC); long timer; if (callDurationMillis > 45000) { // Schedule the alarm at the next minute + 45 secs timer = 45000 + 60000 - callDurationMillis; } else { // Schedule the alarm at the first 45 second mark timer = 45000 - callDurationMillis; } sendEmptyMessageDelayed(MSG_VIBRATE_45_SEC, timer); } private void vibrate(int v1, int p1, int v2) { long[] pattern = new long[] { 0, v1, p1, v2 }; mVibrator.vibrate(pattern, -1); } }
res/values/cm_strings.xml 0 → 100644 +25 −0 Original line number Diff line number Diff line <?xml version="1.0" encoding="utf-8"?> <!-- Copyright (C) 2013-2014 The CyanogenMod Project Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. --> <resources xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2"> <string name="incall_vibration_category_key" translatable="false">dialer_general_incall_vibration_category_key</string> <string name="incall_vibration_category_title">In-call vibration</string> <string name="incall_vibrate_outgoing_title">Vibrate on answer</string> <string name="incall_vibrate_call_waiting_title">Vibrate on call waiting</string> <string name="incall_vibrate_hangup_title">Vibrate on hang up</string> <string name="incall_vibrate_45_title">Vibrate every minute</string> <string name="incall_vibrate_45_summary">Vibrates at the 45 second mark of every minute during outgoing calls</string> </resources>
res/xml/sound_settings.xml +23 −0 Original line number Diff line number Diff line Loading @@ -43,4 +43,27 @@ android:entries="@array/dtmf_tone_length_entries" android:entryValues="@array/dtmf_tone_length_entry_values" /> <PreferenceCategory android:key="@string/incall_vibration_category_key" android:title="@string/incall_vibration_category_title"> <CheckBoxPreference android:key="incall_vibrate_outgoing" android:title="@string/incall_vibrate_outgoing_title" /> <CheckBoxPreference android:key="incall_vibrate_call_waiting" android:title="@string/incall_vibrate_call_waiting_title" /> <CheckBoxPreference android:key="incall_vibrate_hangup" android:title="@string/incall_vibrate_hangup_title" /> <CheckBoxPreference android:key="incall_vibrate_45secs" android:title="@string/incall_vibrate_45_title" android:summary="@string/incall_vibrate_45_summary" /> </PreferenceCategory> </PreferenceScreen>