首页 文章

附近的消息API没有获得任何附件

提问于
浏览
0

编辑:已经解决,是信标问题 .

我在使用Google Nearby Message API时遇到了一些麻烦 . 我按照在他们的页面(https://developers.google.com/nearby/messages/android/get-beacon-messages)上所说的那样做了,但它没有得到信标的任何附件 .

它连接到Google API客户端,它成功订阅但它永远不会到达 onFound 也不会 onLost .

我尝试了Andrew Bunner在这篇文章中所说的内容(Find Eddystone Beacons using Nearby Google API),我到了GITHUB存储库(https://github.com/googlesamples/android-nearby/blob/master/messages/NearbyDevices/app/src/main/java/com/google/android/gms/nearby/messages/samples/nearbydevices/MainActivity.java)并尝试了他们的应用程序,但它在我的任何设备(Motorola Moto X 1st generation和Google Tango平板电脑)中都不起作用,当我点击开关打开发现附近的设备或共享设备信息时,它无法订阅:"Could not subscribe, status = Status" .

我检查了我的代码,并与他们进行了比较,方法类似,但由于某些原因订阅后从未显示附件 . 我检查了我的API密钥,清单,build.gradle,信标仪表板,OAuth面板(并检查了附件确实存在)并检查它们是否属于同一个项目(信标和API),但仍然没有工作 . 我看到有些人遇到了同样的问题,但是我试着按照他们在答案中的说法去做,但似乎我做错了什么而且我看不出它是什么 .

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_beacon);

    if (ContextCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION)
            == PackageManager.PERMISSION_GRANTED) {
        mGoogleApiClient = new GoogleApiClient.Builder(this)
                .addApi(Nearby.MESSAGES_API, new MessagesOptions.Builder()
                        .setPermissions(NearbyPermissions.BLE)
                        .build())
                .addConnectionCallbacks(this)
                .enableAutoManage(this, this)
                .build();
        Log.i(TAG, "API connected");
    }
    mMessageListener = new MessageListener() {

        @Override
        public void onFound(Message message) {
            String messageAsString = new String(message.getContent());
            Log.d(TAG, "Found message: " + messageAsString);
            //When a message is found
            Log.i(TAG, "Message found: " + message.toString());
            Log.i(TAG, "Message string: " + new String(message.getContent()));
            Log.i(TAG, "Message namespaced type: " + message.getNamespace() +
                    "/" + message.getType());
        }

        @Override
        public void onLost(Message message) {
            //When a message is no longer detectable
            String messageAsString = new String(message.getContent());
            Log.d(TAG, "Lost sight of message: " + messageAsString);
        }
    };

}
private void subscribe() {
    Log.i(TAG, "Subscribing.");
    SubscribeOptions options = new SubscribeOptions.Builder()
            .setStrategy(Strategy.BLE_ONLY)
            .setCallback(new SubscribeCallback() {
                @Override
                public void onExpired() {
                    super.onExpired();
                    Log.i(TAG, "No longer subscribing");
                }
            })
            .build();
    Nearby.Messages.subscribe(mGoogleApiClient, mMessageListener, options)
            .setResultCallback(new ResultCallback<Status>() {
                @Override
                public void onResult(@NonNull Status status) {
                    if (status.isSuccess()){
                        Log.i(TAG, "Subscibed succesfully");
                    }else{
                        Log.i(TAG, "Could not subscribe");
                    }
                }
            });

}
private void unsuscribe(){
    Log.i(TAG, "Unsuscribing");
    Nearby.Messages.unsubscribe(mGoogleApiClient, mMessageListener);
}

@Override
public void onStart() {
    super.onStart();
    mGoogleApiClient.connect();
    Log.i(TAG, "onStart");
}

@Override
public void onConnected(Bundle connectionHint) {

    Log.i(TAG, "GoogleApiClient connected");
    subscribe();
}

@Override
public void onConnectionSuspended(int cause) {
    Log.e(TAG, "GoogleApiClient disconnected with cause: " + cause);
}

@Override
public void onConnectionFailed(ConnectionResult result) {
    if (result.hasResolution()) {
        try {
            result.startResolutionForResult(this, REQUEST_RESOLVE_ERROR);
        } catch (IntentSender.SendIntentException e) {
            e.printStackTrace();
        }
    } else {
        Log.e(TAG, "GoogleApiClient connection failed");
    }
}

@Override
public void onStop() {

    unsuscribe();
    if (mGoogleApiClient.isConnected()) {
        mGoogleApiClient.disconnect();
    }
    super.onStop();

}
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
    if (requestCode == REQUEST_RESOLVE_ERROR) {
        if (resultCode == RESULT_OK) {
            mGoogleApiClient.connect();
        } else {
            Log.e(TAG, "GoogleApiClient connection failed. Unable to resolve.");
        }
    } else {
        super.onActivityResult(requestCode, resultCode, data);
    }
}

1 回答

  • 0

    你可以打开以下详细日志记录并重试吗?

    $ adb shell setprop log.tag.NearbyMessages VERBOSE

    $ adb shell setprop log.tag.copresGcore VERBOSE

    我看不出你粘贴的代码有什么问题,看起来不错 .

相关问题