ScreenStateReceiver
This commit is contained in:
parent
5ed6097ed6
commit
83ee19b4fa
@ -523,6 +523,8 @@ public class ActivityManageRule extends Activity
|
|||||||
items.add(new Item(typesLong[i].toString(), R.drawable.smartphone));
|
items.add(new Item(typesLong[i].toString(), R.drawable.smartphone));
|
||||||
else if(types[i].toString().equals(Trigger_Enum.profileActive.toString()))
|
else if(types[i].toString().equals(Trigger_Enum.profileActive.toString()))
|
||||||
items.add(new Item(typesLong[i].toString(), R.drawable.sound));
|
items.add(new Item(typesLong[i].toString(), R.drawable.sound));
|
||||||
|
else if(types[i].toString().equals(Trigger_Enum.screenState.toString()))
|
||||||
|
items.add(new Item(typesLong[i].toString(), R.drawable.smartphone));
|
||||||
else
|
else
|
||||||
items.add(new Item(typesLong[i].toString(), R.drawable.placeholder));
|
items.add(new Item(typesLong[i].toString(), R.drawable.placeholder));
|
||||||
}
|
}
|
||||||
|
@ -22,6 +22,8 @@ import com.jens.automation2.receivers.NoiseListener;
|
|||||||
import com.jens.automation2.receivers.NotificationListener;
|
import com.jens.automation2.receivers.NotificationListener;
|
||||||
import com.jens.automation2.receivers.PhoneStatusListener;
|
import com.jens.automation2.receivers.PhoneStatusListener;
|
||||||
import com.jens.automation2.receivers.ProcessListener;
|
import com.jens.automation2.receivers.ProcessListener;
|
||||||
|
import com.jens.automation2.receivers.ScreenStateReceiver;
|
||||||
|
|
||||||
import static com.jens.automation2.receivers.NotificationListener.EXTRA_TEXT;
|
import static com.jens.automation2.receivers.NotificationListener.EXTRA_TEXT;
|
||||||
import static com.jens.automation2.receivers.NotificationListener.EXTRA_TITLE;
|
import static com.jens.automation2.receivers.NotificationListener.EXTRA_TITLE;
|
||||||
|
|
||||||
@ -123,6 +125,10 @@ public class Trigger
|
|||||||
if(!checkProfileActive())
|
if(!checkProfileActive())
|
||||||
result = false;
|
result = false;
|
||||||
break;
|
break;
|
||||||
|
case screenState:
|
||||||
|
if(!checkScreenState())
|
||||||
|
result = false;
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -308,6 +314,23 @@ public class Trigger
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
boolean checkScreenState()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
int desiredState = Integer.parseInt(getTriggerParameter2());
|
||||||
|
int currentState = ScreenStateReceiver.getScreenState();
|
||||||
|
|
||||||
|
return desiredState == currentState;
|
||||||
|
}
|
||||||
|
catch (Exception e)
|
||||||
|
{
|
||||||
|
Miscellaneous.logEvent("w", "Trigger", "Error checking profile trigger.", 4);
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
boolean checkDeviceOrientation()
|
boolean checkDeviceOrientation()
|
||||||
{
|
{
|
||||||
String deviceOrientationPieces[] = getTriggerParameter2().split(Trigger.triggerParameter2Split);
|
String deviceOrientationPieces[] = getTriggerParameter2().split(Trigger.triggerParameter2Split);
|
||||||
@ -1492,6 +1515,12 @@ public class Trigger
|
|||||||
else
|
else
|
||||||
returnString.append(String.format(Miscellaneous.getAnyContext().getString(R.string.profileNotActive), getTriggerParameter2().split(Trigger.triggerParameter2Split)[0]));
|
returnString.append(String.format(Miscellaneous.getAnyContext().getString(R.string.profileNotActive), getTriggerParameter2().split(Trigger.triggerParameter2Split)[0]));
|
||||||
break;
|
break;
|
||||||
|
case screenState:
|
||||||
|
if(triggerParameter)
|
||||||
|
returnString.append(String.format(Miscellaneous.getAnyContext().getString(R.string.screenIs), getTriggerParameter2().split(Trigger.triggerParameter2Split)[0]));
|
||||||
|
else
|
||||||
|
returnString.append(String.format(Miscellaneous.getAnyContext().getString(R.string.profileNotActive), getTriggerParameter2().split(Trigger.triggerParameter2Split)[0]));
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
returnString.append("error");
|
returnString.append("error");
|
||||||
break;
|
break;
|
||||||
|
@ -0,0 +1,163 @@
|
|||||||
|
package com.jens.automation2.receivers;
|
||||||
|
|
||||||
|
import android.Manifest;
|
||||||
|
import android.content.BroadcastReceiver;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.content.Intent;
|
||||||
|
import android.content.IntentFilter;
|
||||||
|
import android.os.BatteryManager;
|
||||||
|
import android.util.Log;
|
||||||
|
import android.widget.Toast;
|
||||||
|
|
||||||
|
import com.jens.automation2.ActivityPermissions;
|
||||||
|
import com.jens.automation2.AutomationService;
|
||||||
|
import com.jens.automation2.Miscellaneous;
|
||||||
|
import com.jens.automation2.Rule;
|
||||||
|
import com.jens.automation2.Trigger.Trigger_Enum;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
|
||||||
|
public class ScreenStateReceiver extends BroadcastReceiver implements AutomationListenerInterface
|
||||||
|
{
|
||||||
|
static int screenState = -1; // initialize with a better value than this
|
||||||
|
public static AutomationService automationServiceRef = null;
|
||||||
|
|
||||||
|
private static boolean screenStateReceiverActive = false;
|
||||||
|
private static IntentFilter screenStateIntentFilter = null;
|
||||||
|
private static Intent screenStatusIntent = null;
|
||||||
|
private static BroadcastReceiver screenStateReceiverInstance = null;
|
||||||
|
|
||||||
|
public static void startScreenStateReceiver(final AutomationService automationServiceRef)
|
||||||
|
{
|
||||||
|
if(!screenStateReceiverActive)
|
||||||
|
{
|
||||||
|
ScreenStateReceiver.automationServiceRef = automationServiceRef;
|
||||||
|
|
||||||
|
if(screenStateReceiverInstance == null)
|
||||||
|
screenStateReceiverInstance = new ScreenStateReceiver();
|
||||||
|
|
||||||
|
if(screenStateIntentFilter == null)
|
||||||
|
{
|
||||||
|
screenStateIntentFilter = new IntentFilter();
|
||||||
|
screenStateIntentFilter.addAction(Intent.ACTION_SCREEN_OFF);
|
||||||
|
screenStateIntentFilter.addAction(Intent.ACTION_SCREEN_ON);
|
||||||
|
screenStateIntentFilter.addAction(Intent.ACTION_USER_PRESENT);
|
||||||
|
// Intent.ACTION_USER_UNLOCKED
|
||||||
|
}
|
||||||
|
|
||||||
|
screenStatusIntent = automationServiceRef.registerReceiver(screenStateReceiverInstance, screenStateIntentFilter);
|
||||||
|
|
||||||
|
screenStateReceiverActive = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public static void stopScreenStateReceiver()
|
||||||
|
{
|
||||||
|
if(screenStateReceiverActive)
|
||||||
|
{
|
||||||
|
if(screenStateReceiverInstance != null)
|
||||||
|
{
|
||||||
|
automationServiceRef.unregisterReceiver(screenStateReceiverInstance);
|
||||||
|
screenStateReceiverInstance = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
screenStateReceiverActive = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean isScreenStateReceiverActive()
|
||||||
|
{
|
||||||
|
return screenStateReceiverActive;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean isUsbHostConnected()
|
||||||
|
{
|
||||||
|
return usbHostConnected;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static int getScreenState()
|
||||||
|
{
|
||||||
|
return screenState;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static int currentChargingState = 0; //0=unknown, 1=no, 2=yes
|
||||||
|
|
||||||
|
public static int getCurrentChargingState()
|
||||||
|
{
|
||||||
|
return currentChargingState;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onReceive(Context context, Intent intent)
|
||||||
|
{
|
||||||
|
if (intent == null)
|
||||||
|
return;
|
||||||
|
if (context == null)
|
||||||
|
return;
|
||||||
|
|
||||||
|
Miscellaneous.logEvent("e", "ScreenStateReceiver", "Received: " + intent.getAction(), 3);
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
if(intent.getAction().equals(Intent.ACTION_SCREEN_ON))
|
||||||
|
{
|
||||||
|
ScreenStateReceiver.screenState = 1;
|
||||||
|
}
|
||||||
|
else if(intent.getAction().equals(Intent.ACTION_SCREEN_OFF))
|
||||||
|
{
|
||||||
|
ScreenStateReceiver.screenState = 0;
|
||||||
|
}
|
||||||
|
else if(intent.getAction().equals(Intent.ACTION_USER_PRESENT))
|
||||||
|
{
|
||||||
|
ScreenStateReceiver.screenState = 2;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Miscellaneous.logEvent("e", "ScreenStateReceiver", "Unknown state received: " + intent.getAction(), 3);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
Miscellaneous.logEvent("e", "ScreenStateReceiver", "Error receiving screen state: " + e.getMessage(), 3);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void actionCharging(Context context, int state)
|
||||||
|
{
|
||||||
|
|
||||||
|
ArrayList<Rule> ruleCandidates = Rule.findRuleCandidates(Trigger_Enum.screenState);
|
||||||
|
for(int i=0; i<ruleCandidates.size(); i++)
|
||||||
|
{
|
||||||
|
if(ruleCandidates.get(i).getsGreenLight(context))
|
||||||
|
ruleCandidates.get(i).activate(automationServiceRef, false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void startListener(AutomationService automationService)
|
||||||
|
{
|
||||||
|
ScreenStateReceiver.startScreenStateReceiver(automationService);
|
||||||
|
}
|
||||||
|
@Override
|
||||||
|
public void stopListener(AutomationService automationService)
|
||||||
|
{
|
||||||
|
ScreenStateReceiver.stopScreenStateReceiver();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean haveAllPermission()
|
||||||
|
{
|
||||||
|
return ActivityPermissions.havePermission(Manifest.permission.READ_PHONE_STATE, Miscellaneous.getAnyContext()) &&
|
||||||
|
ActivityPermissions.havePermission(Manifest.permission.BATTERY_STATS, Miscellaneous.getAnyContext());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isListenerRunning()
|
||||||
|
{
|
||||||
|
return ScreenStateReceiver.isScreenStateReceiverActive();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Trigger_Enum[] getMonitoredTrigger()
|
||||||
|
{
|
||||||
|
return new Trigger_Enum[] { Trigger_Enum.screenState };
|
||||||
|
}
|
||||||
|
}
|
@ -1,292 +0,0 @@
|
|||||||
package com.jens.automation2.receivers;
|
|
||||||
|
|
||||||
import android.Manifest;
|
|
||||||
import android.content.BroadcastReceiver;
|
|
||||||
import android.content.Context;
|
|
||||||
import android.content.Intent;
|
|
||||||
import android.content.IntentFilter;
|
|
||||||
import android.os.BatteryManager;
|
|
||||||
import android.util.Log;
|
|
||||||
import android.widget.Toast;
|
|
||||||
|
|
||||||
import com.jens.automation2.ActivityPermissions;
|
|
||||||
import com.jens.automation2.AutomationService;
|
|
||||||
import com.jens.automation2.Miscellaneous;
|
|
||||||
import com.jens.automation2.Rule;
|
|
||||||
import com.jens.automation2.Trigger.Trigger_Enum;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
|
|
||||||
public class ScreenStatusReceiver extends BroadcastReceiver implements AutomationListenerInterface
|
|
||||||
{
|
|
||||||
static int batteryLevel = -1; // initialize with a better value than this
|
|
||||||
public static AutomationService automationServiceRef = null;
|
|
||||||
private static boolean usbHostConnected = false;
|
|
||||||
|
|
||||||
private static boolean screenStateReceiverActive = false;
|
|
||||||
private static IntentFilter screenStateIntentFilter = null;
|
|
||||||
private static Intent screenStatusIntent = null;
|
|
||||||
private static BroadcastReceiver screenStateReceiverInstance = null;
|
|
||||||
|
|
||||||
public static void startScreenStateReceiver(final AutomationService automationServiceRef)
|
|
||||||
{
|
|
||||||
if(!screenStateReceiverActive)
|
|
||||||
{
|
|
||||||
ScreenStatusReceiver.automationServiceRef = automationServiceRef;
|
|
||||||
|
|
||||||
if(screenStateReceiverInstance == null)
|
|
||||||
screenStateReceiverInstance = new ScreenStatusReceiver();
|
|
||||||
|
|
||||||
if(screenStateIntentFilter == null)
|
|
||||||
{
|
|
||||||
screenStateIntentFilter = new IntentFilter();
|
|
||||||
screenStateIntentFilter.addAction(Intent.ACTION_SCREEN_OFF);
|
|
||||||
screenStateIntentFilter.addAction(Intent.ACTION_SCREEN_ON);
|
|
||||||
}
|
|
||||||
|
|
||||||
screenStatusIntent = automationServiceRef.registerReceiver(screenStateReceiverInstance, screenStateIntentFilter);
|
|
||||||
|
|
||||||
screenStateReceiverActive = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
public static void stopScreenStateReceiver()
|
|
||||||
{
|
|
||||||
if(screenStateReceiverActive)
|
|
||||||
{
|
|
||||||
if(screenStateReceiverInstance != null)
|
|
||||||
{
|
|
||||||
automationServiceRef.unregisterReceiver(screenStateReceiverInstance);
|
|
||||||
screenStateReceiverInstance = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
screenStateReceiverActive = false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static boolean isScreenStateReceiverActive()
|
|
||||||
{
|
|
||||||
return screenStateReceiverActive;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static boolean isUsbHostConnected()
|
|
||||||
{
|
|
||||||
return usbHostConnected;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static int getBatteryLevel()
|
|
||||||
{
|
|
||||||
return batteryLevel;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static int currentChargingState = 0; //0=unknown, 1=no, 2=yes
|
|
||||||
|
|
||||||
public static int getCurrentChargingState()
|
|
||||||
{
|
|
||||||
return currentChargingState;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onReceive(Context context, Intent intent)
|
|
||||||
{
|
|
||||||
// Log.i("Battery", "Some battery event");
|
|
||||||
|
|
||||||
if (intent == null)
|
|
||||||
return;
|
|
||||||
if (context == null)
|
|
||||||
return;
|
|
||||||
|
|
||||||
if(intent.getAction().equals(Intent.ACTION_BATTERY_LOW))
|
|
||||||
{
|
|
||||||
Log.i("Battery", "Low battery event");
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
// Miscellaneous.logEvent("i", "BatteryReceiver", "Received battery event.");
|
|
||||||
// if(intent.getAction().equals(Intent.ACTION_BATTERY_CHANGED))
|
|
||||||
// {
|
|
||||||
batteryLevel = intent.getIntExtra(BatteryManager.EXTRA_LEVEL, -1);
|
|
||||||
// int scale = -1;
|
|
||||||
// int voltage = -1;
|
|
||||||
// int temp = -1;
|
|
||||||
// scale = intent.getIntExtra(BatteryManager.EXTRA_SCALE, -1);
|
|
||||||
// temp = intent.getIntExtra(BatteryManager.EXTRA_TEMPERATURE, -1);
|
|
||||||
// voltage = intent.getIntExtra(BatteryManager.EXTRA_VOLTAGE, -1);
|
|
||||||
Log.i("Battery", "Level: " + String.valueOf(batteryLevel));
|
|
||||||
this.actionBatteryLevel(context);
|
|
||||||
|
|
||||||
int status = intent.getIntExtra(BatteryManager.EXTRA_STATUS, -1);
|
|
||||||
int statusPlugged = intent.getIntExtra(BatteryManager.EXTRA_PLUGGED, -1);
|
|
||||||
// Miscellaneous.logEvent("i", "BatteryReceiver", "Status: " + String.valueOf(statusPlugged));
|
|
||||||
|
|
||||||
switch(statusPlugged)
|
|
||||||
{
|
|
||||||
case BatteryManager.BATTERY_PLUGGED_AC:
|
|
||||||
// Toast.makeText(context, "Regular charging", Toast.LENGTH_LONG).show();
|
|
||||||
// Miscellaneous.logEvent("i", "BatteryReceiver", "Regular charging.");
|
|
||||||
this.actionCharging(context);
|
|
||||||
break;
|
|
||||||
case BatteryManager.BATTERY_PLUGGED_USB:
|
|
||||||
this.actionUsbConnected(context);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
switch(status)
|
|
||||||
{
|
|
||||||
// case BatteryManager.BATTERY_STATUS_CHARGING:
|
|
||||||
// break;
|
|
||||||
case BatteryManager.BATTERY_STATUS_FULL:
|
|
||||||
// Toast.makeText(context, "Regular charging full", Toast.LENGTH_LONG).show();
|
|
||||||
// Miscellaneous.logEvent("i", "BatteryReceiver", "Device has been fully charged.");
|
|
||||||
this.actionCharging(context);
|
|
||||||
break;
|
|
||||||
case BatteryManager.BATTERY_STATUS_DISCHARGING:
|
|
||||||
this.actionDischarging(context);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch(Exception e)
|
|
||||||
{
|
|
||||||
Miscellaneous.logEvent("e", "BatteryReceiver", "Error receiving battery status: " + e.getMessage(), 3);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static int isDeviceCharging(Context context)
|
|
||||||
{
|
|
||||||
switch(currentChargingState)
|
|
||||||
{
|
|
||||||
case 0:
|
|
||||||
Miscellaneous.logEvent("w", "ChargingInfo", "Status of device charging was requested. Information isn't available, yet.", 4);
|
|
||||||
break;
|
|
||||||
case 1:
|
|
||||||
Miscellaneous.logEvent("i", "ChargingInfo", "Status of device charging was requested. Device is discharging.", 3);
|
|
||||||
break;
|
|
||||||
case BatteryManager.BATTERY_STATUS_CHARGING:
|
|
||||||
Miscellaneous.logEvent("i", "ChargingInfo", "Status of device charging was requested. Device is charging.", 3);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
return currentChargingState;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void actionCharging(Context context)
|
|
||||||
{
|
|
||||||
if(currentChargingState != BatteryManager.BATTERY_STATUS_CHARGING) // Avoid flooding the log. This event will occur on a regular basis even though charging state wasn't changed.
|
|
||||||
{
|
|
||||||
Miscellaneous.logEvent("i", "BatteryReceiver", "Battery is charging or full.", 3);
|
|
||||||
currentChargingState = BatteryManager.BATTERY_STATUS_CHARGING;
|
|
||||||
//activate rule(s)
|
|
||||||
ArrayList<Rule> ruleCandidates = Rule.findRuleCandidates(Trigger_Enum.charging);
|
|
||||||
// ArrayList<Rule> ruleCandidates = Rule.findRuleCandidatesByCharging(true);
|
|
||||||
for(int i=0; i<ruleCandidates.size(); i++)
|
|
||||||
{
|
|
||||||
if(ruleCandidates.get(i).getsGreenLight(context))
|
|
||||||
ruleCandidates.get(i).activate(automationServiceRef, false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void actionBatteryLevel(Context context)
|
|
||||||
{
|
|
||||||
Miscellaneous.logEvent("i", "BatteryReceiver", "Battery level has changed.", 3);
|
|
||||||
//activate rule(s)
|
|
||||||
ArrayList<Rule> ruleCandidates = Rule.findRuleCandidates(Trigger_Enum.batteryLevel);
|
|
||||||
for(int i=0; i<ruleCandidates.size(); i++)
|
|
||||||
{
|
|
||||||
if(ruleCandidates.get(i).getsGreenLight(context))
|
|
||||||
ruleCandidates.get(i).activate(automationServiceRef, false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void actionDischarging(Context context)
|
|
||||||
{
|
|
||||||
if(currentChargingState != BatteryManager.BATTERY_STATUS_UNKNOWN) // Avoid flooding the log. This event will occur on a regular basis even though charging state wasn't changed.
|
|
||||||
{
|
|
||||||
Miscellaneous.logEvent("i", "BatteryReceiver", "Battery is discharging.", 3);
|
|
||||||
currentChargingState = BatteryManager.BATTERY_STATUS_UNKNOWN;
|
|
||||||
//activate rule(s)
|
|
||||||
ArrayList<Rule> ruleCandidates = Rule.findRuleCandidates(Trigger_Enum.charging);
|
|
||||||
// ArrayList<Rule> ruleCandidates = Rule.findRuleCandidatesByCharging(false);
|
|
||||||
for(int i=0; i<ruleCandidates.size(); i++)
|
|
||||||
{
|
|
||||||
if(ruleCandidates.get(i).getsGreenLight(context))
|
|
||||||
ruleCandidates.get(i).activate(automationServiceRef, false);
|
|
||||||
}
|
|
||||||
|
|
||||||
this.actionUsbDisconnected(context);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void actionUsbConnected(Context context)
|
|
||||||
{
|
|
||||||
// Event usbConnected
|
|
||||||
|
|
||||||
// Miscellaneous.logEvent("i", "BatteryReceiver", "BATTERY_PLUGGED_USB");
|
|
||||||
|
|
||||||
if(!usbHostConnected)
|
|
||||||
{
|
|
||||||
usbHostConnected = true;
|
|
||||||
Miscellaneous.logEvent("i", "BatteryReceiver", "Connected to computer.", 3);
|
|
||||||
Toast.makeText(context, "Connected to computer.", Toast.LENGTH_LONG).show();
|
|
||||||
|
|
||||||
ArrayList<Rule> ruleCandidates = Rule.findRuleCandidates(Trigger_Enum.usb_host_connection);
|
|
||||||
// ArrayList<Rule> ruleCandidates = Rule.findRuleCandidatesByUsbHost(true);
|
|
||||||
for(Rule oneRule : ruleCandidates)
|
|
||||||
{
|
|
||||||
if(oneRule.getsGreenLight(context))
|
|
||||||
oneRule.activate(automationServiceRef, false);
|
|
||||||
}
|
|
||||||
|
|
||||||
this.actionCharging(context);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void actionUsbDisconnected(Context context)
|
|
||||||
{
|
|
||||||
// Event usbDisConnected
|
|
||||||
|
|
||||||
if(usbHostConnected)
|
|
||||||
{
|
|
||||||
usbHostConnected = false;
|
|
||||||
Miscellaneous.logEvent("i", "BatteryReceiver", "Disconnected from computer.", 3);
|
|
||||||
Toast.makeText(context, "Disconnected from computer.", Toast.LENGTH_LONG).show();
|
|
||||||
|
|
||||||
ArrayList<Rule> ruleCandidates = Rule.findRuleCandidates(Trigger_Enum.usb_host_connection);
|
|
||||||
// ArrayList<Rule> ruleCandidates = Rule.findRuleCandidatesByUsbHost(false);
|
|
||||||
for(Rule oneRule : ruleCandidates)
|
|
||||||
{
|
|
||||||
if(oneRule.getsGreenLight(context))
|
|
||||||
oneRule.activate(automationServiceRef, false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@Override
|
|
||||||
public void startListener(AutomationService automationService)
|
|
||||||
{
|
|
||||||
ScreenStatusReceiver.startScreenStateReceiver(automationService);
|
|
||||||
}
|
|
||||||
@Override
|
|
||||||
public void stopListener(AutomationService automationService)
|
|
||||||
{
|
|
||||||
ScreenStatusReceiver.stopScreenStateReceiver();
|
|
||||||
}
|
|
||||||
|
|
||||||
public static boolean haveAllPermission()
|
|
||||||
{
|
|
||||||
return ActivityPermissions.havePermission(Manifest.permission.READ_PHONE_STATE, Miscellaneous.getAnyContext()) &&
|
|
||||||
ActivityPermissions.havePermission(Manifest.permission.BATTERY_STATS, Miscellaneous.getAnyContext());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean isListenerRunning()
|
|
||||||
{
|
|
||||||
return ScreenStatusReceiver.isScreenStateReceiverActive();
|
|
||||||
}
|
|
||||||
@Override
|
|
||||||
public Trigger_Enum[] getMonitoredTrigger()
|
|
||||||
{
|
|
||||||
return new Trigger_Enum[] { Trigger_Enum.screenState };
|
|
||||||
}
|
|
||||||
}
|
|
@ -768,4 +768,5 @@
|
|||||||
<string name="emailContactNotice">Email is my preferred method of contact to report bugs, ask questions or make proposals. Go to control center to learn more.</string>
|
<string name="emailContactNotice">Email is my preferred method of contact to report bugs, ask questions or make proposals. Go to control center to learn more.</string>
|
||||||
<string name="controlCenter">Control center</string>
|
<string name="controlCenter">Control center</string>
|
||||||
<string name="sendEmailToDev">Send email to developer</string>
|
<string name="sendEmailToDev">Send email to developer</string>
|
||||||
|
<string name="screenIs">screen is %1$s</string>
|
||||||
</resources>
|
</resources>
|
Loading…
Reference in New Issue
Block a user