Coder Social home page Coder Social logo

xhmm / react-native-headphone-motion Goto Github PK

View Code? Open in Web Editor NEW
7.0 2.0 0.0 165 KB

A react-native module for iOS `CMHeadphoneMotionManager` api, which you can use for getting the headphone(airpods) motion data

License: MIT License

Java 29.35% JavaScript 7.04% Ruby 13.16% Swift 17.53% C 0.34% Objective-C 7.99% Objective-C++ 5.63% TypeScript 18.96%
airpods react-native cmheadphonemotionmanager

react-native-headphone-motion's Introduction

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

react-native-headphone-motion's People

Contributors

xhmm avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.