1 /* 2 * Copyright (C) 2023 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 package android.health.connect.internal.datatypes; 17 18 import android.annotation.NonNull; 19 import android.health.connect.datatypes.BoneMassRecord; 20 import android.health.connect.datatypes.Identifier; 21 import android.health.connect.datatypes.RecordTypeIdentifier; 22 import android.health.connect.datatypes.units.Mass; 23 import android.os.Parcel; 24 25 /** 26 * @see BoneMassRecord 27 * @hide 28 */ 29 @Identifier(recordIdentifier = RecordTypeIdentifier.RECORD_TYPE_BONE_MASS) 30 public final class BoneMassRecordInternal extends InstantRecordInternal<BoneMassRecord> { 31 private double mMass; 32 getMass()33 public double getMass() { 34 return mMass; 35 } 36 37 /** returns this object with the specified mass */ 38 @NonNull setMass(double mass)39 public BoneMassRecordInternal setMass(double mass) { 40 this.mMass = mass; 41 return this; 42 } 43 44 @NonNull 45 @Override toExternalRecord()46 public BoneMassRecord toExternalRecord() { 47 return new BoneMassRecord.Builder(buildMetaData(), getTime(), Mass.fromGrams(getMass())) 48 .setZoneOffset(getZoneOffset()) 49 .buildWithoutValidation(); 50 } 51 52 @Override populateInstantRecordFrom(@onNull Parcel parcel)53 void populateInstantRecordFrom(@NonNull Parcel parcel) { 54 mMass = parcel.readDouble(); 55 } 56 57 @Override populateInstantRecordTo(@onNull Parcel parcel)58 void populateInstantRecordTo(@NonNull Parcel parcel) { 59 parcel.writeDouble(mMass); 60 } 61 } 62