Обнаружение активности пользователя (запуск, циклирование, вождение) с помощью Android

Используя мой Android-устройство, как я могу определить, идет ли пользователь пешком, на велосипеде или вождении? Я проверил приложение Google Fit. Он отличает бег, езда на велосипеде и вождение. Я озадачен тем, какие алгоритмы я должен использовать, чтобы различать эти действия.

Я знаю, что мне придется использовать датчик акселерометра. Но все же я не могу отличить эти действия.

Ответ 1

Вы можете использовать GooglePlayServices для этого.

Он предоставляет специальный apis для ActivityRecognition, который возвращает активность пользователя с уровнем достоверности для каждого.

https://developer.android.com/reference/com/google/android/gms/location/ActivityRecognitionClient.html

http://developer.android.com/training/location/activity-recognition.html

Ответ 2

Этот вопрос довольно старый, но поскольку есть новые технологии, я думал, что стоит упомянуть, если кто-то все еще сталкивается с этой проблемой.

Я могу придумать 3 варианта:

  • Вы можете реализовать свою собственную технику обнаружения хождения, вождения, езды на велосипеде - используя распознавание активности и получение обновлений местоположения, хотя я рекомендую не делать этого, не изобретайте велосипед, есть неплохие apis, уже разработанные в 2016 году.
  • Вы можете использовать бесплатный sdk Neura, который может отправить вам событие, когда ваш пользователь начинает/заканчивает вождение, начинает/заканчивает ходьбу, начинает/завершить работу, узнать больше о событиях, которые вы можете получить от Neura.

    Посмотрите этот git проект: в принципе, у проекта есть все события, которые Nuera может обнаружить. Его очень просто взять этот проект и сделать его своим.

    Я настоятельно рекомендую использовать эту опцию Nega sdk.

  • Вы можете использовать google FenceApi, чтобы объявлять заборы. Например, это код для обнаружения движущей ограды.

    Хотя этот подход кажется хорошим, я столкнулся с тем фактом, что этот api иногда не говорил мне, когда происходили события, и иногда это занимало много времени после того, как я начал ходить/бегать, когда api рассказала мне об этом событие.

    а. включить зависимость от вашего файла build.gradle приложения:

       compile 'com.google.android.gms:play-services-location:+'
    
       compile 'com.google.android.gms:play-services-contextmanager:+'
    

    б. Определения манифеста:

    <uses-permission android:name="com.google.android.gms.permission.ACTIVITY_RECOGNITION" />
    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
    
    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:supportsRtl="true"
        android:theme="@style/AppTheme" >
    
        <meta-data
            android:name="com.google.android.awareness.API_KEY"
            android:value="PUT_YOUR_AWARENESS_KEY_HERE" />
    
        <activity android:name=".MainActivity" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
    
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>
    

    PUT_YOUR_AWARENESS_KEY_HERE: вам нужно создать ключ здесь.

    с. Класс MainActivity - объяснения, прилагаемые к коду:

    public class MainActivity extends Activity {
    
        private GoogleApiClient mGoogleApiClient;
        private PendingIntent mPendingIntent;
        private FenceReceiver mFenceReceiver;
    
        // The intent action which will be fired when your fence is triggered.
        private final String FENCE_RECEIVER_ACTION = BuildConfig.APPLICATION_ID + "FENCE_RECEIVER_ACTION";
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
            mGoogleApiClient = new GoogleApiClient.Builder(this).addApi(Awareness.API).build();
            mGoogleApiClient.connect();
            // Set up the PendingIntent that will be fired when the fence is triggered.
            mPendingIntent = PendingIntent.getBroadcast(this, 0, new Intent(FENCE_RECEIVER_ACTION), 0);
            // The broadcast receiver that will receive intents when a fence is triggered.
            mFenceReceiver = new FenceReceiver();
            registerReceiver(mFenceReceiver, new IntentFilter(FENCE_RECEIVER_ACTION));
            createFence(DetectedActivityFence.IN_VEHICLE, "InVehicleFence");
        }
    
        @Override
        public void onDestroy() {
            try {
                unregisterReceiver(mFenceReceiver); //Don't forget to unregister the receiver
            } catch (Exception e) {
                e.printStackTrace();
            }
            super.onDestroy();
        }
    
        private void createFence(int detectedActivityFence, final String fenceKey) {
            AwarenessFence fence = DetectedActivityFence.during(detectedActivityFence);
            // Register the fence to receive callbacks.
            Awareness.FenceApi.updateFences(
                    mGoogleApiClient, new FenceUpdateRequest.Builder().addFence(fenceKey, fence, mPendingIntent)
                            .build()).setResultCallback(new ResultCallback<Status>() {
                @Override
                public void onResult(@NonNull Status status) {
                    if (status.isSuccess()) {
                        Log.i(getClass().getSimpleName(), "Successfully registered.");
                    } else {
                        Log.e(getClass().getSimpleName(), "Could not be registered: " + status);
                    }
                }
            });
        }
    
        // Handle the callback on the Intent.
        public class FenceReceiver extends BroadcastReceiver {
            @Override
            public void onReceive(Context context, Intent intent) {
                FenceState fenceState = FenceState.extract(intent);
                switch (fenceState.getCurrentState()) {
                    case FenceState.TRUE:
                        Log.i(fenceState.getFenceKey(), "Active");
                        break;
                    case FenceState.FALSE:
                        Log.i(fenceState.getFenceKey(), "Not Active");
                        break;
                }
            }
        }
    }
    

    Этот пример предназначен только для определения состояния вождения, но вы можете вызвать "createFence" с другими методами активности, такими как:

    createFence(DetectedActivityFence.TILTING, "TiltingFence");
    createFence(DetectedActivityFence.WALKING, "WalkingFence");
    createFence(DetectedActivityFence.ON_FOOT, "OnFootFence");
    createFence(DetectedActivityFence.RUNNING, "RunningFence");
    

Ответ 3

Вы можете использовать DetectActivity, чтобы различать предопределенные типы действий.