Loading Android.mk +1 −0 Original line number Original line Diff line number Diff line Loading @@ -173,6 +173,7 @@ LOCAL_SRC_FILES += \ core/java/android/hardware/input/IInputManager.aidl \ core/java/android/hardware/input/IInputManager.aidl \ core/java/android/hardware/input/IInputDevicesChangedListener.aidl \ core/java/android/hardware/input/IInputDevicesChangedListener.aidl \ core/java/android/hardware/location/IActivityRecognitionHardware.aidl \ core/java/android/hardware/location/IActivityRecognitionHardware.aidl \ core/java/android/hardware/location/IActivityRecognitionHardwareClient.aidl \ core/java/android/hardware/location/IActivityRecognitionHardwareSink.aidl \ core/java/android/hardware/location/IActivityRecognitionHardwareSink.aidl \ core/java/android/hardware/location/IActivityRecognitionHardwareWatcher.aidl \ core/java/android/hardware/location/IActivityRecognitionHardwareWatcher.aidl \ core/java/android/hardware/location/IFusedLocationHardware.aidl \ core/java/android/hardware/location/IFusedLocationHardware.aidl \ Loading core/java/android/hardware/location/IActivityRecognitionHardwareClient.aidl 0 → 100644 +36 −0 Original line number Original line Diff line number Diff line /* * Copyright (C) 2015, The Android Open Source 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/license/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 android.hardware.location; import android.hardware.location.IActivityRecognitionHardware; /** * Activity Recognition Hardware client interface. * This interface can be used to receive interfaces to implementations of * {@link IActivityRecognitionHardware}. * * @hide */ interface IActivityRecognitionHardwareClient { /** * Hardware Activity-Recognition availability event. * * @param isSupported whether the platform has hardware support for the feature * @param instance the available instance to provide access to the feature */ void onAvailabilityChanged(in boolean isSupported, in IActivityRecognitionHardware instance); } core/java/android/hardware/location/IActivityRecognitionHardwareWatcher.aidl +3 −1 Original line number Original line Diff line number Diff line Loading @@ -22,6 +22,8 @@ import android.hardware.location.IActivityRecognitionHardware; * Activity Recognition Hardware watcher. This interface can be used to receive interfaces to * Activity Recognition Hardware watcher. This interface can be used to receive interfaces to * implementations of {@link IActivityRecognitionHardware}. * implementations of {@link IActivityRecognitionHardware}. * * * @deprecated use {@link IActivityRecognitionHardwareClient} instead. * @hide * @hide */ */ interface IActivityRecognitionHardwareWatcher { interface IActivityRecognitionHardwareWatcher { Loading location/lib/java/com/android/location/provider/ActivityRecognitionProvider.java +10 −14 Original line number Original line Diff line number Diff line Loading @@ -31,8 +31,7 @@ import java.util.HashSet; */ */ public final class ActivityRecognitionProvider { public final class ActivityRecognitionProvider { private final IActivityRecognitionHardware mService; private final IActivityRecognitionHardware mService; private final HashSet<Sink> mSinkSet = new HashSet<Sink>(); private final HashSet<Sink> mSinkSet = new HashSet<>(); private final SinkTransport mSinkTransport = new SinkTransport(); // the following constants must remain in sync with activity_recognition.h // the following constants must remain in sync with activity_recognition.h Loading Loading @@ -60,7 +59,7 @@ public final class ActivityRecognitionProvider { throws RemoteException { throws RemoteException { Preconditions.checkNotNull(service); Preconditions.checkNotNull(service); mService = service; mService = service; mService.registerSink(mSinkTransport); mService.registerSink(new SinkTransport()); } } public String[] getSupportedActivities() throws RemoteException { public String[] getSupportedActivities() throws RemoteException { Loading Loading @@ -102,26 +101,23 @@ public final class ActivityRecognitionProvider { private final class SinkTransport extends IActivityRecognitionHardwareSink.Stub { private final class SinkTransport extends IActivityRecognitionHardwareSink.Stub { @Override @Override public void onActivityChanged( public void onActivityChanged(android.hardware.location.ActivityChangedEvent event) { android.hardware.location.ActivityChangedEvent activityChangedEvent) { Collection<Sink> sinks; Collection<Sink> sinks; synchronized (mSinkSet) { synchronized (mSinkSet) { if (mSinkSet.isEmpty()) { if (mSinkSet.isEmpty()) { return; return; } } sinks = new ArrayList<>(mSinkSet); sinks = new ArrayList<Sink>(mSinkSet); } } // translate the event from platform internal and GmsCore types // translate the event from platform internal and GmsCore types ArrayList<ActivityRecognitionEvent> gmsEvents = ArrayList<ActivityRecognitionEvent> gmsEvents = new ArrayList<>(); new ArrayList<ActivityRecognitionEvent>(); for (android.hardware.location.ActivityRecognitionEvent reportingEvent for (android.hardware.location.ActivityRecognitionEvent event : event.getActivityRecognitionEvents()) { : activityChangedEvent.getActivityRecognitionEvents()) { ActivityRecognitionEvent gmsEvent = new ActivityRecognitionEvent( ActivityRecognitionEvent gmsEvent = new ActivityRecognitionEvent( event.getActivity(), reportingEvent.getActivity(), event.getEventType(), reportingEvent.getEventType(), event.getTimestampNs()); reportingEvent.getTimestampNs()); gmsEvents.add(gmsEvent); gmsEvents.add(gmsEvent); } } ActivityChangedEvent gmsEvent = new ActivityChangedEvent(gmsEvents); ActivityChangedEvent gmsEvent = new ActivityChangedEvent(gmsEvents); Loading location/lib/java/com/android/location/provider/ActivityRecognitionProviderClient.java 0 → 100644 +75 −0 Original line number Original line Diff line number Diff line /* * Copyright (C) 2015 The Android Open Source 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.location.provider; import android.annotation.NonNull; import android.hardware.location.IActivityRecognitionHardware; import android.hardware.location.IActivityRecognitionHardwareClient; import android.os.Binder; import android.os.IBinder; import android.os.Process; import android.os.RemoteException; import android.util.Log; /** * A client class for interaction with an Activity-Recognition provider. */ public abstract class ActivityRecognitionProviderClient { private static final String TAG = "ArProviderClient"; protected ActivityRecognitionProviderClient() {} private IActivityRecognitionHardwareClient.Stub mClient = new IActivityRecognitionHardwareClient.Stub() { @Override public void onAvailabilityChanged( boolean isSupported, IActivityRecognitionHardware instance) { int callingUid = Binder.getCallingUid(); if (callingUid != Process.SYSTEM_UID) { Log.d(TAG, "Ignoring calls from non-system server. Uid: " + callingUid); return; } ActivityRecognitionProvider provider; try { provider = isSupported ? new ActivityRecognitionProvider(instance) : null; } catch (RemoteException e) { Log.e(TAG, "Error creating Hardware Activity-Recognition Provider.", e); return; } onProviderChanged(isSupported, provider); } }; /** * Gets the binder needed to interact with proxy provider in the platform. */ @NonNull public IBinder getBinder() { return mClient; } /** * Called when a change in the availability of {@link ActivityRecognitionProvider} is detected. * * @param isSupported whether the platform supports the provider natively * @param instance the available provider's instance */ public abstract void onProviderChanged( boolean isSupported, ActivityRecognitionProvider instance); } Loading
Android.mk +1 −0 Original line number Original line Diff line number Diff line Loading @@ -173,6 +173,7 @@ LOCAL_SRC_FILES += \ core/java/android/hardware/input/IInputManager.aidl \ core/java/android/hardware/input/IInputManager.aidl \ core/java/android/hardware/input/IInputDevicesChangedListener.aidl \ core/java/android/hardware/input/IInputDevicesChangedListener.aidl \ core/java/android/hardware/location/IActivityRecognitionHardware.aidl \ core/java/android/hardware/location/IActivityRecognitionHardware.aidl \ core/java/android/hardware/location/IActivityRecognitionHardwareClient.aidl \ core/java/android/hardware/location/IActivityRecognitionHardwareSink.aidl \ core/java/android/hardware/location/IActivityRecognitionHardwareSink.aidl \ core/java/android/hardware/location/IActivityRecognitionHardwareWatcher.aidl \ core/java/android/hardware/location/IActivityRecognitionHardwareWatcher.aidl \ core/java/android/hardware/location/IFusedLocationHardware.aidl \ core/java/android/hardware/location/IFusedLocationHardware.aidl \ Loading
core/java/android/hardware/location/IActivityRecognitionHardwareClient.aidl 0 → 100644 +36 −0 Original line number Original line Diff line number Diff line /* * Copyright (C) 2015, The Android Open Source 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/license/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 android.hardware.location; import android.hardware.location.IActivityRecognitionHardware; /** * Activity Recognition Hardware client interface. * This interface can be used to receive interfaces to implementations of * {@link IActivityRecognitionHardware}. * * @hide */ interface IActivityRecognitionHardwareClient { /** * Hardware Activity-Recognition availability event. * * @param isSupported whether the platform has hardware support for the feature * @param instance the available instance to provide access to the feature */ void onAvailabilityChanged(in boolean isSupported, in IActivityRecognitionHardware instance); }
core/java/android/hardware/location/IActivityRecognitionHardwareWatcher.aidl +3 −1 Original line number Original line Diff line number Diff line Loading @@ -22,6 +22,8 @@ import android.hardware.location.IActivityRecognitionHardware; * Activity Recognition Hardware watcher. This interface can be used to receive interfaces to * Activity Recognition Hardware watcher. This interface can be used to receive interfaces to * implementations of {@link IActivityRecognitionHardware}. * implementations of {@link IActivityRecognitionHardware}. * * * @deprecated use {@link IActivityRecognitionHardwareClient} instead. * @hide * @hide */ */ interface IActivityRecognitionHardwareWatcher { interface IActivityRecognitionHardwareWatcher { Loading
location/lib/java/com/android/location/provider/ActivityRecognitionProvider.java +10 −14 Original line number Original line Diff line number Diff line Loading @@ -31,8 +31,7 @@ import java.util.HashSet; */ */ public final class ActivityRecognitionProvider { public final class ActivityRecognitionProvider { private final IActivityRecognitionHardware mService; private final IActivityRecognitionHardware mService; private final HashSet<Sink> mSinkSet = new HashSet<Sink>(); private final HashSet<Sink> mSinkSet = new HashSet<>(); private final SinkTransport mSinkTransport = new SinkTransport(); // the following constants must remain in sync with activity_recognition.h // the following constants must remain in sync with activity_recognition.h Loading Loading @@ -60,7 +59,7 @@ public final class ActivityRecognitionProvider { throws RemoteException { throws RemoteException { Preconditions.checkNotNull(service); Preconditions.checkNotNull(service); mService = service; mService = service; mService.registerSink(mSinkTransport); mService.registerSink(new SinkTransport()); } } public String[] getSupportedActivities() throws RemoteException { public String[] getSupportedActivities() throws RemoteException { Loading Loading @@ -102,26 +101,23 @@ public final class ActivityRecognitionProvider { private final class SinkTransport extends IActivityRecognitionHardwareSink.Stub { private final class SinkTransport extends IActivityRecognitionHardwareSink.Stub { @Override @Override public void onActivityChanged( public void onActivityChanged(android.hardware.location.ActivityChangedEvent event) { android.hardware.location.ActivityChangedEvent activityChangedEvent) { Collection<Sink> sinks; Collection<Sink> sinks; synchronized (mSinkSet) { synchronized (mSinkSet) { if (mSinkSet.isEmpty()) { if (mSinkSet.isEmpty()) { return; return; } } sinks = new ArrayList<>(mSinkSet); sinks = new ArrayList<Sink>(mSinkSet); } } // translate the event from platform internal and GmsCore types // translate the event from platform internal and GmsCore types ArrayList<ActivityRecognitionEvent> gmsEvents = ArrayList<ActivityRecognitionEvent> gmsEvents = new ArrayList<>(); new ArrayList<ActivityRecognitionEvent>(); for (android.hardware.location.ActivityRecognitionEvent reportingEvent for (android.hardware.location.ActivityRecognitionEvent event : event.getActivityRecognitionEvents()) { : activityChangedEvent.getActivityRecognitionEvents()) { ActivityRecognitionEvent gmsEvent = new ActivityRecognitionEvent( ActivityRecognitionEvent gmsEvent = new ActivityRecognitionEvent( event.getActivity(), reportingEvent.getActivity(), event.getEventType(), reportingEvent.getEventType(), event.getTimestampNs()); reportingEvent.getTimestampNs()); gmsEvents.add(gmsEvent); gmsEvents.add(gmsEvent); } } ActivityChangedEvent gmsEvent = new ActivityChangedEvent(gmsEvents); ActivityChangedEvent gmsEvent = new ActivityChangedEvent(gmsEvents); Loading
location/lib/java/com/android/location/provider/ActivityRecognitionProviderClient.java 0 → 100644 +75 −0 Original line number Original line Diff line number Diff line /* * Copyright (C) 2015 The Android Open Source 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.location.provider; import android.annotation.NonNull; import android.hardware.location.IActivityRecognitionHardware; import android.hardware.location.IActivityRecognitionHardwareClient; import android.os.Binder; import android.os.IBinder; import android.os.Process; import android.os.RemoteException; import android.util.Log; /** * A client class for interaction with an Activity-Recognition provider. */ public abstract class ActivityRecognitionProviderClient { private static final String TAG = "ArProviderClient"; protected ActivityRecognitionProviderClient() {} private IActivityRecognitionHardwareClient.Stub mClient = new IActivityRecognitionHardwareClient.Stub() { @Override public void onAvailabilityChanged( boolean isSupported, IActivityRecognitionHardware instance) { int callingUid = Binder.getCallingUid(); if (callingUid != Process.SYSTEM_UID) { Log.d(TAG, "Ignoring calls from non-system server. Uid: " + callingUid); return; } ActivityRecognitionProvider provider; try { provider = isSupported ? new ActivityRecognitionProvider(instance) : null; } catch (RemoteException e) { Log.e(TAG, "Error creating Hardware Activity-Recognition Provider.", e); return; } onProviderChanged(isSupported, provider); } }; /** * Gets the binder needed to interact with proxy provider in the platform. */ @NonNull public IBinder getBinder() { return mClient; } /** * Called when a change in the availability of {@link ActivityRecognitionProvider} is detected. * * @param isSupported whether the platform supports the provider natively * @param instance the available provider's instance */ public abstract void onProviderChanged( boolean isSupported, ActivityRecognitionProvider instance); }