// Copyright 2013 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/resources/managed_tile_state.h" #include <limits> #include "cc/base/math_util.h" namespace cc { scoped_ptr<base::Value> ManagedTileBinAsValue(ManagedTileBin bin) { switch (bin) { case NOW_AND_READY_TO_DRAW_BIN: return scoped_ptr<base::Value>( base::Value::CreateStringValue("NOW_AND_READY_TO_DRAW_BIN")); case NOW_BIN: return scoped_ptr<base::Value>( base::Value::CreateStringValue("NOW_BIN")); case SOON_BIN: return scoped_ptr<base::Value>( base::Value::CreateStringValue("SOON_BIN")); case EVENTUALLY_AND_ACTIVE_BIN: return scoped_ptr<base::Value>( base::Value::CreateStringValue("EVENTUALLY_AND_ACTIVE_BIN")); case EVENTUALLY_BIN: return scoped_ptr<base::Value>( base::Value::CreateStringValue("EVENTUALLY_BIN")); case AT_LAST_AND_ACTIVE_BIN: return scoped_ptr<base::Value>( base::Value::CreateStringValue("AT_LAST_AND_ACTIVE_BIN")); case AT_LAST_BIN: return scoped_ptr<base::Value>( base::Value::CreateStringValue("AT_LAST_BIN")); case NEVER_BIN: return scoped_ptr<base::Value>( base::Value::CreateStringValue("NEVER_BIN")); case NUM_BINS: NOTREACHED(); return scoped_ptr<base::Value>( base::Value::CreateStringValue("Invalid Bin (NUM_BINS)")); } return scoped_ptr<base::Value>( base::Value::CreateStringValue("Invalid Bin (UNKNOWN)")); } ManagedTileState::ManagedTileState() : raster_mode(LOW_QUALITY_RASTER_MODE), bin(NEVER_BIN), resolution(NON_IDEAL_RESOLUTION), required_for_activation(false), time_to_needed_in_seconds(std::numeric_limits<float>::infinity()), distance_to_visible_in_pixels(std::numeric_limits<float>::infinity()), visible_and_ready_to_draw(false), scheduled_priority(0) { } ManagedTileState::TileVersion::TileVersion() : mode_(RESOURCE_MODE), has_text_(false) { } ManagedTileState::TileVersion::~TileVersion() { DCHECK(!resource_); } bool ManagedTileState::TileVersion::IsReadyToDraw() const { switch (mode_) { case RESOURCE_MODE: return !!resource_; case SOLID_COLOR_MODE: case PICTURE_PILE_MODE: return true; } NOTREACHED(); return false; } size_t ManagedTileState::TileVersion::GPUMemoryUsageInBytes() const { if (!resource_) return 0; return resource_->bytes(); } ManagedTileState::~ManagedTileState() { } scoped_ptr<base::Value> ManagedTileState::AsValue() const { bool has_resource = false; bool has_active_task = false; for (int mode = 0; mode < NUM_RASTER_MODES; ++mode) { has_resource |= (tile_versions[mode].resource_.get() != 0); has_active_task |= !tile_versions[mode].raster_task_.is_null(); } bool is_using_gpu_memory = has_resource || has_active_task; scoped_ptr<base::DictionaryValue> state(new base::DictionaryValue()); state->SetBoolean("has_resource", has_resource); state->SetBoolean("is_using_gpu_memory", is_using_gpu_memory); state->Set("bin", ManagedTileBinAsValue(bin).release()); state->Set("resolution", TileResolutionAsValue(resolution).release()); state->Set("time_to_needed_in_seconds", MathUtil::AsValueSafely(time_to_needed_in_seconds).release()); state->Set("distance_to_visible_in_pixels", MathUtil::AsValueSafely(distance_to_visible_in_pixels).release()); state->SetBoolean("required_for_activation", required_for_activation); state->SetBoolean( "is_solid_color", tile_versions[raster_mode].mode_ == TileVersion::SOLID_COLOR_MODE); state->SetBoolean( "is_transparent", tile_versions[raster_mode].mode_ == TileVersion::SOLID_COLOR_MODE && !SkColorGetA(tile_versions[raster_mode].solid_color_)); state->SetInteger("scheduled_priority", scheduled_priority); return state.PassAs<base::Value>(); } } // namespace cc