diff options
author | Martin Robinson <mrobinson@igalia.com> | 2015-10-09 17:08:35 -0700 |
---|---|---|
committer | Martin Robinson <mrobinson@igalia.com> | 2015-10-20 07:29:06 -0700 |
commit | ac5525aeeb3df60a99b503fa75f919c93c50b43b (patch) | |
tree | 99f867cb70aeb0c549ade092dbd6624efe879dcd /components/layout/fragment.rs | |
parent | 90dd3cdc095d7bf54435f0fcb8a6fe134b00fc24 (diff) | |
download | servo-ac5525aeeb3df60a99b503fa75f919c93c50b43b.tar.gz servo-ac5525aeeb3df60a99b503fa75f919c93c50b43b.zip |
Integrate iframes into the display list
Instead of always promoting iframes to StackingContexts, integrate them
into the display list. This prevents stacking bugs when
non-stacking-context elements should be drawn on top of iframes.
To accomplish this, we add another step to ordering layer creation,
where LayeredItems in the DisplayList are added to layers described by
the LayerInfo structures collected at the end of the DisplayList.
Unlayered items that follow these layered items are added to
synthesized layers.
Another result of this change is that iframe layers can be positioned
directly at the location of the iframe fragment, eliminating the need
for the SubpageLayerInfo struct entirely.
Iframes are the first type of content treated this way, but this change
opens up the possibility to properly order canvas and all other layered
content that does not create a stacking context.
Fixes #7566.
Fixes #7796.
Diffstat (limited to 'components/layout/fragment.rs')
-rw-r--r-- | components/layout/fragment.rs | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/components/layout/fragment.rs b/components/layout/fragment.rs index 469cb0b6654..c97ad052497 100644 --- a/components/layout/fragment.rs +++ b/components/layout/fragment.rs @@ -2102,11 +2102,11 @@ impl Fragment { } /// Returns true if this fragment unconditionally layerizes. - pub fn needs_layer(&self) -> bool { + pub fn needs_layered_stacking_context(&self) -> bool { // Canvas and iframes always layerize, as an special case // FIXME(pcwalton): Don't unconditionally form stacking contexts for each canvas. match self.specific { - SpecificFragmentInfo::Canvas(_) | SpecificFragmentInfo::Iframe(_) => true, + SpecificFragmentInfo::Canvas(_) => true, _ => false, } } @@ -2135,7 +2135,7 @@ impl Fragment { transform_style::T::auto => {} } - if self.needs_layer() { + if self.needs_layered_stacking_context() { return true } |