Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/osteele/p5-orientation-and-motion-example
https://github.com/osteele/p5-orientation-and-motion-example
demo device-motion device-orientation example orientation-events p5js
Last synced: about 2 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/osteele/p5-orientation-and-motion-example
- Owner: osteele
- Created: 2021-05-31T06:29:47.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2021-06-01T04:23:16.000Z (over 3 years ago)
- Last Synced: 2024-10-12T15:46:04.158Z (3 months ago)
- Topics: demo, device-motion, device-orientation, example, orientation-events, p5js
- Language: JavaScript
- Homepage: https://osteele.github.io/p5-orientation-and-motion-example/
- Size: 26.4 KB
- Stars: 5
- Watchers: 3
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# JavaScript Motion and Orientation Demo (in P5)
This is a demonstration of the [device motion and orientation JavaScript
APIs][Detecting Device Orientation], that read accelerometer data from a mobile
device.You may interact with the page at .
The motion and orientation data is displayed in three ways:
1. All motion and orientation values are displayed in textual form
2. A ball moves around the screen in response to the accelerometer
3. A compass displays the heading and the heading accuracy(The ball rotation is simply a frill. It does not directly relate to any sensor
value.)The code uses [p5.js](https://p5js.org).
## Development Instructions
Note that the page needs to *served* over HTTPS, and *viewed* on a mobile device.
Some ways to do this are:
- Run the code on the [P5 Web Editor](https://editor.p5js.org), or (untested)
JSFiddle or CodePen.- Serve the project from your laptop. For example: (a) Open the project in
Visual Studio Code; (b) use the Live Server extension; (c) Use ngrok to create
an HTTPS address for it; (d) visit the `https://` URL on your phone.- Publish the file to GitHub Pages, Netlify, or Vercel. (This is a very slow
development cycle.)This doesn't work:
- Run the program in OpenProcessing.org. This doesn't work because “Source frame
did not have the same security origin as the main page.” Example:
## Gotchas
- The `devicemotion` and `deviceorientation` event listeners may only be added
from then `then` of a call to `DeviceMotionEvent.requestPermission`.
- The call to `DeviceMotionEvent.requestPermission` needs to occur the handler
of a user gesture, such as a mouse click or key press.
- Some example code on the web assigns to `window.ondevicemotion` instead of
adding calling `addEventListener`. This has the same limitations as calling
`addEventListener` with these event names.
- JavaScript code that listens to the motion and orientation events only works
if it is (1) served from `localhost` or `127.0.0.1`, *or* (2) served via
HTTPS. See the Instructions, above.## References
MDN Articles:
- [Detecting Device
Orientation]
- [Orientation and Motion Data
Explained](https://developer.mozilla.org/en-US/docs/Web/Events/Orientation_and_motion_data_explained)
- [DeviceOrientationEvent
reference](https://developer.mozilla.org/en-US/docs/Web/API/DeviceOrientationEvent)
- [DeviceMotionEvent
reference](https://developer.mozilla.org/en-US/docs/Web/API/DeviceMotionEvent)Other documentation:
- [Google Developer Docs: Device Orientation & Motion](https://developers.google.com/web/fundamentals/native-hardware/device-orientation/)
- [Apple Developer Documentation: Device Orientation Event](https://developer.apple.com/documentation/webkitjs/deviceorientationevent)
- [Apple Developer Documentation: Device Motion Event](https://developer.apple.com/documentation/webkitjs/devicemotionevent)[Detecting Device Orientation]: https://developer.mozilla.org/en-US/docs/Web/Events/Detecting_device_orientation
## Credits
The “View Source” CSS is adapted from Christian Heilmann and Ildar Sagdejev's
[Pure CSS responsive "Fork me on GitHub"
ribbon](http://codepo8.github.io/css-fork-on-github-ribbon/).## License
MIT