window_event.rs 3.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. use dioxus::prelude::*;
  2. use dioxus_desktop::{window, Config, WindowBuilder};
  3. fn main() {
  4. LaunchBuilder::new(app)
  5. .cfg(
  6. Config::new().with_window(
  7. WindowBuilder::new()
  8. .with_title("Borderless Window")
  9. .with_decorations(false),
  10. ),
  11. )
  12. .launch_desktop()
  13. }
  14. fn app() -> Element {
  15. let mut fullscreen = use_signal(|| false);
  16. let mut always_on_top = use_signal(|| false);
  17. let mut decorations = use_signal(|| false);
  18. rsx!(
  19. link {
  20. href: "https://unpkg.com/tailwindcss@^2/dist/tailwind.min.css",
  21. rel: "stylesheet"
  22. }
  23. header {
  24. class: "text-gray-400 bg-gray-900 body-font",
  25. onmousedown: move |_| window().drag(),
  26. div { class: "container mx-auto flex flex-wrap p-5 flex-col md:flex-row items-center",
  27. a { class: "flex title-font font-medium items-center text-white mb-4 md:mb-0",
  28. span { class: "ml-3 text-xl", "Dioxus" }
  29. }
  30. nav { class: "md:ml-auto flex flex-wrap items-center text-base justify-center" }
  31. button {
  32. class: "inline-flex items-center bg-gray-800 border-0 py-1 px-3 focus:outline-none hover:bg-gray-700 rounded text-base mt-4 md:mt-0",
  33. onmousedown: |evt| evt.stop_propagation(),
  34. onclick: move |_| window().set_minimized(true),
  35. "Minimize"
  36. }
  37. button {
  38. class: "inline-flex items-center bg-gray-800 border-0 py-1 px-3 focus:outline-none hover:bg-gray-700 rounded text-base mt-4 md:mt-0",
  39. onmousedown: |evt| evt.stop_propagation(),
  40. onclick: move |_| {
  41. window().set_fullscreen(!fullscreen());
  42. window().set_resizable(fullscreen());
  43. fullscreen.toggle();
  44. },
  45. "Fullscreen"
  46. }
  47. button {
  48. class: "inline-flex items-center bg-gray-800 border-0 py-1 px-3 focus:outline-none hover:bg-gray-700 rounded text-base mt-4 md:mt-0",
  49. onmousedown: |evt| evt.stop_propagation(),
  50. onclick: move |_| window().close(),
  51. "Close"
  52. }
  53. }
  54. }
  55. br {}
  56. div { class: "container mx-auto",
  57. div { class: "grid grid-cols-5",
  58. div {
  59. button {
  60. class: "inline-flex items-center text-white bg-green-500 border-0 py-1 px-3 hover:bg-green-700 rounded",
  61. onmousedown: |evt| evt.stop_propagation(),
  62. onclick: move |_| {
  63. window().set_always_on_top(!always_on_top());
  64. always_on_top.toggle();
  65. },
  66. "Always On Top"
  67. }
  68. }
  69. div {
  70. button {
  71. class: "inline-flex items-center text-white bg-blue-500 border-0 py-1 px-3 hover:bg-green-700 rounded",
  72. onmousedown: |evt| evt.stop_propagation(),
  73. onclick: move |_| {
  74. window().set_decorations(!decorations());
  75. decorations.toggle();
  76. },
  77. "Set Decorations"
  78. }
  79. }
  80. div {
  81. button {
  82. class: "inline-flex items-center text-white bg-blue-500 border-0 py-1 px-3 hover:bg-green-700 rounded",
  83. onmousedown: |evt| evt.stop_propagation(),
  84. onclick: move |_| window().set_title("Dioxus Application"),
  85. "Change Title"
  86. }
  87. }
  88. }
  89. }
  90. )
  91. }