Chromium Code Reviews| Index: chrome/browser/android/compositor/scene_layer/reader_mode_scene_layer.cc |
| diff --git a/chrome/browser/android/compositor/scene_layer/reader_mode_scene_layer.cc b/chrome/browser/android/compositor/scene_layer/reader_mode_scene_layer.cc |
| index c4165671d201e49851263746e4f518f152f574fe..697f65e56f0fafa818fee1c35d8450c18d081c65 100644 |
| --- a/chrome/browser/android/compositor/scene_layer/reader_mode_scene_layer.cc |
| +++ b/chrome/browser/android/compositor/scene_layer/reader_mode_scene_layer.cc |
| @@ -6,7 +6,9 @@ |
| #include "base/android/jni_android.h" |
| #include "base/android/jni_array.h" |
| +#include "cc/layers/solid_color_layer.h" |
| #include "chrome/browser/android/compositor/layer/reader_mode_layer.h" |
| +#include "content/public/browser/android/compositor.h" |
| #include "content/public/browser/android/content_view_core.h" |
| #include "jni/ReaderModeSceneLayer_jni.h" |
| #include "ui/android/resources/resource_manager_impl.h" |
| @@ -16,7 +18,13 @@ namespace chrome { |
| namespace android { |
| ReaderModeSceneLayer::ReaderModeSceneLayer(JNIEnv* env, jobject jobj) |
| - : SceneLayer(env, jobj) { |
| + : SceneLayer(env, jobj), |
| + base_page_brightness_(1.0f), |
| + content_container_(cc::Layer::Create()) { |
| + // Responsible for moving the base page without modifying the layer itself. |
| + content_container_->SetIsDrawable(true); |
| + content_container_->SetPosition(gfx::PointF(0.0f, 0.0f)); |
| + layer()->AddChild(content_container_); |
| } |
| ReaderModeSceneLayer::~ReaderModeSceneLayer() { |
| @@ -29,7 +37,11 @@ void ReaderModeSceneLayer::CreateReaderModeLayer( |
| ui::ResourceManager* resource_manager = |
| ui::ResourceManagerImpl::FromJavaObject(jresource_manager); |
| reader_mode_layer_ = ReaderModeLayer::Create(resource_manager); |
| - layer_->AddChild(reader_mode_layer_->layer()); |
| + |
| + // The Reader Mode layer is initially invisible. |
| + reader_mode_layer_->layer()->SetHideLayerAndSubtree(true); |
| + |
| + layer()->AddChild(reader_mode_layer_->layer()); |
| } |
| void ReaderModeSceneLayer::SetResourceIds( |
| @@ -53,6 +65,8 @@ void ReaderModeSceneLayer::Update( |
| JNIEnv* env, |
| const JavaParamRef<jobject>& object, |
| jfloat dp_to_px, |
| + jfloat base_page_brightness, |
| + jfloat base_page_offset, |
| const JavaParamRef<jobject>& jcontent_view_core, |
| jfloat panel_X, |
| jfloat panel_y, |
| @@ -73,6 +87,19 @@ void ReaderModeSceneLayer::Update( |
| : content::ContentViewCore::GetNativeContentViewCore( |
| env, jcontent_view_core); |
| + // Fade the base page out. |
| + if (base_page_brightness_ != base_page_brightness) { |
| + base_page_brightness_ = base_page_brightness; |
| + cc::FilterOperations filters; |
| + if (base_page_brightness < 1.f) |
|
David Trainor- moved to gerrit
2016/05/13 16:14:34
Same here. Maybe check the styleguide first?
mdjones
2016/05/13 20:30:07
Checked, you are correct.
|
| + filters.Append( |
| + cc::FilterOperation::CreateBrightnessFilter(base_page_brightness)); |
| + content_container_->SetFilters(filters); |
| + } |
| + |
| + // Move the base page contents up. |
| + content_container_->SetPosition(gfx::PointF(0.0f, base_page_offset)); |
| + |
| reader_mode_layer_->SetProperties( |
| dp_to_px, |
| content_view_core, |
| @@ -87,6 +114,36 @@ void ReaderModeSceneLayer::Update( |
| bar_border_height, |
| bar_shadow_visible, |
| bar_shadow_opacity); |
| + |
| + // Make the layer visible if it is not already. |
| + reader_mode_layer_->layer()->SetHideLayerAndSubtree(false); |
| +} |
| + |
| +void ReaderModeSceneLayer::SetContentTree( |
| + JNIEnv* env, |
| + const JavaParamRef<jobject>& jobj, |
| + const JavaParamRef<jobject>& jcontent_tree) { |
| + SceneLayer* content_tree = FromJavaObject(env, jcontent_tree); |
| + if (!content_tree || !content_tree->layer()) return; |
| + |
| + if (!content_tree->layer()->parent() |
| + || (content_tree->layer()->parent()->id() != content_container_->id())) { |
| + content_container_->AddChild(content_tree->layer()); |
| + } |
| +} |
| + |
| +void ReaderModeSceneLayer::HideTree(JNIEnv* env, |
| + const JavaParamRef<jobject>& jobj) { |
| + // TODO(mdjones): Create super class for this logic. |
| + if (reader_mode_layer_) { |
| + reader_mode_layer_->layer()->SetHideLayerAndSubtree(true); |
| + } |
| + // Reset base page brightness. |
| + cc::FilterOperations filters; |
| + filters.Append(cc::FilterOperation::CreateBrightnessFilter(1.0f)); |
| + content_container_->SetFilters(filters); |
| + // Reset base page offset. |
| + content_container_->SetPosition(gfx::PointF(0.0f, 0.0f)); |
| } |
| static jlong Init(JNIEnv* env, const JavaParamRef<jobject>& jobj) { |