mirror of
https://github.com/servo/servo.git
synced 2025-08-03 04:30:10 +01:00
script: Get the screen metrics from the WebViewDelegate
instead of via the compositor (#38020)
Similar to #37960, previously, `AvailHeight`, `AvailWidth`, `Height`, `Width` ask compositor for screen metrics. This PR moves the request to embedder. This simplifies code, and reduces workload of compositor, which is busier most of time. Testing: No behaviour change. Updated some tests. `Width/Height` matches other browsers. --------- Signed-off-by: Euclid Ye <yezhizhenjiakang@gmail.com>
This commit is contained in:
parent
d0a93a8b02
commit
d38ffb82b2
11 changed files with 79 additions and 102 deletions
|
@ -2,16 +2,13 @@
|
|||
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||
* file, You can obtain one at https://mozilla.org/MPL/2.0/. */
|
||||
|
||||
use compositing_traits::CompositorMsg;
|
||||
use dom_struct::dom_struct;
|
||||
use euclid::Size2D;
|
||||
use profile_traits::ipc;
|
||||
use servo_geometry::DeviceIndependentIntSize;
|
||||
use style_traits::CSSPixel;
|
||||
use embedder_traits::{EmbedderMsg, ScreenMetrics};
|
||||
use ipc_channel::ipc;
|
||||
|
||||
use crate::dom::bindings::codegen::Bindings::ScreenBinding::ScreenMethods;
|
||||
use crate::dom::bindings::num::Finite;
|
||||
use crate::dom::bindings::reflector::{DomGlobal, Reflector, reflect_dom_object};
|
||||
use crate::dom::bindings::reflector::{Reflector, reflect_dom_object};
|
||||
use crate::dom::bindings::root::{Dom, DomRoot};
|
||||
use crate::dom::window::Window;
|
||||
use crate::script_runtime::CanGc;
|
||||
|
@ -34,58 +31,38 @@ impl Screen {
|
|||
reflect_dom_object(Box::new(Screen::new_inherited(window)), window, can_gc)
|
||||
}
|
||||
|
||||
fn screen_size(&self) -> Size2D<u32, CSSPixel> {
|
||||
let (sender, receiver) =
|
||||
ipc::channel::<DeviceIndependentIntSize>(self.global().time_profiler_chan().clone())
|
||||
.unwrap();
|
||||
self.window
|
||||
.compositor_api()
|
||||
.sender()
|
||||
.send(CompositorMsg::GetScreenSize(
|
||||
self.window.webview_id(),
|
||||
sender,
|
||||
))
|
||||
.unwrap();
|
||||
let size = receiver.recv().unwrap_or(Size2D::zero()).to_u32();
|
||||
Size2D::new(size.width, size.height)
|
||||
}
|
||||
/// Retrives [`ScreenMetrics`] from the embedder.
|
||||
fn screen_metrics(&self) -> ScreenMetrics {
|
||||
let (sender, receiver) = ipc::channel().expect("Failed to create IPC channel!");
|
||||
|
||||
fn screen_avail_size(&self) -> Size2D<u32, CSSPixel> {
|
||||
let (sender, receiver) =
|
||||
ipc::channel::<DeviceIndependentIntSize>(self.global().time_profiler_chan().clone())
|
||||
.unwrap();
|
||||
self.window
|
||||
.compositor_api()
|
||||
.sender()
|
||||
.send(CompositorMsg::GetAvailableScreenSize(
|
||||
self.window.webview_id(),
|
||||
sender,
|
||||
))
|
||||
.unwrap();
|
||||
let size = receiver.recv().unwrap_or(Size2D::zero()).to_u32();
|
||||
Size2D::new(size.width, size.height)
|
||||
self.window.send_to_embedder(EmbedderMsg::GetScreenMetrics(
|
||||
self.window.webview_id(),
|
||||
sender,
|
||||
));
|
||||
|
||||
receiver.recv().unwrap_or_default()
|
||||
}
|
||||
}
|
||||
|
||||
impl ScreenMethods<crate::DomTypeHolder> for Screen {
|
||||
// https://drafts.csswg.org/cssom-view/#dom-screen-availwidth
|
||||
fn AvailWidth(&self) -> Finite<f64> {
|
||||
Finite::wrap(self.screen_avail_size().width as f64)
|
||||
Finite::wrap(self.screen_metrics().available_size.width as f64)
|
||||
}
|
||||
|
||||
// https://drafts.csswg.org/cssom-view/#dom-screen-availheight
|
||||
fn AvailHeight(&self) -> Finite<f64> {
|
||||
Finite::wrap(self.screen_avail_size().height as f64)
|
||||
Finite::wrap(self.screen_metrics().available_size.height as f64)
|
||||
}
|
||||
|
||||
// https://drafts.csswg.org/cssom-view/#dom-screen-width
|
||||
fn Width(&self) -> Finite<f64> {
|
||||
Finite::wrap(self.screen_size().width as f64)
|
||||
Finite::wrap(self.screen_metrics().screen_size.width as f64)
|
||||
}
|
||||
|
||||
// https://drafts.csswg.org/cssom-view/#dom-screen-height
|
||||
fn Height(&self) -> Finite<f64> {
|
||||
Finite::wrap(self.screen_size().height as f64)
|
||||
Finite::wrap(self.screen_metrics().screen_size.height as f64)
|
||||
}
|
||||
|
||||
// https://drafts.csswg.org/cssom-view/#dom-screen-colordepth
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue