API распознавания активности Google

Я собираюсь написать приложение, используя API распознавания активности сервисов Google Play. Обучение на сайте разработчиков Android было прямым, но в последние пару часов я написал простое приложение, но не могу получить от него никакого результата. ОБНОВЛЕНИЕ: На самом деле я собираюсь показать текущую активность пользователя с 5-секундными интервалами в качестве тост-сообщения (как вы можете видеть в методе OnIntentHandler в ActivityRecognitionService Intent Servie) . я думаю, что что-то не так с вызовом Intent, потому что, как вы можете видеть в моем коде, тост, который говорит ActivityRecognitionClient, связан с методом OnConnected.

я что-то пропустил?

Заранее спасибо.

Файл манифеста:

    <?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.nikapps.activityrecognition"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="17" />
    <uses-permission
    android:name="com.google.android.gms.permission.ACTIVITY_RECOGNITION"/>
    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <service
        android:name="com.nikapps.activityrecognition.ActivityRecognitionService"
        android:label="@string/app_name"
        android:exported="false">
        </service>
        <activity
            android:name="com.nikapps.activityrecognition.MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>

MainActivity.java

    package com.nikapps.activityrecognition;

import com.google.android.gms.common.ConnectionResult;
import com.google.android.gms.common.GooglePlayServicesClient.ConnectionCallbacks;
import com.google.android.gms.common.GooglePlayServicesClient.OnConnectionFailedListener;
import com.google.android.gms.location.ActivityRecognitionClient;
import android.app.PendingIntent;
import android.content.Intent;
import android.os.Bundle;
import android.support.v4.app.FragmentActivity;
import android.view.Menu;
import android.widget.Toast;

public class MainActivity extends FragmentActivity implements ConnectionCallbacks, OnConnectionFailedListener{

    public static int intervals = 5000;
    private PendingIntent pendingIntent;
    private ActivityRecognitionClient activityRecognition;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        activityRecognition = new ActivityRecognitionClient(this, this, this);
        activityRecognition.connect();
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.main, menu);
        return true;
    }

    @Override
    public void onConnectionFailed(ConnectionResult result) {
        // TODO Auto-generated method stub

    }

    @Override
    public void onConnected(Bundle connectionHint) {
        // TODO Auto-generated method stub
        Toast.makeText(this, "connected", Toast.LENGTH_SHORT).show();

        Intent intent = new Intent(this, ActivityRecognitionService.class);

        pendingIntent = PendingIntent.getService(this, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT);
        activityRecognition.requestActivityUpdates(0, pendingIntent);
    }

    @Override
    public void onDisconnected() {
        // TODO Auto-generated method stub
        Toast.makeText(this, "disconnected", Toast.LENGTH_SHORT).show();

    }

}

ActivityRecognitionService.java

    package com.nikapps.activityrecognition;

import com.google.android.gms.location.ActivityRecognitionResult;
import com.google.android.gms.location.DetectedActivity;

import android.app.IntentService;
import android.content.Intent;
import android.widget.Toast;

public class ActivityRecognitionService extends IntentService{

    public ActivityRecognitionService() {
        super("ActivityRecognitionService");
        Toast.makeText(this, "here", Toast.LENGTH_SHORT).show();
        // TODO Auto-generated constructor stub
    }

    @Override
    protected void onHandleIntent(Intent intent) {

        // TODO Auto-generated method stub

        Toast.makeText(this, "here2", Toast.LENGTH_SHORT).show();
        ActivityRecognitionResult result = ActivityRecognitionResult.extractResult(intent);
        DetectedActivity activity = result.getMostProbableActivity();
        int type = activity.getType();

        Toast.makeText(this, getNameFromType(type), Toast.LENGTH_SHORT).show();

    }

    private String getNameFromType(int activityType) {
        switch(activityType) {
            case DetectedActivity.IN_VEHICLE:
                return "in_vehicle";
            case DetectedActivity.ON_BICYCLE:
                return "on_bicycle";
            case DetectedActivity.ON_FOOT:
                return "on_foot";
            case DetectedActivity.STILL:
                return "still";
            case DetectedActivity.UNKNOWN:
                return "unknown";
            case DetectedActivity.TILTING:
                return "tilting";
        }
        return "unknown";
    }
}

2 ответа

Вы можете передать намерение отправлять сообщения из службы в основной класс
Например, используйте следующее в вашем ActivityRecognitionService.java:

Intent mIntent = new Intent("myCustomIntentMessage")
    .putExtra("ActivityType", getNameFromType(type));
getLocalBroadcast().sendBroadcast(mIntent);

Затем вам просто нужно зарегистрировать приемник вещания для "myCustomIntentMessage" в файле MainActivity.java и поместить код сообщения Toast в событие OnReceive приемника вещания.

Вы можете вызывать Toast только из потока, для которого настроен обработчик /Looper. Чтобы достичь того, что вы предполагаете, у вас есть два варианта

  1. Используйте широковещательную рассылку от IntentService и выполните действие с BroadcastReceiver, отображающим пользовательский интерфейс. Таким образом, тост не отображается, когда действие не на переднем плане. зарегистрируйте / отмените регистрацию получателя в вашем onResume()/onPause()
  2. создайте обработчик и вызовите ваш метод в Handler.post(new Runnable() {.. })

Ошибка вызова тоста из Сервиса Android

Другие вопросы по тегам