mirror of
https://github.com/italicsjenga/winit-sonoma-fix.git
synced 2025-01-24 02:46:33 +11:00
Implemented a few easy methods
This commit is contained in:
parent
fd4db4000c
commit
f44e98ddc9
1 changed files with 126 additions and 37 deletions
|
@ -4,9 +4,19 @@ use event_loop::{ControlFlow, EventLoopWindowTarget as RootELW, EventLoopClosed}
|
||||||
use icon::Icon;
|
use icon::Icon;
|
||||||
use monitor::{MonitorHandle as RootMH};
|
use monitor::{MonitorHandle as RootMH};
|
||||||
use window::{CreationError, MouseCursor, WindowAttributes};
|
use window::{CreationError, MouseCursor, WindowAttributes};
|
||||||
|
use stdweb::{
|
||||||
|
document,
|
||||||
|
web::html_element::CanvasElement
|
||||||
|
};
|
||||||
|
use std::cell::Cell;
|
||||||
|
use std::collections::VecDeque;
|
||||||
use std::collections::vec_deque::IntoIter as VecDequeIter;
|
use std::collections::vec_deque::IntoIter as VecDequeIter;
|
||||||
use std::marker::PhantomData;
|
use std::marker::PhantomData;
|
||||||
|
use std::rc::Rc;
|
||||||
|
|
||||||
|
// TODO: dpi
|
||||||
|
// TODO: pointer locking (stdweb PR required)
|
||||||
|
// TODO: should there be a maximization / fullscreen API?
|
||||||
|
|
||||||
#[derive(Debug, Copy, Clone, PartialEq, Eq, PartialOrd, Ord, Hash)]
|
#[derive(Debug, Copy, Clone, PartialEq, Eq, PartialOrd, Ord, Hash)]
|
||||||
pub struct DeviceId;
|
pub struct DeviceId;
|
||||||
|
@ -47,7 +57,10 @@ impl WindowId {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct Window;
|
pub struct Window {
|
||||||
|
canvas: CanvasElement,
|
||||||
|
monitors: VecDeque<MonitorHandle>
|
||||||
|
}
|
||||||
|
|
||||||
impl Window {
|
impl Window {
|
||||||
// TODO: type of window_target
|
// TODO: type of window_target
|
||||||
|
@ -56,61 +69,74 @@ impl Window {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn set_title(&self, title: &str) {
|
pub fn set_title(&self, title: &str) {
|
||||||
unimplemented!();
|
document().set_title(title);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn show(&self) {
|
pub fn show(&self) {
|
||||||
unimplemented!();
|
// Intentionally a no-op
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn hide(&self) {
|
pub fn hide(&self) {
|
||||||
unimplemented!();
|
// Intentionally a no-op
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn request_redraw(&self) {
|
pub fn request_redraw(&self) {
|
||||||
|
// TODO: what does this mean
|
||||||
unimplemented!();
|
unimplemented!();
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn get_position(&self) -> Option<LogicalPosition> {
|
pub fn get_position(&self) -> Option<LogicalPosition> {
|
||||||
unimplemented!();
|
let bounds = canvas.get_bouding_client_rect();
|
||||||
|
Some(LogicalPosition {
|
||||||
|
x: bounds.get_x(),
|
||||||
|
y: bounds.get_y(),
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn get_inner_position(&self) -> Option<LogicalPosition> {
|
pub fn get_inner_position(&self) -> Option<LogicalPosition> {
|
||||||
unimplemented!();
|
self.get_inner_position()
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn set_position(&self, position: LogicalPosition) {
|
pub fn set_position(&self, position: LogicalPosition) {
|
||||||
|
// TODO: use CSS?
|
||||||
unimplemented!();
|
unimplemented!();
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn get_inner_size(&self) -> Option<LogicalSize> {
|
pub fn get_inner_size(&self) -> Option<LogicalSize> {
|
||||||
unimplemented!();
|
Some(LogicalSize {
|
||||||
|
x: self.canvas.width() as f64
|
||||||
|
y: self.canvas.height() as f64
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn get_outer_size(&self) -> Option<LogicalSize> {
|
pub fn get_outer_size(&self) -> Option<LogicalSize> {
|
||||||
unimplemented!();
|
Some(LogicalSize {
|
||||||
|
x: self.canvas.width() as f64
|
||||||
|
y: self.canvas.height() as f64
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn set_inner_size(&self, size: LogicalSize) {
|
pub fn set_inner_size(&self, size: LogicalSize) {
|
||||||
unimplemented!();
|
self.canvas.set_width(size.x as u32);
|
||||||
|
self.canvas.set_height(size.y as u32);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn set_min_dimensions(&self, dimensions: Option<LogicalSize>) {
|
pub fn set_min_dimensions(&self, _dimensions: Option<LogicalSize>) {
|
||||||
unimplemented!();
|
// Intentionally a no-op: users can't resize canvas elements
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn set_max_dimensions(&self, dimensions: Option<LogicalSize>) {
|
pub fn set_max_dimensions(&self, _dimensions: Option<LogicalSize>) {
|
||||||
unimplemented!();
|
// Intentionally a no-op: users can't resize canvas elements
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn set_resizable(&self, resizable: bool) {
|
pub fn set_resizable(&self, _resizable: bool) {
|
||||||
unimplemented!();
|
// Intentionally a no-op: users can't resize canvas elements
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
|
@ -120,46 +146,92 @@ impl Window {
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn set_cursor(&self, cursor: MouseCursor) {
|
pub fn set_cursor(&self, cursor: MouseCursor) {
|
||||||
unimplemented!();
|
let text = match cursor {
|
||||||
|
MouseCursor::Default => "auto",
|
||||||
|
MouseCursor::Crosshair => "crosshair",
|
||||||
|
MouseCursor::Hand => "pointer",
|
||||||
|
MouseCursor::Arrow => "default",
|
||||||
|
MouseCursor::Move => "move",
|
||||||
|
MouseCursor::Text => "text",
|
||||||
|
MouseCursor::Wait => "wait",
|
||||||
|
MouseCursor::Help => "help",
|
||||||
|
MouseCursor::Progress => "progress",
|
||||||
|
|
||||||
|
MouseCursor::NotAllowed => "not-allowed",
|
||||||
|
MouseCursor::ContextMenu => "context-menu",
|
||||||
|
MouseCursor::Cell => "cell",
|
||||||
|
MouseCursor::VerticalText => "vertical-text",
|
||||||
|
MouseCursor::Alias => "alias",
|
||||||
|
MouseCursor::Copy => "copy",
|
||||||
|
MouseCursor::NoDrop => "no-drop",
|
||||||
|
MouseCursor::Grab => "grab",
|
||||||
|
MouseCursor::Grabbing => "grabbing",
|
||||||
|
MouseCursor::AllScroll => "all-scroll",
|
||||||
|
MouseCursor::ZoomIn => "zoom-in",
|
||||||
|
MouseCursor::ZoomOut => "zoom-out",
|
||||||
|
|
||||||
|
MouseCursor::EResize => "e-resize",
|
||||||
|
MouseCursor::NResize => "n-resize",
|
||||||
|
MouseCursor::NeResize => "ne-resize",
|
||||||
|
MouseCursor::NwResize => "nw-resize",
|
||||||
|
MouseCursor::SResize => "s-resize",
|
||||||
|
MouseCursor::SeResize => "se-resize",
|
||||||
|
MouseCursor::SwResize => "sw-resize",
|
||||||
|
MouseCursor::WResize => "w-resize",
|
||||||
|
MouseCursor::EwResize => "ew-resize",
|
||||||
|
MouseCursor::NsResize => "ns-resize",
|
||||||
|
MouseCursor::NeswResize => "nesw-resize",
|
||||||
|
MouseCursor::NwseResize => "nwse-resize",
|
||||||
|
MouseCursor::ColResize => "col-resize",
|
||||||
|
MouseCursor::RowResize => "row-resize",
|
||||||
|
};
|
||||||
|
self.canvas.set_attribute("cursor", text);
|
||||||
|
.expect("Setting the cursor on the canvas");
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn set_cursor_position(&self, position: LogicalPosition) -> Result<(), String> {
|
pub fn set_cursor_position(&self, position: LogicalPosition) -> Result<(), String> {
|
||||||
|
// TODO: pointer capture
|
||||||
unimplemented!();
|
unimplemented!();
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn grab_cursor(&self, grab: bool) -> Result<(), String> {
|
pub fn grab_cursor(&self, grab: bool) -> Result<(), String> {
|
||||||
|
// TODO: pointer capture
|
||||||
unimplemented!();
|
unimplemented!();
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn hide_cursor(&self, hide: bool) {
|
pub fn hide_cursor(&self, hide: bool) {
|
||||||
unimplemented!();
|
self.canvas.set_attribute("cursor", "none")
|
||||||
|
.expect("Setting the cursor on the canvas");
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn set_maximized(&self, maximized: bool) {
|
pub fn set_maximized(&self, maximized: bool) {
|
||||||
|
// TODO: should there be a maximization / fullscreen API?
|
||||||
unimplemented!();
|
unimplemented!();
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn set_fullscreen(&self, monitor: Option<RootMH>) {
|
pub fn set_fullscreen(&self, monitor: Option<RootMH>) {
|
||||||
|
// TODO: should there be a maximization / fullscreen API?
|
||||||
unimplemented!();
|
unimplemented!();
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn set_decorations(&self, decorations: bool) {
|
pub fn set_decorations(&self, _decorations: bool) {
|
||||||
unimplemented!();
|
// Intentionally a no-op, no canvas decorations
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn set_always_on_top(&self, always_on_top: bool) {
|
pub fn set_always_on_top(&self, _always_on_top: bool) {
|
||||||
unimplemented!();
|
// Intentionally a no-op, no window ordering
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn set_window_icon(&self, window_icon: Option<Icon>) {
|
pub fn set_window_icon(&self, window_icon: Option<Icon>) {
|
||||||
|
// TODO: should this set the favicon?
|
||||||
unimplemented!();
|
unimplemented!();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -170,27 +242,43 @@ impl Window {
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn get_current_monitor(&self) -> RootMH {
|
pub fn get_current_monitor(&self) -> RootMH {
|
||||||
unimplemented!();
|
RootMH {
|
||||||
|
inner: MonitorHandle
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn get_available_monitors(&self) -> VecDequeIter<MonitorHandle> {
|
pub fn get_available_monitors(&self) -> VecDequeIter<MonitorHandle> {
|
||||||
unimplemented!();
|
self.monitors.iter()
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn get_primary_monitor(&self) -> MonitorHandle {
|
pub fn get_primary_monitor(&self) -> MonitorHandle {
|
||||||
unimplemented!();
|
MonitorHandle
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn id(&self) -> WindowId {
|
pub fn id(&self) -> WindowId {
|
||||||
unimplemented!();
|
WindowId::dummy()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn new_rootelw<T>() -> RootELW<T> {
|
||||||
|
RootELW {
|
||||||
|
p: EventLoopWindowTarget,
|
||||||
|
_marker: PhantomData
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct EventLoop<T> {
|
pub struct EventLoop<T> {
|
||||||
_phantom: PhantomData<T>
|
window_target: RootELW<T>,
|
||||||
|
monitors: VecDeque<MonitorHandle>,
|
||||||
|
data: Rc<Cell<EventLoopData>>,
|
||||||
|
}
|
||||||
|
|
||||||
|
struct EventLoopData {
|
||||||
|
events: VecDeque<T>,
|
||||||
|
control: ControlFlow,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<T> EventLoop<T> {
|
impl<T> EventLoop<T> {
|
||||||
|
@ -199,40 +287,41 @@ impl<T> EventLoop<T> {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn get_available_monitors(&self) -> VecDequeIter<MonitorHandle> {
|
pub fn get_available_monitors(&self) -> VecDequeIter<MonitorHandle> {
|
||||||
unimplemented!();
|
self.monitors.iter()
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn get_primary_monitor(&self) -> MonitorHandle {
|
pub fn get_primary_monitor(&self) -> MonitorHandle {
|
||||||
unimplemented!();
|
MonitorHandle
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn run<F>(mut self, event_handler: F) -> !
|
pub fn run<F>(mut self, event_handler: F) -> !
|
||||||
where F: 'static + FnMut(Event<T>, &RootELW<T>, &mut ControlFlow)
|
where F: 'static + FnMut(Event<T>, &RootELW<T>, &mut ControlFlow)
|
||||||
{
|
{
|
||||||
|
// TODO: Create event handlers for the JS events
|
||||||
|
// TODO: how to handle request redraw?
|
||||||
unimplemented!();
|
unimplemented!();
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn create_proxy(&self) -> EventLoopProxy<T> {
|
pub fn create_proxy(&self) -> EventLoopProxy<T> {
|
||||||
unimplemented!();
|
EventLoopProxy {
|
||||||
|
events: self.window_target.p.events.clone()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn window_target(&self) -> &RootELW<T> {
|
pub fn window_target(&self) -> &RootELW<T> {
|
||||||
unimplemented!();
|
&self.window_target
|
||||||
/*&EventLoopWindowTarget {
|
|
||||||
p: self.event_loop.window_target(),
|
|
||||||
_marker: std::marker::PhantomData
|
|
||||||
}*/
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Copy, Clone, PartialEq, Eq, PartialOrd, Ord, Hash)]
|
#[derive(Debug, Copy, Clone, PartialEq, Eq, PartialOrd, Ord, Hash)]
|
||||||
pub struct EventLoopProxy<T> {
|
pub struct EventLoopProxy<T> {
|
||||||
_phantom: PhantomData<T>
|
data: EventLoopData
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<T> EventLoopProxy<T> {
|
impl<T> EventLoopProxy<T> {
|
||||||
pub fn send_event(&self, event: T) -> Result<(), EventLoopClosed> {
|
pub fn send_event(&self, event: T) -> Result<(), EventLoopClosed> {
|
||||||
unimplemented!();
|
self.data.borrow_mut().events.push_back(Event::UserEvent(event));
|
||||||
|
Ok(())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue