GoogleApiClient onConnected никогда не вызывался на носимом устройстве

У меня есть носимое устройство, которое я пытаюсь подключить к GoogleApiClient, но обратные вызовы никогда не вызываются (onConnected, onConnectionSuspended или onConnectionFailed). Все остальное работает нормально, DataLayerListenerService может получать сообщения с КПК, а onPeerConnected вызывается при подключении. Я пробовал как на эмуляторе, так и на устройстве Samsung Gear Live. Это код, который у меня есть в действии, где я пытаюсь подключиться к GoogleApiClient.

public class WearReaderActivity extends Activity implements GoogleApiClient.ConnectionCallbacks, GoogleApiClient.OnConnectionFailedListener {
    public static final String CONTENT_EXTRA = "contentExtra";
    private String LOG_TAG = WearReaderActivity.class.getSimpleName();

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.reader);
        mGoogleApiClient = new GoogleApiClient.Builder(this)
                .addApi(Wearable.API)
                .addConnectionCallbacks(this)
                .addOnConnectionFailedListener(this)
                .build();
    }

    private GoogleApiClient mGoogleApiClient;

    @Override
    protected void onStart() {
        super.onStart();
        Log.e("Connected?", String.valueOf(mGoogleApiClient.isConnected()));
        //new Thread(new GetContent()).start();
    }

    @Override
    public void onConnected(Bundle bundle) {
        Log.d("Connected", "Connected");
        new Thread(new GetContent()).start();
    }

    @Override
    public void onConnectionSuspended(int i) {
        Log.d("Connection suspened", "Connection suspended");
    }

    @Override
    public void onConnectionFailed(ConnectionResult connectionResult) {
        Log.d("Connection suspened", "Connection suspended");
    }
...
}

Не уверен, что это поможет, но это мой манифест для приложения Wearable.

    <?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
          package="my.packagename">
    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@android:style/Theme.DeviceDefault" >
        <meta-data
            android:name="com.google.android.gms.version"
            android:value="@integer/google_play_services_version" />

    <activity
        android:name=".WearReaderActivity"
        android:label="Reading" >
        <intent-filter>
           <action android:name="android.intent.action.MAIN" />
           <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>

<meta-data android:name="com.google.android.gms.version"
       android:value="@integer/google_play_services_version" />

    <service
        android:name=".DataLayerListenerService" >
        <intent-filter>
            <action android:name="com.google.android.gms.wearable.BIND_LISTENER" />
        </intent-filter>
    </service>

</application>

Any ideas?

РЕДАКТИРОВАТЬ: добавлено следующее в манифест носимых устройств, но все еще не работает

<meta-data android:name="com.google.android.gms.version"
           android:value="@integer/google_play_services_version" />

person odiggity    schedule 10.07.2014    source источник


Ответы (3)


Ого, ответ до безобразия прост. Я пропустил часть, где в onStart() нужно звонить mGoogleApiClient.connect().

person odiggity    schedule 10.07.2014
comment
К сожалению, это случилось и со мной в самом начале. Ржу не могу. - person gatlingxyz; 15.07.2014
comment
Не так уж и неловко, когда в «уроках» документации об этом не упоминается. - person iforce2d; 27.12.2014
comment
Именно то, о чем я думал iforce2d. - person bmeulmeester; 21.01.2015
comment
Шокирующее упущение в руководстве по адресу developer.android.com/training/location/retrieve- текущий.html! - person Craig McMahon; 29.01.2015
comment
Я отправил запрос на исправление документации здесь. - person Wayne Piekarski; 10.07.2015
comment
В уроках документации об этом не упоминается, как нам указывал @iforce2d. Будьте осторожны, вызывая mGoogleApiClient.disconnect() также в onStop(). - person Sébastien BATEZAT; 14.07.2015
comment
.... это ВСЕ ЕЩЕ проблема с документацией.... удивительно. К их чести, вы можете проверить пример кода (который сам по себе является жесткой ссылкой для поиска на странице), где они действительно показывают onStart() и подключение: github.com/googlesamples/android -play-location/blob/master/ - person Don Cheadle; 23.08.2015

Вы можете вызвать подключение и отключение вручную в методах жизненного цикла onStart и onStop или использовать enableAutoManage< /a> особенность.

mCredentialsApiClient = new GoogleApiClient.Builder(this)
            .addConnectionCallbacks(this)
            .enableAutoManage(this, this)
            .addApi(Auth.CREDENTIALS_API)
            .build();
person Imre    schedule 18.11.2015

Кроме того, я заметил, что если вы попытаетесь выполнить GoogleApiClient, когда пользователь не настроил Google Play, может возникнуть конфликт при подключении. (Я только что перезагрузил свое устройство, и вот что произошло). Поэтому рекомендуется проверить соединение с GoogleApiClient, используя

mCredentialsApiClient = new GoogleApiClient.Builder(this)
        .addConnectionCallbacks(this)
        .addOnConnectionFailedListener(this)

Или просто проверьте mCredentialsApiClient.isConnected() перед выполнением какой-либо задачи.

person Juan Mendez    schedule 29.09.2017