Please check the build logs for more information.
See Builds for ideas on how to fix a failed build, or Metadata for how to configure docs.rs builds.
If you believe this is docs.rs' fault, open an issue.
bevy_ios_notifications
Rust crate and Swift package to easily integrate iOS's native Notification API into a Bevy application.
Demo from our game using this crate: zoolitaire.com
Features
- change/read badge
- get remote push deviceToken
- scheduling local notifications
- enable/disable presenting notifications while app is foregrounded
- and the notoriously hard (in unity) to do things like: what notification was clicked
Instructions
- Add to XCode: Add SPM (Swift Package Manager) dependency
- Add Rust dependency
- Setup Plugin
Use Apple Push Notification Dashboard to simply send push notifications for testing.
1. Add to XCode
Go to File
-> Add Package Dependencies
and paste https://github.com/rustunit/bevy_ios_notifications.git
into the search bar on the top right:
2. Add Rust dependency
cargo add bevy_ios_notifications
or
bevy_ios_notifications = { version = "0.4" }
3. Setup Plugin
Initialize Bevy Plugin:
// requests permissions for alerts, sounds and badges
app.add_plugins;
Trigger Alert in your application code:
// this will clear the badge, the notification center and all pending ones
// process async events coming in from ios notification system
Implementation Details
- due to the more complex nature of the types that need to be send in and out this crates uses protobuf for that (see schema)
- because winit currently does not let you hook into the AppDelegates's
didRegisterForRemoteNotificationsWithDeviceToken
callback we use method swizzling to intercept these (see code, see winit PR (dont hold your breath))
Our Other Crates
- bevy_debug_log
- bevy_device_lang
- bevy_web_popups
- bevy_libgdx_atlas
- bevy_ios_review
- bevy_ios_gamecenter
- bevy_ios_alerts
- bevy_ios_iap
- bevy_ios_impact
- bevy_ios_safearea
Bevy version support
bevy | bevy_ios_notifications |
---|---|
0.16 | 0.4,main |
0.15 | 0.3 |
0.14 | 0.2 |
0.13 | 0.1 |
License
All code in this repository is dual-licensed under either:
- MIT License (LICENSE-MIT or http://opensource.org/licenses/MIT)
- Apache License, Version 2.0 (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
at your option. This means you can select the license you prefer.
Your contributions
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.