Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(3466)

Unified Diff: cc/tile_priority.cc

Issue 12471007: Part 8 of cc/ directory shuffles: resources (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « cc/tile_priority.h ('k') | cc/tile_priority_unittest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: cc/tile_priority.cc
diff --git a/cc/tile_priority.cc b/cc/tile_priority.cc
deleted file mode 100644
index 2f1000dbb24e8155e5c1604e660ff16ae81a7253..0000000000000000000000000000000000000000
--- a/cc/tile_priority.cc
+++ /dev/null
@@ -1,195 +0,0 @@
-// Copyright 2012 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-#include "cc/tile_priority.h"
-
-#include "base/values.h"
-#include "cc/base/math_util.h"
-
-namespace {
-
-// TODO(qinmin): modify ui/range/Range.h to support template so that we
-// don't need to define this.
-struct Range {
- Range(float start, float end) : start_(start), end_(end) {}
- bool IsEmpty();
- float start_;
- float end_;
-};
-
-inline bool Intersects(const Range& a, const Range& b) {
- return a.start_ < b.end_ && b.start_ < a.end_;
-}
-
-inline Range Intersect(const Range& a, const Range& b) {
- return Range(std::max(a.start_, b.start_), std::min(a.end_, b.end_));
-}
-
-bool Range::IsEmpty() {
- return start_ >= end_;
-}
-
-inline void IntersectNegativeHalfplane(Range& out, float previous,
- float current, float target, float time_delta) {
- float time_per_dist = time_delta / (current - previous);
- float t = (target - current) * time_per_dist;
- if (time_per_dist > 0.0f)
- out.start_ = std::max(out.start_, t);
- else
- out.end_ = std::min(out.end_, t);
-}
-
-inline void IntersectPositiveHalfplane(Range& out, float previous,
- float current, float target, float time_delta) {
- float time_per_dist = time_delta / (current - previous);
- float t = (target - current) * time_per_dist;
- if (time_per_dist < 0.0f)
- out.start_ = std::max(out.start_, t);
- else
- out.end_ = std::min(out.end_, t);
-}
-
-} // namespace
-
-namespace cc {
-
-const float TilePriority::kMaxDistanceInContentSpace = 4096.0f;
-
-// At 256x256 tiles, 128 tiles cover an area of 2048x4096 pixels.
-const int64 TilePriority::
- kNumTilesToCoverWithInflatedViewportRectForPrioritization = 128;
-
-scoped_ptr<base::Value> WhichTreeAsValue(WhichTree tree) {
- switch (tree) {
- case ACTIVE_TREE:
- return scoped_ptr<base::Value>(base::Value::CreateStringValue(
- "ACTIVE_TREE"));
- case PENDING_TREE:
- return scoped_ptr<base::Value>(base::Value::CreateStringValue(
- "PENDING_TREE"));
- default:
- DCHECK(false) << "Unrecognized WhichTree value " << tree;
- return scoped_ptr<base::Value>(base::Value::CreateStringValue(
- "<unknown WhichTree value>"));
- }
-}
-
-scoped_ptr<base::Value> TileResolutionAsValue(
- TileResolution resolution) {
- switch (resolution) {
- case LOW_RESOLUTION:
- return scoped_ptr<base::Value>(base::Value::CreateStringValue(
- "LOW_RESOLUTION"));
- case HIGH_RESOLUTION:
- return scoped_ptr<base::Value>(base::Value::CreateStringValue(
- "HIGH_RESOLUTION"));
- case NON_IDEAL_RESOLUTION:
- return scoped_ptr<base::Value>(base::Value::CreateStringValue(
- "NON_IDEAL_RESOLUTION"));
- default:
- DCHECK(false) << "Unrecognized TileResolution value " << resolution;
- return scoped_ptr<base::Value>(base::Value::CreateStringValue(
- "<unknown TileResolution value>"));
- }
-}
-
-scoped_ptr<base::Value> TilePriority::AsValue() const {
- scoped_ptr<base::DictionaryValue> state(new base::DictionaryValue());
- state->SetBoolean("is_live", is_live);
- state->Set("resolution", TileResolutionAsValue(resolution).release());
- state->Set("time_to_visible_in_seconds", MathUtil::AsValueSafely(time_to_visible_in_seconds).release());
- state->Set("distance_to_visible_in_pixels", MathUtil::AsValueSafely(distance_to_visible_in_pixels).release());
- state->Set("current_screen_quad", MathUtil::AsValue(current_screen_quad).release());
- return state.PassAs<base::Value>();
-}
-
-float TilePriority::TimeForBoundsToIntersect(const gfx::RectF& previous_bounds,
- const gfx::RectF& current_bounds,
- float time_delta,
- const gfx::RectF& target_bounds) {
- // Perform an intersection test explicitly between current and target.
- if (current_bounds.x() < target_bounds.right() &&
- current_bounds.y() < target_bounds.bottom() &&
- target_bounds.x() < current_bounds.right() &&
- target_bounds.y() < current_bounds.bottom())
- return 0.0f;
-
- const float kMaxTimeToVisibleInSeconds =
- std::numeric_limits<float>::infinity();
-
- if (time_delta == 0.0f)
- return kMaxTimeToVisibleInSeconds;
-
- // As we are trying to solve the case of both scaling and scrolling, using
- // a single coordinate with velocity is not enough. The logic here is to
- // calculate the velocity for each edge. Then we calculate the time range that
- // each edge will stay on the same side of the target bounds. If there is an
- // overlap between these time ranges, the bounds must have intersect with
- // each other during that period of time.
- Range range(0.0f, kMaxTimeToVisibleInSeconds);
- IntersectPositiveHalfplane(
- range, previous_bounds.x(), current_bounds.x(),
- target_bounds.right(), time_delta);
- IntersectNegativeHalfplane(
- range, previous_bounds.right(), current_bounds.right(),
- target_bounds.x(), time_delta);
- IntersectPositiveHalfplane(
- range, previous_bounds.y(), current_bounds.y(),
- target_bounds.bottom(), time_delta);
- IntersectNegativeHalfplane(
- range, previous_bounds.bottom(), current_bounds.bottom(),
- target_bounds.y(), time_delta);
- return range.IsEmpty() ? kMaxTimeToVisibleInSeconds : range.start_;
-}
-
-scoped_ptr<base::Value> TileMemoryLimitPolicyAsValue(
- TileMemoryLimitPolicy policy) {
- switch (policy) {
- case ALLOW_NOTHING:
- return scoped_ptr<base::Value>(base::Value::CreateStringValue(
- "ALLOW_NOTHING"));
- case ALLOW_ABSOLUTE_MINIMUM:
- return scoped_ptr<base::Value>(base::Value::CreateStringValue(
- "ALLOW_ABSOLUTE_MINIMUM"));
- case ALLOW_PREPAINT_ONLY:
- return scoped_ptr<base::Value>(base::Value::CreateStringValue(
- "ALLOW_PREPAINT_ONLY"));
- case ALLOW_ANYTHING:
- return scoped_ptr<base::Value>(base::Value::CreateStringValue(
- "ALLOW_ANYTHING"));
- default:
- DCHECK(false) << "Unrecognized policy value";
- return scoped_ptr<base::Value>(base::Value::CreateStringValue(
- "<unknown>"));
- }
-}
-
-scoped_ptr<base::Value> TreePriorityAsValue(TreePriority prio) {
- switch (prio) {
- case SAME_PRIORITY_FOR_BOTH_TREES:
- return scoped_ptr<base::Value>(base::Value::CreateStringValue(
- "SAME_PRIORITY_FOR_BOTH_TREES"));
- case SMOOTHNESS_TAKES_PRIORITY:
- return scoped_ptr<base::Value>(base::Value::CreateStringValue(
- "SMOOTHNESS_TAKES_PRIORITY"));
- case NEW_CONTENT_TAKES_PRIORITY:
- return scoped_ptr<base::Value>(base::Value::CreateStringValue(
- "NEW_CONTENT_TAKES_PRIORITY"));
- default:
- DCHECK(false) << "Unrecognized priority value " << prio;
- return scoped_ptr<base::Value>(base::Value::CreateStringValue(
- "<unknown>"));
- }
-}
-
-scoped_ptr<base::Value> GlobalStateThatImpactsTilePriority::AsValue() const {
- scoped_ptr<base::DictionaryValue> state(new base::DictionaryValue());
- state->Set("memory_limit_policy", TileMemoryLimitPolicyAsValue(memory_limit_policy).release());
- state->SetInteger("memory_limit_in_bytes", memory_limit_in_bytes);
- state->Set("tree_priority", TreePriorityAsValue(tree_priority).release());
- return state.PassAs<base::Value>();
-}
-
-
-} // namespace cc
« no previous file with comments | « cc/tile_priority.h ('k') | cc/tile_priority_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698