// Copyright (c) 2011 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. #ifndef VIEWS_LAYER_HELPER_H_ #define VIEWS_LAYER_HELPER_H_ #pragma once #include "base/basictypes.h" #include "base/memory/ref_counted.h" #include "base/memory/scoped_ptr.h" #include "ui/gfx/rect.h" namespace ui { class Layer; class Texture; class Transform; } namespace views { class LayerPropertySetter; // This is a views-internal API and should not be used externally. View uses // this class to manage fields related to accelerated painting. namespace internal { class LayerHelper { public: LayerHelper(); ~LayerHelper(); void SetTransform(const ui::Transform& transform); // Only returns non-null if a non-identity transform has been set. const ui::Transform* transform() const { return transform_.get(); } void SetLayer(ui::Layer* layer); ui::Layer* layer() { return layer_.get(); } // Passing NULL will cause the layer to get a texture from its compositor. void SetExternalTexture(ui::Texture* texture); // Sometimes the Layer is being updated by something other than SetCanvas // (e.g. the GPU process on TOUCH_UI). bool layer_updated_externally() const { return external_texture_.get() != NULL; } // Rectangle that needs to be painted. void set_clip_rect(const gfx::Rect& rect) { clip_rect_ = rect; } const gfx::Rect& clip_rect() const { return clip_rect_; } // If true the layer was explicitly turned on. void set_paint_to_layer(bool value) { paint_to_layer_ = value; } bool paint_to_layer() const { return paint_to_layer_; } // See description in View for details void set_fills_bounds_opaquely(bool fills_bounds_opaquely) { fills_bounds_opaquely_ = fills_bounds_opaquely; } bool fills_bounds_opaquely() const { return fills_bounds_opaquely_; } void SetPropertySetter(LayerPropertySetter* setter); LayerPropertySetter* property_setter() { return property_setter_.get(); } // If true the LayerPropertySetter was explicitly set. void set_property_setter_explicitly_set(bool value) { property_setter_explicitly_set_ = value; } bool property_setter_explicitly_set() { return property_setter_explicitly_set_; } // Returns true if the layer needs to be used. bool ShouldPaintToLayer() const; private: // The transformation matrix (rotation, translate, scale). If non-null the // transform is not the identity transform. scoped_ptr transform_; scoped_ptr layer_; scoped_ptr property_setter_; // Used during painting. If not empty and View::Paint() is invoked, the canvas // is created with the specified size. // TODO(sky): this should be passed into paint. gfx::Rect clip_rect_; bool fills_bounds_opaquely_; // Should the View paint to a layer? bool paint_to_layer_; bool property_setter_explicitly_set_; bool needs_paint_all_; scoped_refptr external_texture_; DISALLOW_COPY_AND_ASSIGN(LayerHelper); }; } // namespace internal } // namespace views #endif // VIEWS_LAYER_HELPER_H_