PhoneStatusListener
This commit is contained in:
parent
af8b1fded8
commit
236e884c8f
@ -178,12 +178,25 @@ public class PhoneStatusListener implements AutomationListenerInterface, Executo
|
|||||||
};
|
};
|
||||||
|
|
||||||
TelephonyCallback callback = new TelephonyCallback();
|
TelephonyCallback callback = new TelephonyCallback();
|
||||||
|
TelephonyCallback.CallStateListener callStateListener = new TelephonyCallback.CallStateListener()
|
||||||
telephonyManager.registerTelephonyCallback(context.mainExecutor, new TelephonyCallback());
|
{
|
||||||
object : TelephonyCallback(), TelephonyCallback.CallStateListener {
|
@Override
|
||||||
override fun onCallStateChanged(state: Int) {
|
public void onCallStateChanged(int state)
|
||||||
|
{
|
||||||
|
switch (state)
|
||||||
|
{
|
||||||
|
case TelephonyManager.CALL_STATE_RINGING:
|
||||||
|
break;
|
||||||
|
case TelephonyManager.CALL_STATE_OFFHOOK:
|
||||||
|
break;
|
||||||
|
case TelephonyManager.CALL_STATE_IDLE:
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})
|
};
|
||||||
|
|
||||||
|
telephonyManager.registerTelephonyCallback(executor, callback);
|
||||||
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -357,4 +370,150 @@ public class PhoneStatusListener implements AutomationListenerInterface, Executo
|
|||||||
{
|
{
|
||||||
return new Trigger_Enum[] { Trigger_Enum.phoneCall };
|
return new Trigger_Enum[] { Trigger_Enum.phoneCall };
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public class PhoneCallback extends PhoneStateListener {
|
||||||
|
|
||||||
|
//--------------------------------------------------
|
||||||
|
// Constants
|
||||||
|
//--------------------------------------------------
|
||||||
|
|
||||||
|
public static final String LOG_TAG = "PhoneCallback";
|
||||||
|
|
||||||
|
//--------------------------------------------------
|
||||||
|
// Attributes
|
||||||
|
//--------------------------------------------------
|
||||||
|
|
||||||
|
private final TextView mTextView;
|
||||||
|
|
||||||
|
//--------------------------------------------------
|
||||||
|
// Constructor
|
||||||
|
//--------------------------------------------------
|
||||||
|
|
||||||
|
public PhoneCallback(TextView textView) {
|
||||||
|
mTextView = textView;
|
||||||
|
}
|
||||||
|
|
||||||
|
//--------------------------------------------------
|
||||||
|
// Methods
|
||||||
|
//--------------------------------------------------
|
||||||
|
|
||||||
|
private String serviceStateToString(int serviceState) {
|
||||||
|
switch (serviceState) {
|
||||||
|
case ServiceState.STATE_IN_SERVICE:
|
||||||
|
return "STATE_IN_SERVICE";
|
||||||
|
case ServiceState.STATE_OUT_OF_SERVICE:
|
||||||
|
return "STATE_OUT_OF_SERVICE";
|
||||||
|
case ServiceState.STATE_EMERGENCY_ONLY:
|
||||||
|
return "STATE_EMERGENCY_ONLY";
|
||||||
|
case ServiceState.STATE_POWER_OFF:
|
||||||
|
return "STATE_POWER_OFF";
|
||||||
|
default:
|
||||||
|
return "UNKNOWN_STATE";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private String callStateToString(int state) {
|
||||||
|
switch (state) {
|
||||||
|
case TelephonyManager.CALL_STATE_IDLE:
|
||||||
|
return "\nonCallStateChanged: CALL_STATE_IDLE, ";
|
||||||
|
case TelephonyManager.CALL_STATE_RINGING:
|
||||||
|
return "\nonCallStateChanged: CALL_STATE_RINGING, ";
|
||||||
|
case TelephonyManager.CALL_STATE_OFFHOOK:
|
||||||
|
return "\nonCallStateChanged: CALL_STATE_OFFHOOK, ";
|
||||||
|
default:
|
||||||
|
return "\nUNKNOWN_STATE: " + state + ", ";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//--------------------------------------------------
|
||||||
|
// PhoneStateListener
|
||||||
|
//--------------------------------------------------
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onCellInfoChanged(List<CellInfo> cellInfo) {
|
||||||
|
super.onCellInfoChanged(cellInfo);
|
||||||
|
Log.i(LOG_TAG, "onCellInfoChanged: " + cellInfo);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onDataActivity(int direction) {
|
||||||
|
super.onDataActivity(direction);
|
||||||
|
switch (direction) {
|
||||||
|
case TelephonyManager.DATA_ACTIVITY_NONE:
|
||||||
|
Log.i(LOG_TAG, "onDataActivity: DATA_ACTIVITY_NONE");
|
||||||
|
break;
|
||||||
|
case TelephonyManager.DATA_ACTIVITY_IN:
|
||||||
|
Log.i(LOG_TAG, "onDataActivity: DATA_ACTIVITY_IN");
|
||||||
|
break;
|
||||||
|
case TelephonyManager.DATA_ACTIVITY_OUT:
|
||||||
|
Log.i(LOG_TAG, "onDataActivity: DATA_ACTIVITY_OUT");
|
||||||
|
break;
|
||||||
|
case TelephonyManager.DATA_ACTIVITY_INOUT:
|
||||||
|
Log.i(LOG_TAG, "onDataActivity: DATA_ACTIVITY_INOUT");
|
||||||
|
break;
|
||||||
|
case TelephonyManager.DATA_ACTIVITY_DORMANT:
|
||||||
|
Log.i(LOG_TAG, "onDataActivity: DATA_ACTIVITY_DORMANT");
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
Log.w(LOG_TAG, "onDataActivity: UNKNOWN " + direction);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onServiceStateChanged(ServiceState serviceState) {
|
||||||
|
super.onServiceStateChanged(serviceState);
|
||||||
|
String message = "onServiceStateChanged: " + serviceState + "\n";
|
||||||
|
message += "onServiceStateChanged: getOperatorAlphaLong " + serviceState.getOperatorAlphaLong() + "\n";
|
||||||
|
message += "onServiceStateChanged: getOperatorAlphaShort " + serviceState.getOperatorAlphaShort() + "\n";
|
||||||
|
message += "onServiceStateChanged: getOperatorNumeric " + serviceState.getOperatorNumeric() + "\n";
|
||||||
|
message += "onServiceStateChanged: getIsManualSelection " + serviceState.getIsManualSelection() + "\n";
|
||||||
|
message += "onServiceStateChanged: getRoaming " + serviceState.getRoaming() + "\n";
|
||||||
|
message += "onServiceStateChanged: " + serviceStateToString(serviceState.getState());
|
||||||
|
Log.i(LOG_TAG, message);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onCallStateChanged(int state, String incomingNumber) {
|
||||||
|
super.onCallStateChanged(state, incomingNumber);
|
||||||
|
callStateToString(state);
|
||||||
|
String message = callStateToString(state) + "incomingNumber: " + incomingNumber;
|
||||||
|
mTextView.setText(message);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onCellLocationChanged(CellLocation location) {
|
||||||
|
super.onCellLocationChanged(location);
|
||||||
|
String message = "";
|
||||||
|
if (location instanceof GsmCellLocation) {
|
||||||
|
GsmCellLocation gcLoc = (GsmCellLocation) location;
|
||||||
|
message += "onCellLocationChanged: GsmCellLocation " + gcLoc + "\n";
|
||||||
|
message += "onCellLocationChanged: GsmCellLocation getCid " + gcLoc.getCid() + "\n";
|
||||||
|
message += "onCellLocationChanged: GsmCellLocation getLac " + gcLoc.getLac() + "\n";
|
||||||
|
message += "onCellLocationChanged: GsmCellLocation getPsc" + gcLoc.getPsc(); // Requires min API 9
|
||||||
|
Log.i(LOG_TAG, message);
|
||||||
|
} else if (location instanceof CdmaCellLocation) {
|
||||||
|
CdmaCellLocation ccLoc = (CdmaCellLocation) location;
|
||||||
|
message += "onCellLocationChanged: CdmaCellLocation " + ccLoc + "\n";;
|
||||||
|
message += "onCellLocationChanged: CdmaCellLocation getBaseStationId " + ccLoc.getBaseStationId() + "\n";;
|
||||||
|
message += "onCellLocationChanged: CdmaCellLocation getBaseStationLatitude " + ccLoc.getBaseStationLatitude() + "\n";;
|
||||||
|
message += "onCellLocationChanged: CdmaCellLocation getBaseStationLongitude" + ccLoc.getBaseStationLongitude() + "\n";;
|
||||||
|
message += "onCellLocationChanged: CdmaCellLocation getNetworkId " + ccLoc.getNetworkId() + "\n";;
|
||||||
|
message += "onCellLocationChanged: CdmaCellLocation getSystemId " + ccLoc.getSystemId();
|
||||||
|
Log.i(LOG_TAG, message);
|
||||||
|
} else {
|
||||||
|
Log.i(LOG_TAG, "onCellLocationChanged: " + location);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onCallForwardingIndicatorChanged(boolean changed) {
|
||||||
|
super.onCallForwardingIndicatorChanged(changed);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onMessageWaitingIndicatorChanged(boolean changed) {
|
||||||
|
super.onMessageWaitingIndicatorChanged(changed);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user