Build p2p turn-based games with anonimity for both clients with help of Veilid.
Peek.2023-11-07.14-08.mp4
bevy version | veilid version | bevy_veilid version |
---|---|---|
0.11 | 0.2.4 | 0.1.0 |
0.11 | 0.2.5 | 0.1.2 |
0.12 | 0.3 | 0.2 |
0.13 | 0.3.2 | 0.3 |
0.14 | 0.3.3 | 0.4 |
- Event-Based: read and send event to communicate with other peer
- Turn-Based: no tick synchronization
- Anonymous: each run creates a new persona
Refer to examples/pingpong for basic example.
#[derive(Serialize, Deserialize, Debug, Clone, Default, Resource)]
struct SampleMessage {
pub counter: i32,
pub extra: String,
}
fn main() {
App::new()
.add_plugins(DefaultPlugins)
.add_plugins(VeilidPlugin::<SampleMessage>::default())
.add_systems(
Update,
(
on_ev_veilid_initialized,
handle_ui_state,
on_host_game,
on_join_game,
on_ev_awating_peer,
on_ev_error,
on_ev_veilid_message,
on_ev_connected_peer,
on_ev_change_counter,
),
)
.run();
}
EventConnectedPeer
EventError
EventAwaitingPeer
EventVeilidInitialized
EventReceiveMessage<SampleMessage>
EventSendMessage<SampleMessage>
EventMessageSent
bevy_veilid
will inject this into bevy
pub enum VeilidPluginStatus {
Initializing,
Initialized,
ConnectedPeer,
AwaitingPeer,
Error,
}
A full veilid instance will run in background with settings defined in veilid_duplex.
veilid_duplex
manages veilid internals and provides an API to send a message to another peer by refering each other with dht_keys unique for each run.