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

Unified Diff: cc/layers/scrollbar_layer_impl_base.h

Issue 23983047: Pinch/Zoom Infrastructure & Plumbing CL (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Backup 2013.10.29 Created 7 years, 2 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
Index: cc/layers/scrollbar_layer_impl_base.h
diff --git a/cc/layers/scrollbar_layer_impl_base.h b/cc/layers/scrollbar_layer_impl_base.h
index 55ade6ab04f18b5ab7691ca3e4555903046ca902..cba60d286221d310efaf6b11870a83e924553580 100644
--- a/cc/layers/scrollbar_layer_impl_base.h
+++ b/cc/layers/scrollbar_layer_impl_base.h
@@ -7,6 +7,7 @@
#include "cc/base/cc_export.h"
#include "cc/input/scrollbar.h"
+#include "cc/layers/layer.h"
#include "cc/layers/layer_impl.h"
namespace cc {
@@ -15,8 +16,16 @@ class LayerTreeImpl;
class CC_EXPORT ScrollbarLayerImplBase : public LayerImpl {
public:
- int ScrollLayerId() const { return scroll_layer_id_; }
- void set_scroll_layer_id(int id) { scroll_layer_id_ = id; }
+ int ScrollLayerId() const {
+ return scroll_layer_ ? scroll_layer_->id() : Layer::INVALID_ID;
+ }
+ void ClearScrollLayer() { scroll_layer_ = NULL; }
+ void SetScrollLayerById(int id);
+ int ClipLayerId() const {
+ return clip_layer_ ? clip_layer_->id() : Layer::INVALID_ID;
+ }
+ void ClearClipLayer() { clip_layer_ = NULL; }
+ void SetClipLayerById(int id);
float current_pos() const { return current_pos_; }
void SetCurrentPos(float current_pos);
@@ -48,12 +57,15 @@ class CC_EXPORT ScrollbarLayerImplBase : public LayerImpl {
thumb_thickness_scale_factor_ = thumb_thickness_scale_factor;
}
+ void ScrollbarParametersDidChange();
+ bool opacity_can_animate() { return opacity_can_animate_; }
+
protected:
ScrollbarLayerImplBase(LayerTreeImpl* tree_impl,
int id,
ScrollbarOrientation orientation,
bool is_left_side_vertical_scrollbar);
- virtual ~ScrollbarLayerImplBase() {}
+ virtual ~ScrollbarLayerImplBase();
gfx::Rect ScrollbarLayerRectToContentRect(gfx::RectF layer_rect) const;
@@ -68,7 +80,8 @@ class CC_EXPORT ScrollbarLayerImplBase : public LayerImpl {
virtual int TrackStart() const = 0;
private:
- int scroll_layer_id_;
+ LayerImpl* scroll_layer_;
+ LayerImpl* clip_layer_;
bool is_overlay_scrollbar_;
float thumb_thickness_scale_factor_;
@@ -83,7 +96,11 @@ class CC_EXPORT ScrollbarLayerImplBase : public LayerImpl {
float visible_to_total_length_ratio_;
+
DISALLOW_COPY_AND_ASSIGN(ScrollbarLayerImplBase);
+
+ protected:
+ bool opacity_can_animate_;
};
} // namespace cc

Powered by Google App Engine
This is Rietveld 408576698