mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:30:27 +00:00
b372a2634f
- Bug 1087646 - Properly serialize nullprincipal URIs across IPC. (1fcc5a63e) - bug 1137538 - remove nsIIdentityInfo and nsNSSSocketInfo::GetPreviousCert Bug 1136471 - Remove unused nsIIdentityInfo.getValidEVPolicyOid(). (f23ed7a6f) - Bug 1049476 - 0001. webidl change - Support user certificate parameter (ba92ac3c6) - Bug 1049476 - 0002. Support user certificate parameter in API. (30ec1a9c8) - Bug 1049476 - 0003. Add EAP-TLS to wifi capabilities. (69920f968) - Bug 1130400. Part 1. Pass the passed in anchor frame to SetPopupPosition in nsMenuPopupFrame::LayoutPopup if we have one. r=enndeakin (2de244c51) - Bug 1130400. Part 2. Use a reflow callback to set the position of xul popups. r=enndeakin (aa2117085) - Bug 1130400. Add test. (9047c9013) - Bug 1043143: Step 2a: Add a class like nsDownloader but using memory instead of a file. (fad673f10) - Bug 1034143: Step 2b: Add the ability to read jar files from arbitrary memory. (e1dc9faa6) - Bug 1034143: Step 1: Fix tests for bug 945152 and bug 1008126. r=smaug (e6b6cc408) - Bug 1043143: Step 3: Convert nsJARChannel from temporary files to temporary memory. r=honzab (79e381e50) - Bug 1145631 - Part 1: Replace MOZ_OVERRIDE and MOZ_FINAL with override and final in the tree; r=froydnj (f21f630cb) - Bug 1148527 - Indentation fix after bug 1145631 (a8153b9c5)
93 lines
3.4 KiB
C++
93 lines
3.4 KiB
C++
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* vim: set shiftwidth=2 tabstop=8 autoindent cindent expandtab: */
|
|
/* 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/. */
|
|
|
|
#ifndef ScrollVelocityQueue_h_
|
|
#define ScrollVelocityQueue_h_
|
|
|
|
#include "nsTArray.h"
|
|
#include "nsPoint.h"
|
|
#include "mozilla/TimeStamp.h"
|
|
|
|
class nsPresContext;
|
|
|
|
namespace mozilla {
|
|
namespace layout {
|
|
|
|
/**
|
|
* ScrollVelocityQueue is used to determine the current velocity of a
|
|
* scroll frame, derived from scroll position samples.
|
|
*
|
|
* Using the last iteration's scroll position, stored in mLastPosition, a
|
|
* delta of the scroll position is calculated and accumulated in mAccumulator
|
|
* until the refresh driver returns a new timestamp for MostRecentRefresh().
|
|
*
|
|
* When there is a new timestamp from the refresh driver, the accumulated
|
|
* change in scroll position is divided by the delta of the timestamp to
|
|
* get an average velocity over that period. This velocity is pushed into
|
|
* mQueue as a std::pair associating each velocity with the
|
|
* duration over which it was sampled.
|
|
*
|
|
* Samples are removed from mQueue, leaving only those necessary to determine
|
|
* the average velocity over the recent relevant period, which has a duration
|
|
* set by the apz.velocity_relevance_time_ms preference.
|
|
*
|
|
* The velocity of each sample is clamped to a value set by the
|
|
* layout.css.scroll-snap.prediction-max-velocity.
|
|
*
|
|
* As the average velocity will later be integrated over a duration set by
|
|
* the layout.css.scroll-snap.prediction-sensitivity preference and the
|
|
* velocity samples are clamped to a set value, the maximum expected scroll
|
|
* offset can be calculated. This maximum offset is used to clamp
|
|
* mAccumulator, eliminating samples that would otherwise result in scroll
|
|
* snap position selection that is not consistent with the user's perception
|
|
* of scroll velocity.
|
|
*/
|
|
|
|
class ScrollVelocityQueue final {
|
|
public:
|
|
explicit ScrollVelocityQueue(nsPresContext *aPresContext)
|
|
: mPresContext(aPresContext) {}
|
|
|
|
// Sample() is to be called periodically when scroll movement occurs, to
|
|
// record samples of scroll position used later by GetVelocity().
|
|
void Sample(const nsPoint& aScrollPosition);
|
|
|
|
// Discards velocity samples, resulting in velocity of 0 returned by
|
|
// GetVelocity until move scroll position updates.
|
|
void Reset();
|
|
|
|
// Get scroll velocity averaged from recent movement, in appunits / second
|
|
nsPoint GetVelocity();
|
|
private:
|
|
// A queue of (duration, velocity) pairs; these are the historical average
|
|
// velocities over the given durations. Durations are in milliseconds,
|
|
// velocities are in app units per second.
|
|
nsTArray<std::pair<uint32_t, nsPoint> > mQueue;
|
|
|
|
// Accumulates the distance and direction travelled by the scroll frame since
|
|
// mSampleTime.
|
|
nsPoint mAccumulator;
|
|
|
|
// Time that mAccumulator was last reset and began accumulating.
|
|
TimeStamp mSampleTime;
|
|
|
|
// Scroll offset at the mAccumulator was last reset and began
|
|
// accumulating.
|
|
nsPoint mLastPosition;
|
|
|
|
// PresContext of the containing frame, used to get timebase
|
|
nsPresContext* mPresContext;
|
|
|
|
// Remove samples from mQueue that no longer contribute to GetVelocity()
|
|
// due to their age
|
|
void TrimQueue();
|
|
};
|
|
|
|
} // namespace layout
|
|
} // namespace mozilla
|
|
|
|
#endif /* !defined(ScrollVelocityQueue_h_) */
|