No description
Find a file
Ian Douglas Scott 2ede84ab2f
wayland: handle axis_value120 scroll events
This can be tested with the `application` example, looking at the events
shown for mouse wheel movement.

`wl_pointer::axis_discrete` isn't sent in version 8 or higher of
`wl_pointer`. And `sctk` doesn't convert the `value120` events, so
on compositors advertising version 8, only pixel scroll events were
being sent.

This sends `MouseScrollDelta::LineDelta` with a fractional value,
without doing any accumulation. Given `LineDelta` contains `f32` values,
this presumably is expected?

Though it might be good to change the definition of `MouseScrollDelta`
to include both discrete and pixel values, when the compositor sends
both. I'm not familiar with how this works on non-Wayland backends
though.
2025-10-08 11:53:57 +09:00
.cargo Use Taplo for TOML formatting 2024-07-28 17:38:44 +02:00
.github chore: bump ci deps versions 2025-08-23 21:19:46 +09:00
dpi chore: fix nightly clippy 2025-10-07 17:56:05 +09:00
winit wayland: handle axis_value120 scroll events 2025-10-08 11:53:57 +09:00
winit-android Bump version on master 2025-07-27 22:13:06 +09:00
winit-appkit chore: update to objc2 frameworks v0.3.2 2025-10-07 17:56:05 +09:00
winit-common linux: align scancode conversions with Chromium 2025-09-05 10:17:34 +09:00
winit-core winit-core:winit: add tablet input support 2025-10-07 21:42:36 +09:00
winit-orbital Add borderless fullscreen mode for orbital (#4343) 2025-09-04 22:14:41 +02:00
winit-uikit winit-core:winit: add tablet input support 2025-10-07 21:42:36 +09:00
winit-wayland wayland: handle axis_value120 scroll events 2025-10-08 11:53:57 +09:00
winit-web winit-core:winit: add tablet input support 2025-10-07 21:42:36 +09:00
winit-win32 winit-core:winit: add tablet input support 2025-10-07 21:42:36 +09:00
winit-x11 winit-core:winit: add tablet input support 2025-10-07 21:42:36 +09:00
.git-blame-ignore-revs Add to .git-blame-ignore-revs file 2024-07-28 17:39:04 +02:00
.gitattributes Update changelog guidelines to prevent conflicts from blocking PRs (#2145) 2022-01-23 13:55:33 +01:00
.gitignore Move to TypeScript (#3830) 2024-07-27 18:26:52 +02:00
Cargo.toml chore: update to objc2 frameworks v0.3.2 2025-10-07 17:56:05 +09:00
CHANGELOG.md Move winit itself to crate 2025-06-07 13:07:12 +09:00
clippy.toml winit-core:winit: add tablet input support 2025-10-07 21:42:36 +09:00
CODE_OF_CONDUCT.md docs: add a code of conduct 2024-03-07 17:32:06 +04:00
CONTRIBUTING.md chore: make git checkout build on Windows with symlinks disabled 2025-06-10 07:37:36 +09:00
deny.toml ci/deny: add rustix 2025-05-26 14:56:00 +09:00
examples winit-core/ime: add more purposes and content hints 2025-09-06 13:27:55 +09:00
FEATURES.md Remove feature description in FEATURES.md (#3479) 2024-12-03 21:24:57 +01:00
HALL_OF_CHAMPIONS.md Changes and improvements to the documentation (#3253) 2023-12-03 18:39:08 +01:00
LICENSE Initial commit 2014-07-27 11:41:26 +02:00
README.md Bump version on master 2025-07-27 22:13:06 +09:00
rustfmt.toml Use Taplo for TOML formatting 2024-07-28 17:38:44 +02:00
taplo.toml Use Taplo for TOML formatting 2024-07-28 17:38:44 +02:00
typos.toml Add safe area and document coordinate systems (#3890) 2024-11-21 17:37:03 +01:00

winit - Cross-platform window creation and management in Rust

Crates.io Docs.rs UNSTABLE docs CI Status

[dependencies]
winit = "0.30.12"

Documentation

For features within the scope of winit, see FEATURES.md.

For features outside the scope of winit, see Are we GUI Yet? and Are we game yet?, depending on what kind of project you're looking to do.

Contact Us

Join us in our Matrix room.

The maintainers have a meeting every friday at UTC 15. The meeting notes can be found here.

Usage

Winit is a window creation and management library. It can create windows and lets you handle events (for example: the window being resized, a key being pressed, a mouse movement, etc.) produced by the window.

Winit is designed to be a low-level brick in a hierarchy of libraries. Consequently, in order to show something on the window you need to use the platform-specific getters provided by winit, or another library.

CONTRIBUTING

For contributing guidelines see CONTRIBUTING.md.

MSRV Policy

This crate's Minimum Supported Rust Version (MSRV) is 1.80. Changes to the MSRV will be accompanied by a minor version bump.

As a tentative policy, the upper bound of the MSRV is given by the following formula:

min(sid, stable - 3)

Where sid is the current version of rustc provided by Debian Sid, and stable is the latest stable version of Rust. This bound may be broken in case of a major ecosystem shift or a security vulnerability.

An exception is made for the Android platform, where a higher Rust version must be used for certain Android features. In this case, the MSRV will be capped at the latest stable version of Rust minus three. This inconsistency is not reflected in Cargo metadata, as it is not powerful enough to expose this restriction.

Redox OS is also not covered by this MSRV policy, as it requires a Rust nightly toolchain to compile.

All crates in the rust-windowing organizations have the same MSRV policy.

Platform-specific usage

Check out the winit::platform module for platform-specific usage.

Repository License

Note that the license in LICENSE doesn't apply in full to the DPI package ./dpi. Full details can be found in that folder's README.