Skip to content
On this page

Oxygen Saturation

The Oxygen Saturation value is sent both as an instantaneous value during the measurement and as part of the final results.

The application can receive the Oxygen Saturation (SpO2) result by implementing VitalSignsListener:

Swift
func onVitalSign(vitalSign: VitalSign) {
    DispatchQueue.main.async {
        if (vitalSign.type == VitalSignTypes.oxygenSaturation) {
            if let oxygenSaturation = vitalSign as? VitalSignOxygenSaturation {
                print("Oxygen Saturation: \(oxygenSaturation.value)")
            }
        }
    }
}

func onFinalResults(results: VitalSignsResults) {
    DispatchQueue.main.async {
        if let oxygenSaturation = results.getResult(of: VitalSignTypes.oxygenSaturation) as? VitalSignOxygenSaturation {
            print("Oxygen Saturation: \(oxygenSaturation.value)")
        }
    }
}
Objective-C
- (void)onVitalSignWithVitalSign:(id<BNHVitalSign> _Nullable)vitalSign {
    dispatch_async(dispatch_get_main_queue(), ^{
        if (vitalSign.type == BNHVitalSignTypes.oxygenSaturation) {
            BNHVitalSignOxygenSaturation *oxygenSaturation = (BNHVitalSignOxygenSaturation *)vitalSign;
            if (oxygenSaturation != nil) {
                NSLog(@"Oxygen Saturation: %ld", (long)oxygenSaturation.value);
            }
        }
    });
}

- (void)onFinalResultsWithResults:(BNHVitalSignsResults *)results {
    dispatch_async(dispatch_get_main_queue(), ^{
        BNHVitalSignOxygenSaturation *oxygenSaturation = (BNHVitalSignOxygenSaturation *)[results getResultOf:BNHVitalSignTypes.oxygenSaturation];
        if (oxygenSaturation != nil) {
            NSLog(@"Oxygen Saturation: %ld", (long)oxygenSaturation.value);
        }
    });
}

For general information about vital signs see the Vital Signs and Health Indicators Information Page.

For a list of supported vital signs per platform and measurement mode (face/finger) see the Supported Vital Signs Page.

Important

Note that vital signs are sent on a background thread. The application must switch to the UI thread in order to perform UI updates.