이 예시에서는 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) })
}