Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 8ff73b59 authored by Daniel Estrada Alva's avatar Daniel Estrada Alva Committed by Android (Google) Code Review
Browse files

Merge "Cherry-pick: Add callback-based support for HW Activity Recognition." into mnc-dr-dev

parents a07177f0 e1a5144a
Loading
Loading
Loading
Loading
+1 −0
Original line number Diff line number Diff line
@@ -173,6 +173,7 @@ LOCAL_SRC_FILES += \
	core/java/android/hardware/input/IInputManager.aidl \
	core/java/android/hardware/input/IInputDevicesChangedListener.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/IActivityRecognitionHardwareWatcher.aidl \
	core/java/android/hardware/location/IFusedLocationHardware.aidl \
+36 −0
Original line number 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);
}
+3 −1
Original line number Diff line number Diff line
@@ -22,6 +22,8 @@ import android.hardware.location.IActivityRecognitionHardware;
 * Activity Recognition Hardware watcher. This interface can be used to receive interfaces to
 * implementations of {@link IActivityRecognitionHardware}.
 *
 * @deprecated use {@link IActivityRecognitionHardwareClient} instead.

 * @hide
 */
interface IActivityRecognitionHardwareWatcher {
+10 −14
Original line number Diff line number Diff line
@@ -31,8 +31,7 @@ import java.util.HashSet;
 */
public final class ActivityRecognitionProvider {
    private final IActivityRecognitionHardware mService;
    private final HashSet<Sink> mSinkSet = new HashSet<Sink>();
    private final SinkTransport mSinkTransport = new SinkTransport();
    private final HashSet<Sink> mSinkSet = new HashSet<>();

    // the following constants must remain in sync with activity_recognition.h

@@ -60,7 +59,7 @@ public final class ActivityRecognitionProvider {
            throws RemoteException {
        Preconditions.checkNotNull(service);
        mService = service;
        mService.registerSink(mSinkTransport);
        mService.registerSink(new SinkTransport());
    }

    public String[] getSupportedActivities() throws RemoteException {
@@ -102,26 +101,23 @@ public final class ActivityRecognitionProvider {

    private final class SinkTransport extends IActivityRecognitionHardwareSink.Stub {
        @Override
        public void onActivityChanged(
                android.hardware.location.ActivityChangedEvent activityChangedEvent) {
        public void onActivityChanged(android.hardware.location.ActivityChangedEvent event) {
            Collection<Sink> sinks;
            synchronized (mSinkSet) {
                if (mSinkSet.isEmpty()) {
                    return;
                }

                sinks = new ArrayList<Sink>(mSinkSet);
                sinks = new ArrayList<>(mSinkSet);
            }

            // translate the event from platform internal and GmsCore types
            ArrayList<ActivityRecognitionEvent> gmsEvents =
                    new ArrayList<ActivityRecognitionEvent>();
            for (android.hardware.location.ActivityRecognitionEvent event
                    : activityChangedEvent.getActivityRecognitionEvents()) {
            ArrayList<ActivityRecognitionEvent> gmsEvents = new ArrayList<>();
            for (android.hardware.location.ActivityRecognitionEvent reportingEvent
                    : event.getActivityRecognitionEvents()) {
                ActivityRecognitionEvent gmsEvent = new ActivityRecognitionEvent(
                        event.getActivity(),
                        event.getEventType(),
                        event.getTimestampNs());
                        reportingEvent.getActivity(),
                        reportingEvent.getEventType(),
                        reportingEvent.getTimestampNs());
                gmsEvents.add(gmsEvent);
            }
            ActivityChangedEvent gmsEvent = new ActivityChangedEvent(gmsEvents);
+75 −0
Original line number 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