mirror of
https://github.com/rust-windowing/winit.git
synced 2026-06-26 22:53:15 -04:00
* Initial implementation * Corrected RAWINPUT buffer sizing * Mostly complete XInput implementation * XInput triggers * Add preliminary CHANGELOG entry. * match unix common API to evl 2.0 * wayland: eventloop2.0 * make EventLoopProxy require T: 'static * Revamp device event API, as well as several misc. fixes on Windows: * When you have multiple windows, you no longer receive duplicate device events * Mouse Device Events now send X-button input * Mouse Device Events now send horizontal scroll wheel input * Add MouseEvent documentation and Device ID debug passthrough * Improve type safety on get_raw_input_data * Remove button_id field from MouseEvent::Button in favor of utton * Remove regex dependency on Windows * Remove axis filtering in XInput * Make gamepads not use lazy_static * Publicly expose gamepad rumble * Unstack DeviceEvent and fix examples/tests * Add HANDLE retrieval method to DeviceExtWindows * Add distinction between non-joystick axes and joystick axes. This helps with properly calculating the deadzone for controller joysticks. One potential issue is that the `Stick` variant isn't used for *all* joysticks, which could be potentially confusing - for example, raw input joysticks will never use the `Stick` variant because we don't understand the semantic meaning of raw input joystick axes. * Add ability to get gamepad port * Fix xinput controller hot swapping * Add functions for enumerating attached devices * Clamp input to [0.0, 1.0] on gamepad rumble * Expose gamepad rumble errors * Add method to check if device is still connected * Add docs * Rename AxisHint and ButtonHint to GamepadAxis and GamepadButton * Add CHANGELOG entry * Update CHANGELOG.md * Add HidId and MovedAbsolute * Fix xinput deprecation warnings * Add ability to retrieve gamepad battery level * Fix weird imports in gamepad example * Update CHANGELOG.md * Resolve francesca64 comments
79 lines
3.4 KiB
Rust
79 lines
3.4 KiB
Rust
use winit::{
|
|
event::{Event, KeyboardInput, WindowEvent},
|
|
event_loop::{ControlFlow, EventLoop},
|
|
window::WindowBuilder,
|
|
};
|
|
|
|
fn main() {
|
|
let event_loop = EventLoop::new();
|
|
|
|
let _window = WindowBuilder::new()
|
|
.with_title("Your faithful window")
|
|
.build(&event_loop)
|
|
.unwrap();
|
|
|
|
let mut close_requested = false;
|
|
|
|
event_loop.run(move |event, _, control_flow| {
|
|
use winit::event::{
|
|
ElementState::Released,
|
|
VirtualKeyCode::{N, Y},
|
|
};
|
|
*control_flow = ControlFlow::Wait;
|
|
|
|
match event {
|
|
Event::WindowEvent { event, .. } => {
|
|
match event {
|
|
WindowEvent::CloseRequested => {
|
|
// `CloseRequested` is sent when the close button on the window is pressed (or
|
|
// through whatever other mechanisms the window manager provides for closing a
|
|
// window). If you don't handle this event, the close button won't actually do
|
|
// anything.
|
|
|
|
// A common thing to do here is prompt the user if they have unsaved work.
|
|
// Creating a proper dialog box for that is far beyond the scope of this
|
|
// example, so here we'll just respond to the Y and N keys.
|
|
println!("Are you ready to bid your window farewell? [Y/N]");
|
|
close_requested = true;
|
|
|
|
// In applications where you can safely close the window without further
|
|
// action from the user, this is generally where you'd handle cleanup before
|
|
// closing the window. How to close the window is detailed in the handler for
|
|
// the Y key.
|
|
}
|
|
WindowEvent::KeyboardInput(KeyboardInput {
|
|
virtual_keycode: Some(virtual_code),
|
|
state: Released,
|
|
..
|
|
}) => {
|
|
match virtual_code {
|
|
Y => {
|
|
if close_requested {
|
|
// This is where you'll want to do any cleanup you need.
|
|
println!("Buh-bye!");
|
|
|
|
// For a single-window application like this, you'd normally just
|
|
// break out of the event loop here. If you wanted to keep running the
|
|
// event loop (i.e. if it's a multi-window application), you need to
|
|
// drop the window. That closes it, and results in `Destroyed` being
|
|
// sent.
|
|
*control_flow = ControlFlow::Exit;
|
|
}
|
|
}
|
|
N => {
|
|
if close_requested {
|
|
println!("Your window will continue to stay by your side.");
|
|
close_requested = false;
|
|
}
|
|
}
|
|
_ => (),
|
|
}
|
|
}
|
|
_ => (),
|
|
}
|
|
}
|
|
_ => (),
|
|
}
|
|
});
|
|
}
|