Skip to content

Access sensor data for any Android device easily using Jetpack Compose 🌑️ 🧲 🧭

License

Notifications You must be signed in to change notification settings

mutualmobile/ComposeSensors

This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.

Folders and files

NameName
Last commit message
Last commit date
Sep 5, 2023
Jul 30, 2023
Mar 23, 2023
Oct 25, 2023
Sep 5, 2023
Sep 5, 2023
Sep 5, 2023
Jul 29, 2023
Mar 23, 2023
Jul 30, 2023
Sep 5, 2023
Mar 24, 2023
Sep 5, 2023
Jul 29, 2023
Jul 29, 2023
Mar 30, 2023

Repository files navigation

Compose Sensors

Accessing sensor data of your Android devices just became quick and easy ⚑️

This library provides a convenience wrapper over the Sensor APIs for Android to be used with Jetpack Compose.

Demo ❀️

Because A picture is worth a thousand words

Screen Recording 2023-04-03 at 1 00 08 PM

Usage πŸš€

Install dependency πŸ“²

Kotlin build.gradle.kts (:module-name)

dependencies {
    ...
    implementation("com.mutualmobile:composesensors:x.y.z")
}

Groovy build.gradle (:module-name)

dependencies {
    ...
    implementation 'com.mutualmobile:composesensors:x.y.z'
}

The library provides straightforward state methods for multiple sensors like Accelerometer, Gyroscope, etc (more mentioned below). Following is an example on how to get the current values from the Accelerometer:

val accelerometerState = rememberAccelerometerSensorState()

Use it in an example:

val accelerometerState = rememberAccelerometerSensorState()
// Optional: You could also write: rememberAccelerometerSensorState(sensorDelay = SensorDelay.Fastest) for fetching sensor data faster

Text(
    text = "Force X: ${accelerometerState.xForce}" +
    "\nForce Y: ${accelerometerState.yForce}" +
    "\nForce Z: ${accelerometerState.zForce}" +
    "\nIs Available?: ${accelerometerState.isAvailable}"
)

Sensors Supported πŸ“±

ComposeSensors supports the following Android sensors:

Sensor Composable
Accelerometer rememberAccelerometerSensorState()
Magnetic Field rememberMagneticFieldSensorState()
Gyroscope rememberGyroscopeSensorState()
Light rememberLightSensorState()
Pressure rememberPressureSensorState()
Proximity rememberProximitySensorState()
Gravity rememberGravitySensorState()
Linear Acceleration rememberLinearAccelerationSensorState()
Rotation Vector rememberRotationVectorSensorState()
Relative Humidity rememberRelativeHumiditySensorState()
Ambient Temperature rememberAmbientTemperatureSensorState()
Magnetic Field (Uncalibrated)️ rememberUncalibratedMagneticFieldSensorState()
GameRotation Vector rememberGameRotationVectorSensorState()
Gyroscope (Uncalibrated) rememberUncalibratedGyroscopeSensorState()
Significant Motion rememberSignificantMotionSensorState(onMotionEvent = {})
Step Detector rememberStepDetectorSensorState()
Step Counter rememberStepCounterSensorState()
Geomagnetic Rotation Vector rememberGeomagneticRotationVectorSensorState()
Heart Rate rememberHeartRateSensorState()
Pose6DOF rememberPose6DOFSensorState()
Stationary Detect rememberStationaryDetectSensorState()
Motion Detect rememberMotionDetectSensorState()
Heart Beat rememberHeartBeatSensorState()
Low Latency Off-Body Detect rememberLowLatencyOffBodyDetectSensorState()
Accelerometer (Uncalibrated) rememberUncalibratedAccelerometerSensorState()
Hinge Angle rememberHingeAngleSensorState()
Head Tracker rememberHeadTrackerSensorState()
Accelerometer Limited Axes rememberLimitedAxesAccelerometerSensorState()
Gyroscope Limited Axes rememberLimitedAxesGyroscopeSensorState()
Accelerometer Limited Axes (Uncalibrated) rememberUncalibratedLimitedAxesAccelerometerSensorState()
Gyroscope Limited Axes (Uncalibrated) rememberUncalibratedLimitedAxesGyroscopeSensorState()
Heading rememberHeadingSensorState()

License πŸ”–

Copyright 2023 MutualMobile

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

   http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.