Update tui_keys example and web_sys to use new accessor methods

This commit is contained in:
Reinis Mazeiks 2022-05-07 18:28:15 +03:00
parent b7447503ea
commit 5bddafb943
2 changed files with 37 additions and 22 deletions

View file

@ -1,5 +1,7 @@
use dioxus::events::WheelEvent; use dioxus::events::WheelEvent;
use dioxus::prelude::*; use dioxus::prelude::*;
use dioxus_html::geometry::ScreenPoint;
use dioxus_html::input::MouseButtonSet;
use dioxus_html::on::{KeyboardEvent, MouseEvent}; use dioxus_html::on::{KeyboardEvent, MouseEvent};
use dioxus_html::KeyCode; use dioxus_html::KeyCode;
@ -9,9 +11,9 @@ fn main() {
fn app(cx: Scope) -> Element { fn app(cx: Scope) -> Element {
let key = use_state(&cx, || "".to_string()); let key = use_state(&cx, || "".to_string());
let mouse = use_state(&cx, || (0, 0)); let mouse = use_state(&cx, || ScreenPoint::zero());
let count = use_state(&cx, || 0); let count = use_state(&cx, || 0);
let buttons = use_state(&cx, || 0); let buttons = use_state(&cx, || MouseButtonSet::empty());
let mouse_clicked = use_state(&cx, || false); let mouse_clicked = use_state(&cx, || false);
cx.render(rsx! { cx.render(rsx! {
@ -36,21 +38,21 @@ fn app(cx: Scope) -> Element {
count.set(count + evt.data.delta_y as i64); count.set(count + evt.data.delta_y as i64);
}, },
ondrag: move |evt: MouseEvent| { ondrag: move |evt: MouseEvent| {
mouse.set((evt.data.screen_x, evt.data.screen_y)); mouse.set(evt.data.screen_coordinates());
}, },
onmousedown: move |evt: MouseEvent| { onmousedown: move |evt: MouseEvent| {
mouse.set((evt.data.screen_x, evt.data.screen_y)); mouse.set(evt.data.screen_coordinates());
buttons.set(evt.data.buttons); buttons.set(evt.data.held_buttons());
mouse_clicked.set(true); mouse_clicked.set(true);
}, },
onmouseup: move |evt: MouseEvent| { onmouseup: move |evt: MouseEvent| {
buttons.set(evt.data.buttons); buttons.set(evt.data.held_buttons());
mouse_clicked.set(false); mouse_clicked.set(false);
}, },
"count: {count:?}", "count: {count:?}",
"key: {key}", "key: {key}",
"mouse buttons: {buttons:b}", "mouse buttons: {buttons:?}",
"mouse pos: {mouse:?}", "mouse pos: {mouse:?}",
"mouse button pressed: {mouse_clicked}" "mouse button pressed: {mouse_clicked}"
} }

View file

@ -1,8 +1,11 @@
use crate::geometry::{ClientPoint, Coordinates, ElementPoint, PagePoint, ScreenPoint};
use crate::input::{decode_mouse_button_set, MouseButton};
use crate::on::{ use crate::on::{
AnimationData, CompositionData, KeyboardData, MouseData, PointerData, TouchData, AnimationData, CompositionData, KeyboardData, MouseData, PointerData, TouchData,
TransitionData, WheelData, TransitionData, WheelData,
}; };
use crate::KeyCode; use crate::KeyCode;
use keyboard_types::Modifiers;
use wasm_bindgen::JsCast; use wasm_bindgen::JsCast;
use web_sys::{ use web_sys::{
AnimationEvent, CompositionEvent, Event, KeyboardEvent, MouseEvent, PointerEvent, TouchEvent, AnimationEvent, CompositionEvent, Event, KeyboardEvent, MouseEvent, PointerEvent, TouchEvent,
@ -71,22 +74,32 @@ impl From<&KeyboardEvent> for KeyboardData {
impl From<&MouseEvent> for MouseData { impl From<&MouseEvent> for MouseData {
fn from(e: &MouseEvent) -> Self { fn from(e: &MouseEvent) -> Self {
Self { let mut modifiers = Modifiers::empty();
alt_key: e.alt_key(),
button: e.button(), if e.alt_key() {
buttons: e.buttons(), modifiers.insert(Modifiers::ALT);
client_x: e.client_x(),
client_y: e.client_y(),
ctrl_key: e.ctrl_key(),
meta_key: e.meta_key(),
offset_x: e.offset_x(),
offset_y: e.offset_y(),
screen_x: e.screen_x(),
screen_y: e.screen_y(),
shift_key: e.shift_key(),
page_x: e.page_x(),
page_y: e.page_y(),
} }
if e.ctrl_key() {
modifiers.insert(Modifiers::CONTROL);
}
if e.meta_key() {
modifiers.insert(Modifiers::META);
}
if e.shift_key() {
modifiers.insert(Modifiers::SHIFT);
}
MouseData::new(
Coordinates::new(
ScreenPoint::new(e.screen_x().into(), e.screen_y().into()),
ClientPoint::new(e.client_x().into(), e.client_y().into()),
ElementPoint::new(e.offset_x().into(), e.offset_y().into()),
PagePoint::new(e.page_x().into(), e.page_y().into()),
),
Some(MouseButton::from_web_code(e.button().into())),
decode_mouse_button_set(e.buttons()),
modifiers,
)
} }
} }