123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657 |
- use std::rc::Rc;
- use dioxus::{html::geometry::euclid::Rect, prelude::*};
- fn main() {
- dioxus_desktop::launch_cfg(
- app,
- dioxus_desktop::Config::default().with_custom_head(
- r#"
- <style type="text/css">
- html, body {
- height: 100%;
- width: 100%;
- margin: 0;
- }
- #main {
- height: 100%;
- width: 100%;
- }
- </style>
- "#
- .to_owned(),
- ),
- );
- }
- fn app(cx: Scope) -> Element {
- let div_element: &UseRef<Option<Rc<MountedData>>> = use_ref(cx, || None);
- let dimentions = use_ref(cx, || Rect::zero());
- cx.render(rsx!(
- div {
- width: "50%",
- height: "50%",
- background_color: "red",
- onmounted: move |cx| {
- div_element.set(Some(cx.inner().clone()));
- },
- "This element is {dimentions.read():?}"
- }
- button {
- onclick: move |_| {
- to_owned![div_element, dimentions];
- async move {
- if let Some(div) = div_element.read().as_ref() {
- if let Ok(rect)=div.get_client_rect().await{
- dimentions.set(rect);
- }
- }
- }
- },
- "Read dimentions"
- }
- ))
- }
|