私はGoogleの場所apisから始めています、私はこれまで行ってきたことですが、デバイスの現在の位置を取得しようとしていますが、どのようにいつOnResultのコードが呼び出されるのかわかりません、その内部のログはlogcatで印刷されていないので:アプリケーションでOnResultが呼び出されるのはいつですか? (ResultCallback)
Log.d("2^^check1111","nside : beforee");
try {
if (ActivityCompat.checkSelfPermission(getActivity().getApplicationContext(), android.Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED) {
// TODO: Consider calling
// ActivityCompat#requestPermissions
// here to request the missing permissions, and then overriding
// public void onRequestPermissionsResult(int requestCode, String[] permissions,
// int[] grantResults)
// to handle the case where the user grants the permission. See the documentation
// for ActivityCompat#requestPermissions for more details.
Log.d("2here now","yoyo0");
ActivityCompat.requestPermissions(getActivity(), new String[] {Manifest.permission.ACCESS_FINE_LOCATION}, 123);
}
Log.d("999here now","yoyo0");
PendingResult<PlaceLikelihoodBuffer> result = Places.PlaceDetectionApi.getCurrentPlace(mGoogleApiClient, null);
Log.d("888here now","after result");
result.setResultCallback(new ResultCallback<PlaceLikelihoodBuffer>() {
@Override
public void onResult(@NonNull PlaceLikelihoodBuffer likelyPlaces) {
// utils.showLog(TAG, "" + likelyPlaces.getCount());
/// Toast.makeText(getActivity().getApplicationContext(),"inside : onResult",Toast.LENGTH_LONG).show();
Log.d("2^^check","nside : onResul");
if (likelyPlaces.getCount() > 0) {
// Toast.makeText(getActivity().getApplicationContext(),"inside :likely >0",Toast.LENGTH_LONG).show();
Log.d("2^^check2","nside :likely >0");
PlaceLikelihood placeLikelihood = likelyPlaces.get(0);
// String content = "";
if (placeLikelihood != null && placeLikelihood.getPlace() != null && !TextUtils.isEmpty(placeLikelihood.getPlace().getName())) {
Log.d("2^^check3","nside : placelikelihood not nu");
// Toast.makeText(getActivity().getApplicationContext(),"inside : placelikelihood not null",Toast.LENGTH_LONG).show();
LatLng FromLatLng = placeLikelihood.getPlace().getLatLng();
Log.d("2^^check4","4444"+FromLatLng);
// Toast.makeText(getActivity().getApplicationContext(),"inside : latlng :"+FromLatLng,Toast.LENGTH_LONG).show();
newLatLng = FromLatLng;
FromLat = FromLatLng.latitude;
FromLng = FromLatLng.longitude;
}
} else {
Toast.makeText(getActivity(), "Auto Location can't fetch", Toast.LENGTH_SHORT).show();
}
likelyPlaces.release();
}
});
} catch (Exception e) {
e.printStackTrace();
}
}
あなたのコードはtry-catchブロック内にあります。キャッチ内にいくつかのログやブレークポイントを入れて、あなたのコードがいくつかの例外をスローしているかどうかを確認してください。 – androidevil
ログにcatchブロックを追加してみましたが、そこに例外がキャッチされていません – user3820753