이 예에서는 Fitness API 클라이언트를 만드는 방법을 보여줍니다.
다음과 같이 API 클라이언트를 만듭니다.
FitnessOptions
인스턴스를 만들고 앱에 필요한 데이터 유형과 액세스 유형 (읽기 또는 쓰기)을 선언합니다.val fitnessOptions = FitnessOptions.builder() .addDataType(DataType.TYPE_STEP_COUNT_DELTA, FitnessOptions.ACCESS_READ) .addDataType(DataType.AGGREGATE_STEP_COUNT_DELTA, FitnessOptions.ACCESS_READ) .build()
API에서 사용할
Account
객체의 인스턴스를 가져옵니다.val account = GoogleSignIn.getAccountForExtension(this, fitnessOptions)
사용자가 이전에 필요한 데이터 액세스 권한을 부여했는지 확인하고, 부여하지 않았다면 승인 흐름을 시작합니다.
if (!GoogleSignIn.hasPermissions(account, fitnessOptions)) { GoogleSignIn.requestPermissions( this, // your activity GOOGLE_FIT_PERMISSIONS_REQUEST_CODE, // e.g. 1 account, fitnessOptions) } else { accessGoogleFit() }
승인 흐름이 필요한 경우 사용자의 응답을 처리합니다.
override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) { super.onActivityResult(requestCode, resultCode, data) when (resultCode) { Activity.RESULT_OK -> when (requestCode) { GOOGLE_FIT_PERMISSIONS_REQUEST_CODE -> accessGoogleFit() else -> { // Result wasn't from Google Fit } } else -> { // Permission not granted } } }
사용자가 요청된 데이터에 대한 액세스를 승인한 후 앱의 목적과 요구사항에 따라 피트니스 클라이언트 (예: 이전 피트니스 데이터를 읽거나 쓰는
HistoryClient
)를 만듭니다.private fun accessGoogleFit() { val end = LocalDateTime.now() val start = end.minusYears(1) val endSeconds = end.atZone(ZoneId.systemDefault()).toEpochSecond() val startSeconds = start.atZone(ZoneId.systemDefault()).toEpochSecond() val readRequest = DataReadRequest.Builder() .aggregate(DataType.AGGREGATE_STEP_COUNT_DELTA) .setTimeRange(startSeconds, endSeconds, TimeUnit.SECONDS) .bucketByTime(1, TimeUnit.DAYS) .build() val account = GoogleSignIn.getAccountForExtension(this, fitnessOptions) Fitness.getHistoryClient(this, account) .readData(readRequest) .addOnSuccessListener({ response -> // Use response data here Log.i(TAG, "OnSuccess()") }) .addOnFailureListener({ e -> Log.d(TAG, "OnFailure()", e) }) }