mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:18:48 +00:00
a7ea204c19
- fix restore button on MacOS 10.6 fullscreen (08151078bd)
- Bug 1216580 - Make background-position:fixed clip stealing work with display items that create their own layer. r=mattwoodrow (7760c8ddd8)
- Bug 1222661 - Replace ToUntyped(obj) calls with obj.ToUnknown*(). r=nical (76e36824f0)
- Bug 1223310 (part 1) - Pass a LayoutDeviceIntPoint instead of an nsIntPoint to InitEvent(). r=kats. (ea95207afe)
- Bug 1223310 (part 2) - Use LayoutDeviceIntRect for bounds-related functions in nsIWidget. r=kats. (4993cccff8)
- Bug 1218552 - Fix GTK drag-and-drop coordinate scaling on HiDPI displays (r=karlt) (d03cf04136)
- fix preprocessing (2f4c1a1c94)
- Bug 1205923: Make VectorImage::GetWidth/GetHeight set outparam to 0 (not -1) on failure, to accomodate callers that don't check error codes. r=seth (487de31340)
- Bug 1212954 - Make BaseSize::IsEmpty return true for negative sizes to avoid NS_ERROR in VectorImage::GetFrameAtSize when root svg doesn't have intrinsic width or height. r=roc (402b154f56)
- fix ordering (ac8483c966)
- Bug 1216056 - Always sent OpRemoveTextureAsync as pending async Messages r=nica (66c9ee8708)
- Bug 121976 - Add a destruction handshake to PCompositable so as to avoid races between messages and the protocol. r=sotaro (636a669e44)
- Bug 1209724 - Cancel ImageBridge proxy functions if they are called too late. r=sotao (5bf81453ef)
- Bug 1221371 - Switch chromium IPC code to use mozilla::Tuple (r=jld,cpearce,kats) (eebcd419e9)
- Bug 1221371 - Remove unused Chromium callback code (r=jld) (3f2e882485)
- Bug 1221368 - Change MakeTuple to decay the types of its arguments (r=froydnj) (bed635f565)
- Bug 1181303. Set composition time earlier so that computing invalid regions works properly. r=mattwoodrow (7a3e41cd96)
- Bug 1150552 - Fix partial present bug with FPS counter. r=mattwoodrow (6e6ae92909)
- Bug 1216287 - Properly invalidate the debug overlay. r=mattwoodrow (60d4f3451a)
- Compute the compositor's damage region before composites, rather than layers updates. (bug 1217560, r=mattwoodrow) (6efcac085b)
- Bug 1216248 - Recomposite when the window overlay changes. r=mattwoodrow (8a8c5ccd07)
- Bug 1224021 - Support fractional async scroll offsets in the reftest harness. r=tn (353f75d3aa)
- Bug 1121072 - Always notify when layers cleared (r=dvander) (aa6ffc67e2)
- Bug 1224403 (part 1) - Make Configuration::mBounds a LayoutDeviceIntRect. r=kats. (7617b9da7e)
- Bug 1224403 (part 2) - Split GetClientOffset() into typed and untyped versions. r=kats. (06916479b1)
- Bug 1224403 (part 3) - Make mNonClientOffset a LayoutDeviceIntMargin. r=kats. (76efba1fb6)
- Bug 1224403 (part 4) - Make {Get,Set}NonClientMargins() return/take aLayoutDeviceIntMargin. r=kats. (99cfc2fdbc)
- Bug 1224403 (part 5) - Make OnDefaultButtonLoaded() return/take a LayoutDeviceIntMargin. r=kats (c402452f97)
- Bug 1224403 (part 6) - Remove one WidgetToScreenOffsetUntyped() call. r=kats. (8e4485a404)
- Bug 1224403 (part 7) - Use LayoutDeviceIntMargin more in IMMHandler. r=kats. (6b5e9124fc)
- Bug 1224403 (part 8) - Use LayoutDeviceIntMargin more in HyperTextAccessible. r=kats. (5bc1a04cc7)
- Bug 1224403 (part 9) - Remove GetRestoredBoundsUntyped(). r=kats. (20e2b28335)
- Bug 1224403 (part 10) - Make nsScreenGonk::GetNaturalBoundsUntyped() typed. r=kats. (9d19986f22)
- Bug 1224403 (part 11) - Remove a GetBoundsUntyped() call. r=kats. (58ce962157)
- Bug 1214267 - Followup to fix missing propagation of 'fixedPositionSides' to the compositor, and add it to the layers dump. r=mattwoodrow (7dc122eb62)
- Use compositor clip rects, not client clip rects, when computing the compositor's backbuffer damage region. (bug 1189159, r=mattwoodrow) (b70d71b1b7)
- Bug 1210784 - Layer tree invalidation with Preserves3D. r=roc (8a7bfa1a22)
- Bug 1166165 - Check if the timestamp is null to prevent assertion. r=nical (189a8d42d0)
- Bug 1137004 - Changed the location of the counter so when it is used in a maximized window it is no longer cut off, and added a little left padding. r=mattwoodrow (140d294445)
- Bug 1222661 - Replace FromUntyped(obj) calls with FromUnknown*(obj). r=nical (b399ccef2e)
- Bug 1216506. Properly initialize min inset box shadow color to black. r=mstange (335259200c)
- Bug 1223690 - Remove implicit Rect conversions. r=jrmuizel. (5aef25158f)
- Bug 1056356 - Allow calling NewRunnableMethod() with a const pointer to the callee object. r=froydnj (145279b91c)
- Bug 1209649. Part 2: Reftest to test box shadows and border radii. r=mstange (9405ccfe23)
- Bug 1211363. Part 2: reftest with int border radius. r=mstange (9edb37635e)
- Bug 1216200. Inset box shadow reftest with negative spread value. r=mstange (8350478107)
- Bug 1211264. Fallback to render dest rect with outer box shadows on non-int transforms. r=mstange (a244775d24)
- Bug 1216200. Correct for negative spread values with inset box shadows. r=mstange (4851e9c792)
- cleanup (1f78332ad8)
- Bug 1213970 - Enable APZ on iOS r=kats (1d170e32e3)
- Bug 1217939 - part 1 - remove nsContentUtils::GetViewportInfo; r=smaug (8c25236851)
- Bug 1217939 - part 2 - move nsContentUtils::GetSelectionBoundingRect to nsLayoutUtils; r=smaug (6beb37157c)
- Bug 1146713 - Don't export NO_PKG_FILES (fix ssltunnel in b2g); r=glandium (a21152c79c)
- Bug 1222323 - Avoid passing extra defines to the compiler from config.mk. r=gps (2d1076d513)
- Bug 1222321 - Avoid the duplication of OS_CPPFLAGS on the compiler command line. r=gps (cf762f1644)
- Bug 1210687 - Separate out jar.mn parsing in a separate class. r=gps (d54cc5576b)
- Bug 1219147 - Use addEntriesToListFile in mozbuild.jar.JarMaker.updateManifest. r=mshal (3cd74ff478)
- Bug 1208160 - Show information when Xcode requires accepting license agreement; r=gps (352bb43d73)
- Bug 1174524 - Make objdir path comparison case-insensitive on Windows. r=mshal (6f74f10845)
- Bug 1158898 - Cache config.guess output; r=mshal (a7b01184fa)
- Bug 1187245 - Make .mozconfig.mk environment variables available to mach valgrind-test. r=gps (2033642ceb)
299 lines
12 KiB
C++
299 lines
12 KiB
C++
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
#include "MobileViewportManager.h"
|
|
|
|
#include "LayersLogging.h"
|
|
#include "nsViewManager.h"
|
|
#include "nsViewportInfo.h"
|
|
|
|
#define MVM_LOG(...)
|
|
// #define MVM_LOG(...) printf_stderr("MVM: " __VA_ARGS__)
|
|
|
|
NS_IMPL_ISUPPORTS(MobileViewportManager, nsIDOMEventListener, nsIObserver)
|
|
|
|
static const nsLiteralString DOM_META_ADDED = NS_LITERAL_STRING("DOMMetaAdded");
|
|
static const nsLiteralString DOM_META_CHANGED = NS_LITERAL_STRING("DOMMetaChanged");
|
|
static const nsLiteralString FULL_ZOOM_CHANGE = NS_LITERAL_STRING("FullZoomChange");
|
|
static const nsLiteralCString BEFORE_FIRST_PAINT = NS_LITERAL_CSTRING("before-first-paint");
|
|
|
|
using namespace mozilla;
|
|
using namespace mozilla::layers;
|
|
|
|
MobileViewportManager::MobileViewportManager(nsIPresShell* aPresShell,
|
|
nsIDocument* aDocument)
|
|
: mDocument(aDocument)
|
|
, mPresShell(aPresShell)
|
|
, mIsFirstPaint(false)
|
|
, mPainted(false)
|
|
{
|
|
MOZ_ASSERT(mPresShell);
|
|
MOZ_ASSERT(mDocument);
|
|
|
|
MVM_LOG("%p: creating with presShell %p document %p\n", this, mPresShell, aDocument);
|
|
|
|
if (nsCOMPtr<nsPIDOMWindow> window = mDocument->GetWindow()) {
|
|
mEventTarget = window->GetChromeEventHandler();
|
|
}
|
|
if (mEventTarget) {
|
|
mEventTarget->AddEventListener(DOM_META_ADDED, this, false);
|
|
mEventTarget->AddEventListener(DOM_META_CHANGED, this, false);
|
|
mEventTarget->AddEventListener(FULL_ZOOM_CHANGE, this, false);
|
|
}
|
|
|
|
nsCOMPtr<nsIObserverService> observerService = mozilla::services::GetObserverService();
|
|
if (observerService) {
|
|
observerService->AddObserver(this, BEFORE_FIRST_PAINT.Data(), false);
|
|
}
|
|
}
|
|
|
|
MobileViewportManager::~MobileViewportManager()
|
|
{
|
|
}
|
|
|
|
void
|
|
MobileViewportManager::Destroy()
|
|
{
|
|
MVM_LOG("%p: destroying\n", this);
|
|
|
|
if (mEventTarget) {
|
|
mEventTarget->RemoveEventListener(DOM_META_ADDED, this, false);
|
|
mEventTarget->RemoveEventListener(DOM_META_CHANGED, this, false);
|
|
mEventTarget->RemoveEventListener(FULL_ZOOM_CHANGE, this, false);
|
|
mEventTarget = nullptr;
|
|
}
|
|
|
|
nsCOMPtr<nsIObserverService> observerService = mozilla::services::GetObserverService();
|
|
if (observerService) {
|
|
observerService->RemoveObserver(this, BEFORE_FIRST_PAINT.Data());
|
|
}
|
|
|
|
mDocument = nullptr;
|
|
mPresShell = nullptr;
|
|
}
|
|
|
|
void
|
|
MobileViewportManager::RequestReflow()
|
|
{
|
|
MVM_LOG("%p: got a reflow request\n", this);
|
|
RefreshViewportSize(false);
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
MobileViewportManager::HandleEvent(nsIDOMEvent* event)
|
|
{
|
|
nsAutoString type;
|
|
event->GetType(type);
|
|
|
|
if (type.Equals(DOM_META_ADDED)) {
|
|
MVM_LOG("%p: got a dom-meta-added event\n", this);
|
|
RefreshViewportSize(mPainted);
|
|
} else if (type.Equals(DOM_META_CHANGED)) {
|
|
MVM_LOG("%p: got a dom-meta-changed event\n", this);
|
|
RefreshViewportSize(mPainted);
|
|
} else if (type.Equals(FULL_ZOOM_CHANGE)) {
|
|
MVM_LOG("%p: got a full-zoom-change event\n", this);
|
|
RefreshViewportSize(false);
|
|
}
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
MobileViewportManager::Observe(nsISupports* aSubject, const char* aTopic, const char16_t* aData)
|
|
{
|
|
if (SameCOMIdentity(aSubject, mDocument) && BEFORE_FIRST_PAINT.EqualsASCII(aTopic)) {
|
|
MVM_LOG("%p: got a before-first-paint event\n", this);
|
|
mIsFirstPaint = true;
|
|
mPainted = true;
|
|
RefreshViewportSize(false);
|
|
}
|
|
return NS_OK;
|
|
}
|
|
|
|
CSSToScreenScale
|
|
MobileViewportManager::UpdateResolution(const nsViewportInfo& aViewportInfo,
|
|
const ScreenIntSize& aDisplaySize,
|
|
const CSSSize& aViewport,
|
|
const Maybe<float>& aDisplayWidthChangeRatio)
|
|
{
|
|
CSSToLayoutDeviceScale cssToDev =
|
|
mPresShell->GetPresContext()->CSSToDevPixelScale();
|
|
LayoutDeviceToLayerScale res(nsLayoutUtils::GetResolution(mPresShell));
|
|
|
|
if (mIsFirstPaint) {
|
|
CSSToScreenScale defaultZoom = aViewportInfo.GetDefaultZoom();
|
|
MVM_LOG("%p: default zoom from viewport is %f\n", this, defaultZoom.scale);
|
|
// FIXME/bug 799585(?): GetViewportInfo() returns a default zoom of
|
|
// 0.0 to mean "did not calculate a zoom". In that case, we default
|
|
// it to the intrinsic scale.
|
|
if (defaultZoom.scale < 0.01f) {
|
|
defaultZoom = MaxScaleRatio(ScreenSize(aDisplaySize), aViewport);
|
|
MVM_LOG("%p: Intrinsic computed zoom is %f\n", this, defaultZoom.scale);
|
|
}
|
|
MOZ_ASSERT(aViewportInfo.GetMinZoom() <= defaultZoom &&
|
|
defaultZoom <= aViewportInfo.GetMaxZoom());
|
|
|
|
CSSToParentLayerScale zoom = ViewTargetAs<ParentLayerPixel>(defaultZoom,
|
|
PixelCastJustification::ScreenIsParentLayerForRoot);
|
|
|
|
LayoutDeviceToLayerScale resolution = zoom / cssToDev * ParentLayerToLayerScale(1);
|
|
MVM_LOG("%p: setting resolution %f\n", this, resolution.scale);
|
|
nsLayoutUtils::SetResolutionAndScaleTo(mPresShell, resolution.scale);
|
|
|
|
return defaultZoom;
|
|
}
|
|
|
|
// If this is not a first paint, then in some cases we want to update the pre-
|
|
// existing resolution so as to maintain how much actual content is visible
|
|
// within the display width. Note that "actual content" may be different with
|
|
// respect to CSS pixels because of the CSS viewport size changing.
|
|
//
|
|
// aDisplayWidthChangeRatio is non-empty if:
|
|
// (a) The meta-viewport tag information changes, and so the CSS viewport
|
|
// might change as a result. If this happens after the content has been
|
|
// painted, we want to adjust the zoom to compensate. OR
|
|
// (b) The display size changed from a nonzero value to another nonzero value.
|
|
// This covers the case where e.g. the device was rotated, and again we
|
|
// want to adjust the zoom to compensate.
|
|
// Note in particular that aDisplayWidthChangeRatio will be None if all that
|
|
// happened was a change in the full-zoom. In this case, we still want to
|
|
// compute a new CSS viewport, but we don't want to update the resolution.
|
|
//
|
|
// Given the above, the algorithm below accounts for all types of changes I
|
|
// can conceive of:
|
|
// 1. screen size changes, CSS viewport does not (pages with no meta viewport
|
|
// or a fixed size viewport)
|
|
// 2. screen size changes, CSS viewport also does (pages with a device-width
|
|
// viewport)
|
|
// 3. screen size remains constant, but CSS viewport changes (meta viewport
|
|
// tag is added or removed)
|
|
// 4. neither screen size nor CSS viewport changes
|
|
if (aDisplayWidthChangeRatio) {
|
|
float cssViewportChangeRatio = (mMobileViewportSize.width == 0)
|
|
? 1.0f : aViewport.width / mMobileViewportSize.width;
|
|
LayoutDeviceToLayerScale newRes(res.scale * aDisplayWidthChangeRatio.value()
|
|
/ cssViewportChangeRatio);
|
|
MVM_LOG("%p: Old resolution was %f, changed by %f/%f to %f\n", this, res.scale,
|
|
aDisplayWidthChangeRatio.value(), cssViewportChangeRatio, newRes.scale);
|
|
nsLayoutUtils::SetResolutionAndScaleTo(mPresShell, newRes.scale);
|
|
res = newRes;
|
|
}
|
|
|
|
return ViewTargetAs<ScreenPixel>(cssToDev * res / ParentLayerToLayerScale(1),
|
|
PixelCastJustification::ScreenIsParentLayerForRoot);
|
|
}
|
|
|
|
void
|
|
MobileViewportManager::UpdateSPCSPS(const ScreenIntSize& aDisplaySize,
|
|
const CSSToScreenScale& aZoom)
|
|
{
|
|
ScreenSize compositionSize(aDisplaySize);
|
|
ScreenMargin scrollbars =
|
|
LayoutDeviceMargin::FromAppUnits(
|
|
nsLayoutUtils::ScrollbarAreaToExcludeFromCompositionBoundsFor(
|
|
mPresShell->GetRootScrollFrame()),
|
|
mPresShell->GetPresContext()->AppUnitsPerDevPixel())
|
|
// Scrollbars are not subject to resolution scaling, so LD pixels =
|
|
// Screen pixels for them.
|
|
* LayoutDeviceToScreenScale(1.0f);
|
|
|
|
compositionSize.width -= scrollbars.LeftRight();
|
|
compositionSize.height -= scrollbars.TopBottom();
|
|
CSSSize compSize = compositionSize / aZoom;
|
|
MVM_LOG("%p: Setting SPCSPS %s\n", this, Stringify(compSize).c_str());
|
|
nsLayoutUtils::SetScrollPositionClampingScrollPortSize(mPresShell, compSize);
|
|
}
|
|
|
|
void
|
|
MobileViewportManager::UpdateDisplayPortMargins()
|
|
{
|
|
if (nsIFrame* root = mPresShell->GetRootScrollFrame()) {
|
|
if (!nsLayoutUtils::GetDisplayPort(root->GetContent(), nullptr)) {
|
|
// There isn't already a displayport, so we don't want to add one.
|
|
return;
|
|
}
|
|
nsIScrollableFrame* scrollable = do_QueryFrame(root);
|
|
nsLayoutUtils::CalculateAndSetDisplayPortMargins(scrollable,
|
|
nsLayoutUtils::RepaintMode::DoNotRepaint);
|
|
}
|
|
}
|
|
|
|
void
|
|
MobileViewportManager::RefreshViewportSize(bool aForceAdjustResolution)
|
|
{
|
|
// This function gets called by the various triggers that may result in a
|
|
// change of the CSS viewport. In some of these cases (e.g. the meta-viewport
|
|
// tag changes) we want to update the resolution and in others (e.g. the full
|
|
// zoom changing) we don't want to update the resolution. See the comment in
|
|
// UpdateResolution for some more detail on this. An important assumption we
|
|
// make here is that this RefreshViewportSize function will be called
|
|
// separately for each trigger that changes. For instance it should never get
|
|
// called such that both the full zoom and the meta-viewport tag have changed;
|
|
// instead it would get called twice - once after each trigger changes. This
|
|
// assumption is what allows the aForceAdjustResolution parameter to work as
|
|
// intended; if this assumption is violated then we will need to add extra
|
|
// complicated logic in UpdateResolution to ensure we only do the resolution
|
|
// update in the right scenarios.
|
|
|
|
Maybe<float> displayWidthChangeRatio;
|
|
LayoutDeviceIntSize newDisplaySize;
|
|
if (nsLayoutUtils::GetContentViewerSize(mPresShell->GetPresContext(), newDisplaySize)) {
|
|
// See the comment in UpdateResolution for why we're doing this.
|
|
if (mDisplaySize.width > 0) {
|
|
if (aForceAdjustResolution || mDisplaySize.width != newDisplaySize.width) {
|
|
displayWidthChangeRatio = Some((float)newDisplaySize.width / (float)mDisplaySize.width);
|
|
}
|
|
} else if (aForceAdjustResolution) {
|
|
displayWidthChangeRatio = Some(1.0f);
|
|
}
|
|
|
|
MVM_LOG("%p: Display width change ratio is %f\n", this, displayWidthChangeRatio.valueOr(0.0f));
|
|
mDisplaySize = newDisplaySize;
|
|
}
|
|
|
|
MVM_LOG("%p: Computing CSS viewport using %d,%d\n", this,
|
|
mDisplaySize.width, mDisplaySize.height);
|
|
if (mDisplaySize.width == 0 || mDisplaySize.height == 0) {
|
|
// We can't do anything useful here, we should just bail out
|
|
return;
|
|
}
|
|
|
|
ScreenIntSize displaySize = ViewAs<ScreenPixel>(
|
|
mDisplaySize, PixelCastJustification::LayoutDeviceIsScreenForBounds);
|
|
nsViewportInfo viewportInfo = mDocument->GetViewportInfo(displaySize);
|
|
|
|
CSSSize viewport = viewportInfo.GetSize();
|
|
MVM_LOG("%p: Computed CSS viewport %s\n", this, Stringify(viewport).c_str());
|
|
|
|
if (!mIsFirstPaint && mMobileViewportSize == viewport) {
|
|
// Nothing changed, so no need to do a reflow
|
|
return;
|
|
}
|
|
|
|
// If it's the first-paint or the viewport changed, we need to update
|
|
// various APZ properties (the zoom and some things that might depend on it)
|
|
MVM_LOG("%p: Updating properties because %d || %d\n", this,
|
|
mIsFirstPaint, mMobileViewportSize != viewport);
|
|
|
|
if (gfxPrefs::APZAllowZooming()) {
|
|
CSSToScreenScale zoom = UpdateResolution(viewportInfo, displaySize, viewport,
|
|
displayWidthChangeRatio);
|
|
MVM_LOG("%p: New zoom is %f\n", this, zoom.scale);
|
|
UpdateSPCSPS(displaySize, zoom);
|
|
}
|
|
if (gfxPlatform::AsyncPanZoomEnabled()) {
|
|
UpdateDisplayPortMargins();
|
|
}
|
|
|
|
// Update internal state.
|
|
mIsFirstPaint = false;
|
|
mMobileViewportSize = viewport;
|
|
|
|
// Kick off a reflow.
|
|
mPresShell->ResizeReflowIgnoreOverride(
|
|
nsPresContext::CSSPixelsToAppUnits(viewport.width),
|
|
nsPresContext::CSSPixelsToAppUnits(viewport.height));
|
|
}
|