mirror of
https://github.com/griffi-gh/kubi.git
synced 2024-12-25 21:28:20 -06:00
stuff
This commit is contained in:
parent
caa7cf9aeb
commit
fb0ff88c10
|
@ -1,14 +1,18 @@
|
||||||
|
use kubi_shared::networking::client::ClientId;
|
||||||
use shipyard::{AllStoragesView, Unique, UniqueViewMut};
|
use shipyard::{AllStoragesView, Unique, UniqueViewMut};
|
||||||
|
|
||||||
pub enum ChatMessage {
|
pub enum ChatMessage {
|
||||||
PlayerMessage {
|
PlayerMessage {
|
||||||
|
id: ClientId,
|
||||||
username: String,
|
username: String,
|
||||||
message: String,
|
message: String,
|
||||||
},
|
},
|
||||||
PlayerJoin {
|
PlayerJoin {
|
||||||
|
id: ClientId,
|
||||||
username: String,
|
username: String,
|
||||||
},
|
},
|
||||||
PlayerLeave {
|
PlayerLeave {
|
||||||
|
id: ClientId,
|
||||||
username: String,
|
username: String,
|
||||||
},
|
},
|
||||||
System(String),
|
System(String),
|
||||||
|
@ -24,16 +28,16 @@ impl ChatManager {
|
||||||
self.messages.push(message);
|
self.messages.push(message);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn add_chat_message(&mut self, username: String, message: String,) {
|
pub fn add_chat_message(&mut self, id: ClientId, username: String, message: String,) {
|
||||||
self.messages.push(ChatMessage::PlayerMessage { username, message });
|
self.messages.push(ChatMessage::PlayerMessage { id, username, message });
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn add_player_join(&mut self, username: String) {
|
pub fn add_player_join(&mut self, id: ClientId, username: String) {
|
||||||
self.messages.push(ChatMessage::PlayerJoin { username });
|
self.messages.push(ChatMessage::PlayerJoin { id, username });
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn add_player_leave(&mut self, username: String) {
|
pub fn add_player_leave(&mut self, id: ClientId, username: String) {
|
||||||
self.messages.push(ChatMessage::PlayerLeave { username });
|
self.messages.push(ChatMessage::PlayerLeave { id, username });
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn add_system_message(&mut self, message: String) {
|
pub fn add_system_message(&mut self, message: String) {
|
||||||
|
|
|
@ -1,6 +1,10 @@
|
||||||
use shipyard::{AllStoragesView, Unique, NonSendSync, UniqueView, UniqueViewMut};
|
use shipyard::{AllStoragesView, IntoIter, NonSendSync, Unique, UniqueView, UniqueViewMut, View};
|
||||||
use crate::rendering::Renderer;
|
use crate::{events::InputDeviceEvent, rendering::Renderer};
|
||||||
use winit::window::CursorGrabMode;
|
use winit::{
|
||||||
|
event::{DeviceEvent, ElementState, RawKeyEvent},
|
||||||
|
keyboard::{KeyCode, PhysicalKey},
|
||||||
|
window::CursorGrabMode
|
||||||
|
};
|
||||||
|
|
||||||
#[derive(Unique)]
|
#[derive(Unique)]
|
||||||
pub struct CursorLock(pub bool);
|
pub struct CursorLock(pub bool);
|
||||||
|
@ -34,3 +38,18 @@ pub fn lock_cursor_now(
|
||||||
) {
|
) {
|
||||||
lock.0 = true
|
lock.0 = true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// XXX: this is a huge hack
|
||||||
|
pub fn debug_toggle_lock(
|
||||||
|
mut lock: UniqueViewMut<CursorLock>,
|
||||||
|
device_events: View<InputDeviceEvent>,
|
||||||
|
) {
|
||||||
|
for evt in device_events.iter() {
|
||||||
|
if let DeviceEvent::Key(RawKeyEvent {
|
||||||
|
physical_key: PhysicalKey::Code(KeyCode::F3),
|
||||||
|
state: ElementState::Pressed,
|
||||||
|
}) = evt.event {
|
||||||
|
lock.0 = !lock.0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -78,7 +78,7 @@ use rendering::{
|
||||||
};
|
};
|
||||||
use block_placement::update_block_placement;
|
use block_placement::update_block_placement;
|
||||||
use delta_time::{DeltaTime, init_delta_time};
|
use delta_time::{DeltaTime, init_delta_time};
|
||||||
use cursor_lock::{insert_lock_state, update_cursor_lock_state, lock_cursor_now};
|
use cursor_lock::{debug_toggle_lock, insert_lock_state, lock_cursor_now, update_cursor_lock_state};
|
||||||
use control_flow::{exit_on_esc, insert_control_flow_unique, RequestExit};
|
use control_flow::{exit_on_esc, insert_control_flow_unique, RequestExit};
|
||||||
use state::{is_ingame, is_ingame_or_loading, is_loading, init_state, update_state, is_connecting};
|
use state::{is_ingame, is_ingame_or_loading, is_loading, init_state, update_state, is_connecting};
|
||||||
use networking::{update_networking, update_networking_late, is_multiplayer, disconnect_on_exit, is_singleplayer};
|
use networking::{update_networking, update_networking_late, is_multiplayer, disconnect_on_exit, is_singleplayer};
|
||||||
|
@ -121,6 +121,7 @@ fn startup() -> Workload {
|
||||||
|
|
||||||
fn update() -> Workload {
|
fn update() -> Workload {
|
||||||
(
|
(
|
||||||
|
debug_toggle_lock,
|
||||||
update_window_size,
|
update_window_size,
|
||||||
update_cursor_lock_state,
|
update_cursor_lock_state,
|
||||||
process_inputs,
|
process_inputs,
|
||||||
|
|
|
@ -4,12 +4,13 @@ use uflow::{SendMode, client::Event as ClientEvent};
|
||||||
use kubi_shared::{
|
use kubi_shared::{
|
||||||
transform::Transform,
|
transform::Transform,
|
||||||
networking::{
|
networking::{
|
||||||
messages::{ClientToServerMessage, ServerToClientMessage, ServerToClientMessageType},
|
|
||||||
channels::Channel,
|
channels::Channel,
|
||||||
client::ClientIdMap,
|
client::{ClientIdMap, Username},
|
||||||
|
messages::{ClientToServerMessage, ServerToClientMessage, ServerToClientMessageType},
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
use crate::{
|
use crate::{
|
||||||
|
chat::ChatManager,
|
||||||
events::player_actions::PlayerActionEvent,
|
events::player_actions::PlayerActionEvent,
|
||||||
player::spawn_remote_player_multiplayer,
|
player::spawn_remote_player_multiplayer,
|
||||||
};
|
};
|
||||||
|
@ -96,6 +97,9 @@ pub fn receive_player_connect_events(
|
||||||
for message in messages {
|
for message in messages {
|
||||||
let ServerToClientMessage::PlayerConnected { init } = message else { unreachable!() };
|
let ServerToClientMessage::PlayerConnected { init } = message else { unreachable!() };
|
||||||
log::info!("player connected: {} (id {})", init.username, init.client_id);
|
log::info!("player connected: {} (id {})", init.username, init.client_id);
|
||||||
|
let mut chat = storages.borrow::<UniqueViewMut<ChatManager>>().unwrap();
|
||||||
|
chat.add_player_join(init.client_id, init.username.clone());
|
||||||
|
drop(chat);
|
||||||
spawn_remote_player_multiplayer(&mut storages, init);
|
spawn_remote_player_multiplayer(&mut storages, init);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -120,12 +124,21 @@ pub fn receive_player_disconnect_events(
|
||||||
for message in messages {
|
for message in messages {
|
||||||
let ServerToClientMessage::PlayerDisconnected { id } = message else { unreachable!() };
|
let ServerToClientMessage::PlayerDisconnected { id } = message else { unreachable!() };
|
||||||
log::info!("player disconnected: {}", id);
|
log::info!("player disconnected: {}", id);
|
||||||
|
|
||||||
let mut id_map = storages.borrow::<UniqueViewMut<ClientIdMap>>().unwrap();
|
let mut id_map = storages.borrow::<UniqueViewMut<ClientIdMap>>().unwrap();
|
||||||
let Some(ent_id) = id_map.0.remove(&id) else {
|
let Some(ent_id) = id_map.0.remove(&id) else {
|
||||||
log::warn!("Disconnected player entity not found in client-id map");
|
log::warn!("Disconnected player entity not found in client-id map");
|
||||||
continue
|
continue
|
||||||
};
|
};
|
||||||
|
|
||||||
|
let username = storages.get::<&Username>(ent_id).unwrap();
|
||||||
|
let mut chat = storages.borrow::<UniqueViewMut<ChatManager>>().unwrap();
|
||||||
|
chat.add_player_leave(id, username.0.to_string());
|
||||||
|
|
||||||
|
drop(chat);
|
||||||
drop(id_map);
|
drop(id_map);
|
||||||
|
drop(username);
|
||||||
|
|
||||||
if !storages.delete_entity(ent_id) {
|
if !storages.delete_entity(ent_id) {
|
||||||
log::warn!("Disconnected player entity not found in storage");
|
log::warn!("Disconnected player entity not found in storage");
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
use hui::{element::{container::Container, text::Text, UiElementExt}, layout::Alignment, size};
|
use hui::{color, element::{container::Container, text::Text, UiElementExt}, layout::Alignment, size};
|
||||||
use shipyard::{NonSendSync, UniqueView, UniqueViewMut};
|
use shipyard::{NonSendSync, UniqueView, UniqueViewMut};
|
||||||
use crate::{chat::{ChatManager, ChatMessage}, hui_integration::UiState, rendering::WindowSize};
|
use crate::{chat::{ChatManager, ChatMessage}, hui_integration::UiState, rendering::WindowSize};
|
||||||
|
|
||||||
|
@ -14,23 +14,26 @@ pub fn render_chat(
|
||||||
.with_align((Alignment::Begin, Alignment::End))
|
.with_align((Alignment::Begin, Alignment::End))
|
||||||
.with_children(|ui| {
|
.with_children(|ui| {
|
||||||
for message in messages.iter().rev().take(10).rev() {
|
for message in messages.iter().rev().take(10).rev() {
|
||||||
let text = match message {
|
let (text, color) = match message {
|
||||||
ChatMessage::PlayerMessage { username, message } => {
|
ChatMessage::PlayerMessage { username, id, message } => {
|
||||||
format!("{}: {}", username, message)
|
(format!("{username} ({id}): {message}"), color::CYAN)
|
||||||
}
|
}
|
||||||
ChatMessage::PlayerJoin { username } => {
|
ChatMessage::PlayerJoin { username, id } => {
|
||||||
format!("{} joined the game", username)
|
(format!("{username} ({id}) joined the game"), color::YELLOW)
|
||||||
}
|
}
|
||||||
ChatMessage::PlayerLeave { username } => {
|
ChatMessage::PlayerLeave { username, id } => {
|
||||||
format!("{} left the game", username)
|
(format!("{username} ({id}) left the game"), color::YELLOW)
|
||||||
|
}
|
||||||
|
ChatMessage::System(message) => {
|
||||||
|
(message.clone(), color::WHITE)
|
||||||
}
|
}
|
||||||
ChatMessage::System(message) => message.clone(),
|
|
||||||
};
|
};
|
||||||
Container::default()
|
Container::default()
|
||||||
.with_background((0., 0., 0., 0.5))
|
.with_background((0., 0., 0., 0.5))
|
||||||
.with_padding((5., 2.))
|
.with_padding((5., 2.))
|
||||||
.with_children(|ui| {
|
.with_children(|ui| {
|
||||||
Text::new(text)
|
Text::new(text)
|
||||||
|
.with_color(color)
|
||||||
.add_child(ui)
|
.add_child(ui)
|
||||||
})
|
})
|
||||||
.add_child(ui);
|
.add_child(ui);
|
||||||
|
|
Loading…
Reference in a new issue