2016-09-30 3 views
0

Как рассчитать расстояние, покрываемое пользователем, с помощью API-интерфейса google? В настоящее время я использую Google Fit История Апи, как это:Google Fit API: получить расстояние от google fit

DataReadRequest readRequest = new DataReadRequest.Builder() 
        .aggregate(DataType.TYPE_DISTANCE_DELTA, DataType.AGGREGATE_DISTANCE_DELTA) 
        .bucketByTime(1, TimeUnit.DAYS) 
        .setTimeRange(startTime, endTime, TimeUnit.MILLISECONDS) 
        .build(); 

      DataReadResult dataReadResult = 
        Fitness.HistoryApi.readData(mGoogleApiClient, readRequest).await(1, TimeUnit.MINUTES); 

Но это не возвращает значение ли кто-нибудь ключ?

+0

Вы нашли решение? По одной и той же проблеме. – Smeet

+0

нет .. все еще сталкивается с той же проблемой –

ответ

1

Вам нужно добавить еще один объем, когда экземпляр GoogleApiClient.Builder:

«.addScope (новый Scope (Scopes.FITNESS_LOCATION_READ))»

И вы также должны получить разрешение Расположение путем добавления этого разрешения в файле манифеста:

и в своей деятельности, добавьте этот метод:

public void request_location_permission() { 

    // If location permission was not granted yet, request it. Otherwise, request nothing and 
    // just do what you want. 
    if (ContextCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION) != 
    PackageManager.PERMISSION_GRANTED) { 

    PermissionUtils.requestPermission(this, LOCATION_PERMISSION_REQUEST_CODE, 
     Manifest.permission.ACCESS_FINE_LOCATION, false); 

    } else { 
    process(); 
    } 
} 

PermissionUtils мой собственный класс, вы можете использовать его, чтобы иметь незамедлительный взгляд, если вы хотите увидеть результат первый:

public abstract class PermissionUtils { 

/** 
* Requests the fine location permission. If a rationale with an additional explanation should 
* be shown to the user, displays a dialog that triggers the request. 
*/ 
public static void requestPermission(AppCompatActivity activity, int requestId, 
            String permission, boolean finishActivity) { 
    if (ActivityCompat.shouldShowRequestPermissionRationale(activity, permission)) { 

     // Display a dialog with rationale, this dialog wil request permission by itself. 
     PermissionUtils.RationaleDialog.newInstance(requestId, finishActivity) 
       .show(activity.getSupportFragmentManager(), "dialog"); 
    } else { 

     // Location permission has not been granted yet, request it. 
     ActivityCompat.requestPermissions(activity, new String[]{permission}, requestId); 
    } 
} 

/** 
* Checks if the result contains a {@link PackageManager#PERMISSION_GRANTED} result for a 
* permission from a runtime permissions request. 
* 
* @see android.support.v4.app.ActivityCompat.OnRequestPermissionsResultCallback 
*/ 
public static boolean isPermissionGranted(String[] grantPermissions, int[] grantResults, 
              String permission) { 
    for (int i = 0; i < grantPermissions.length; i++) { 
     if (permission.equals(grantPermissions[i])) { 
      return grantResults[i] == PackageManager.PERMISSION_GRANTED; 
     } 
    } 
    return false; 
} 

/** 
* A dialog that displays a permission denied message. 
*/ 
public static class PermissionDeniedDialog extends DialogFragment { 

    private static final String ARGUMENT_FINISH_ACTIVITY = "finish"; 

    private boolean mFinishActivity = false; 

    /** 
    * Creates a new instance of this dialog and optionally finishes the calling Activity 
    * when the 'Ok' button is clicked. 
    */ 
    public static PermissionDeniedDialog newInstance(boolean finishActivity) { 
     Bundle arguments = new Bundle(); 
     arguments.putBoolean(ARGUMENT_FINISH_ACTIVITY, finishActivity); 

     PermissionDeniedDialog dialog = new PermissionDeniedDialog(); 
     dialog.setArguments(arguments); 
     return dialog; 
    } 

    @Override 
    public Dialog onCreateDialog(Bundle savedInstanceState) { 
     mFinishActivity = getArguments().getBoolean(ARGUMENT_FINISH_ACTIVITY); 

     return new AlertDialog.Builder(getActivity()) 
       .setMessage(R.string.location_permission_denied) 
       .setPositiveButton(android.R.string.ok, null) 
       .create(); 
    } 

    @Override 
    public void onDismiss(DialogInterface dialog) { 
     super.onDismiss(dialog); 
     if (mFinishActivity) { 
      Toast.makeText(getActivity(), R.string.permission_required_toast, 
        Toast.LENGTH_SHORT).show(); 
      getActivity().finish(); 
     } 
    } 
} 

/** 
* A dialog that explains the use of the location permission and requests the necessary 
* permission. 
* <p> 
* The activity should implement 
* {@link android.support.v4.app.ActivityCompat.OnRequestPermissionsResultCallback} 
* to handle permit or denial of this permission request. 
*/ 
public static class RationaleDialog extends DialogFragment { 

    private static final String ARGUMENT_PERMISSION_REQUEST_CODE = "requestCode"; 

    private static final String ARGUMENT_FINISH_ACTIVITY = "finish"; 

    private boolean mFinishActivity = false; 

    /** 
    * Creates a new instance of a dialog displaying the rationale for the use of the location 
    * permission. 
    * <p> 
    * The permission is requested after clicking 'ok'. 
    * 
    * @param requestCode Id of the request that is used to request the permission. It is 
    *      returned to the 
    *      {@link android.support.v4.app.ActivityCompat.OnRequestPermissionsResultCallback}. 
    * @param finishActivity Whether the calling Activity should be finished if the dialog is 
    *      cancelled. 
    */ 
    public static RationaleDialog newInstance(int requestCode, boolean finishActivity) { 
     Bundle arguments = new Bundle(); 
     arguments.putInt(ARGUMENT_PERMISSION_REQUEST_CODE, requestCode); 
     arguments.putBoolean(ARGUMENT_FINISH_ACTIVITY, finishActivity); 
     RationaleDialog dialog = new RationaleDialog(); 
     dialog.setArguments(arguments); 
     return dialog; 
    } 

    @Override 
    public Dialog onCreateDialog(Bundle savedInstanceState) { 
     Bundle arguments = getArguments(); 
     final int requestCode = arguments.getInt(ARGUMENT_PERMISSION_REQUEST_CODE); 
     mFinishActivity = arguments.getBoolean(ARGUMENT_FINISH_ACTIVITY); 

     return new AlertDialog.Builder(getActivity()) 
       .setMessage(R.string.permission_rationale_location) 
       .setPositiveButton(android.R.string.ok, new DialogInterface.OnClickListener() { 
        @Override 
        public void onClick(DialogInterface dialog, int which) { 
         // After click on Ok, request the permission. 
         ActivityCompat.requestPermissions(getActivity(), 
           new String[]{Manifest.permission.ACCESS_FINE_LOCATION}, 
           requestCode); 
         // Do not finish the Activity while requesting permission. 
         mFinishActivity = false; 
        } 
       }) 
       .setNegativeButton(android.R.string.cancel, null) 
       .create(); 
    } 

    @Override 
    public void onDismiss(DialogInterface dialog) { 
     super.onDismiss(dialog); 
     if (mFinishActivity) { 
      Toast.makeText(getActivity(), 
        R.string.permission_required_toast, 
        Toast.LENGTH_SHORT) 
        .show(); 
      getActivity().finish(); 
     } 
    } 
} 

Это мой способ получить разрешение на получение разрешения от пользователя, создав мой собственный диалог Rational, вы можете сделать по-другому, выполнив поиск, как получить разрешение на размещение в google.

Надеется, что это поможет,

Mttdat.

0

Постарайтесь проверить руководство по эксплуатации Record a Workout. После записи ваших данных о фитнесе попробуйте прочитать руководство Working with Datasets, чтобы получить доступ к типу данных com.google.distance.delta, на котором находится пройденное расстояние.

Вот Google Fit repo для реальных образцов кода.

+0

Нет .. этот не работает –

+1

У меня была аналогичная проблема, пытающаяся получить доступ к новому GoogleApiClient.Builder (this) .addApi (Fitness.HISTORY_API) .addScope (новый масштаб (Scopes. FITNESS_ACTIVITY_READ_WRITE)), после часов чтения документов и пробных решений; выяснили, что единственный способ разрешить доступ к сервисам Google Play Services - это когда вы запускаете из ** подписанного приложения **, с тем же хранилищем ключей, которое вы создали ключ SHA1, для OAuth2 от Google. Установка отладки, подписанной apk, решила проблему для меня. – Awi

1

Я решил проблему в своем проекте после многого. Если у вас есть проблема, сообщите мне, я помогу вам. Вы должны добавить сферу, как показано ниже:

.addScope (новый Scope (Scopes.FITNESS_LOCATION_READ))

+0

где добавить область? –

Смежные вопросы