#ios #bevy-plugin #swift #bevy #gamedev #mobile

bevy_ios_alerts

Bevy plugin to request ios native UIAlert popups

4 releases

new 0.1.3 May 11, 2024
0.1.2 Apr 17, 2024
0.1.1 Apr 17, 2024
0.1.0 Apr 17, 2024

#1163 in Game dev

Download history 352/week @ 2024-04-16 38/week @ 2024-04-23 54/week @ 2024-04-30 262/week @ 2024-05-07

706 downloads per month

MIT license

10KB
192 lines

bevy_ios_alerts

crates.io

Rust crate and Swift package to easily integrate iOS's native UIAlerts API into a Bevy application.

demo

demo from our game using this crate: zoolitaire.com

See also bevy_ios_iap, bevy_ios_notifications, bevy_ios_gamecenter, bevy_ios_review & bevy_ios_impact

Instructions

  1. Add to XCode: Add SPM (Swift Package Manager) dependency
  2. Add Rust dependency
  3. Setup Plugin

1. Add to XCode

Go to File -> Add Package Dependencies and paste https://github.com/rustunit/bevy_ios_alerts.git into the search bar on the top right: xcode

2. Add Rust dependency

cargo add bevy_ios_alerts

or

bevy_ios_alerts = { version = "=0.1.3" }

3. Setup Plugin

Initialize Bevy Plugin:

app.add_plugins(bevy_ios_alerts::IosAlertsPlugin);

Trigger Alert in your application code:

fn system_triggerin_alerts(mut events: EventWriter<IosAlert>) {
     
    events.send(IosAlert::Message {
        title: String::from("title"),
        msg: String::from("msg"),
        button: String::from("ok"),
    });
     
    events.send(IosAlert::Dialog {
        title: String::from("title"),
        msg: String::from("this is a dialog with multiple buttons"),
        button_yes: String::from("absolutely yes"),
        button_no: String::from("no no no"),
    });
                    
    events.send(IosAlert::Input {
        title: String::from("title"),
        msg: String::from("input box"),
        button: String::from("ok"),
        placeholder: String::from("placeholder"),
    });
}

fn process_alert_response(mut events: EventReader<IosAlertResponse>) {
    for e in events.read() {
        info!("incoming alert response: {e:?}");
    }
}

License

All code in this repository is dual-licensed under either:

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.

Dependencies

~18–47MB
~735K SLoC