0.1.0 • Published 10 months ago

react-native-headphone-motion v0.1.0

Weekly downloads
-
License
MIT
Repository
github
Last release
10 months ago

react-native-headphone-motion

A react-native module for iOS CMHeadphoneMotionManager api, which you can use for getting the headphone(airpods) motion data, this api is only available for iOS 14+

Install

npm install react-native-headphone-motion
npx pod-install

Then you must add below config to Info.plist if you are going to get headphone motion data, or your app will be crashed by system:

<key>NSMotionUsageDescription</key>
<string>The description will be shown under the permission dialog</string>

API

isHeadphoneMotionAvailable

a boolean constant for checking if the system support this functionality

requestPermission() => Promise<AuthorizationStatus>

call this will trigger system permission dialog to request permission and return the permission status. Same with other permission strategy, the dialog only show at the first call, subsequent calls only return status.

getAuthorizationStatus() => Promise<AuthorizationStatus>

get the permission request status

startListenDeviceMotionUpdates() => Promise<void>

after calling this, onDeviceMotionUpdates event will be triggered continuously if the device was connected and onDeviceMotionUpdatesError would be triggered if error occurred

startDeviceMotionUpdates() => Promise<void>

after calling this, no onDeviceMotionUpdates or onDeviceMotionUpdatesError would be triggered, you need to manually call getLatestDeviceMotion() to get the latest motion data

stopDeviceMotionUpdates() => Promise<void>

after calling this, onHeadphoneDisconnected event would be triggered (the system automatically disconnect your headphone from your app if you stopped getting motion updates), and getLatestDeviceMotion() will always return empty data

isDeviceMotionActive() => Promise<boolean>

check if you are in active status of getting motion data

getLatestDeviceMotion() => Promise<HeadphoneMotionData | null>

get the latest motion data, normally used with startDeviceMotionUpdates, return null if you did not call startXxUpdates

onDeviceMotionUpdates((data: HeadphoneMotionData) => void) => EmitterSubscription

a listener called after you called startListenDeviceMotionUpdates

onDeviceMotionUpdatesError((error: {text: string}) => void) => EmitterSubscription

a listener called after you called startListenDeviceMotionUpdates

onHeadphoneConnected(() => void) => EmitterSubscription

a listener called when you called startXxUpdates and headphone is in connected

onHeadphoneDisconnected(() => void) => EmitterSubscription

a listener called when you called stopDeviceMotionUpdates and headphone is in connected

License

MIT