2011-07-28 14:26:00 +00:00
|
|
|
|
2010-02-12 17:17:10 +00:00
|
|
|
/*
|
2011-07-28 14:26:00 +00:00
|
|
|
* Copyright 2010 The Android Open Source Project
|
2010-02-12 17:17:10 +00:00
|
|
|
*
|
2011-07-28 14:26:00 +00:00
|
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
|
|
* found in the LICENSE file.
|
2010-02-12 17:17:10 +00:00
|
|
|
*/
|
|
|
|
|
2011-07-28 14:26:00 +00:00
|
|
|
|
2010-02-12 17:17:10 +00:00
|
|
|
#ifndef SkLayer_DEFINED
|
|
|
|
#define SkLayer_DEFINED
|
|
|
|
|
|
|
|
#include "SkRefCnt.h"
|
|
|
|
#include "SkTDArray.h"
|
|
|
|
#include "SkColor.h"
|
2010-02-18 19:32:03 +00:00
|
|
|
#include "SkMatrix.h"
|
2010-02-12 17:17:10 +00:00
|
|
|
#include "SkPoint.h"
|
|
|
|
#include "SkRect.h"
|
|
|
|
#include "SkSize.h"
|
|
|
|
|
|
|
|
class SkCanvas;
|
|
|
|
|
|
|
|
class SkLayer : public SkRefCnt {
|
|
|
|
|
|
|
|
public:
|
2015-06-26 18:45:03 +00:00
|
|
|
|
2012-08-16 14:58:06 +00:00
|
|
|
|
2010-02-12 17:17:10 +00:00
|
|
|
SkLayer();
|
|
|
|
SkLayer(const SkLayer&);
|
|
|
|
virtual ~SkLayer();
|
|
|
|
|
2010-03-23 20:10:46 +00:00
|
|
|
bool isInheritFromRootTransform() const;
|
2010-02-18 19:32:03 +00:00
|
|
|
SkScalar getOpacity() const { return m_opacity; }
|
2010-02-19 21:41:30 +00:00
|
|
|
const SkSize& getSize() const { return m_size; }
|
2010-02-18 19:32:03 +00:00
|
|
|
const SkPoint& getPosition() const { return m_position; }
|
|
|
|
const SkPoint& getAnchorPoint() const { return m_anchorPoint; }
|
2010-02-19 21:41:30 +00:00
|
|
|
const SkMatrix& getMatrix() const { return fMatrix; }
|
|
|
|
const SkMatrix& getChildrenMatrix() const { return fChildrenMatrix; }
|
2010-02-18 19:32:03 +00:00
|
|
|
|
2010-02-19 21:41:30 +00:00
|
|
|
SkScalar getWidth() const { return m_size.width(); }
|
|
|
|
SkScalar getHeight() const { return m_size.height(); }
|
2010-02-12 17:17:10 +00:00
|
|
|
|
2010-03-23 20:10:46 +00:00
|
|
|
void setInheritFromRootTransform(bool);
|
2010-02-19 21:41:30 +00:00
|
|
|
void setOpacity(SkScalar opacity) { m_opacity = opacity; }
|
|
|
|
void setSize(SkScalar w, SkScalar h) { m_size.set(w, h); }
|
|
|
|
void setPosition(SkScalar x, SkScalar y) { m_position.set(x, y); }
|
|
|
|
void setAnchorPoint(SkScalar x, SkScalar y) { m_anchorPoint.set(x, y); }
|
2010-02-18 19:32:03 +00:00
|
|
|
void setMatrix(const SkMatrix&);
|
|
|
|
void setChildrenMatrix(const SkMatrix&);
|
2010-02-12 17:17:10 +00:00
|
|
|
|
|
|
|
// children
|
|
|
|
|
2010-02-24 17:16:35 +00:00
|
|
|
/** Return the number of layers in our child list.
|
|
|
|
*/
|
2010-02-12 17:17:10 +00:00
|
|
|
int countChildren() const;
|
2010-02-24 17:16:35 +00:00
|
|
|
|
|
|
|
/** Return the child at the specified index (starting at 0). This does not
|
|
|
|
affect the reference count of the child.
|
|
|
|
*/
|
2010-02-12 17:17:10 +00:00
|
|
|
SkLayer* getChild(int index) const;
|
2010-02-24 17:16:35 +00:00
|
|
|
|
|
|
|
/** Add this layer to our child list at the end (top-most), and ref() it.
|
|
|
|
If it was already in another hierarchy, remove it from that list.
|
|
|
|
Return the new child.
|
|
|
|
*/
|
2010-02-12 17:17:10 +00:00
|
|
|
SkLayer* addChild(SkLayer* child);
|
2010-02-24 17:16:35 +00:00
|
|
|
|
2010-03-23 20:10:46 +00:00
|
|
|
/** Remove this layer from its parent's list (or do nothing if it has no
|
|
|
|
parent.) If it had a parent, then unref() is called.
|
2010-02-24 17:16:35 +00:00
|
|
|
*/
|
2010-03-23 20:10:46 +00:00
|
|
|
void detachFromParent();
|
2010-02-24 17:16:35 +00:00
|
|
|
|
|
|
|
/** Remove, and unref(), all of the layers in our child list.
|
|
|
|
*/
|
2010-02-12 17:17:10 +00:00
|
|
|
void removeChildren();
|
|
|
|
|
2010-02-24 17:16:35 +00:00
|
|
|
/** Return our parent layer, or NULL if we have none.
|
|
|
|
*/
|
|
|
|
SkLayer* getParent() const { return fParent; }
|
|
|
|
|
|
|
|
/** Return the root layer in this hiearchy. If this layer is the root
|
|
|
|
(i.e. has no parent), then this returns itself.
|
|
|
|
*/
|
|
|
|
SkLayer* getRootLayer() const;
|
|
|
|
|
|
|
|
// coordinate system transformations
|
|
|
|
|
|
|
|
/** Return, in matrix, the matix transfomations that are applied locally
|
|
|
|
when this layer draws (i.e. its position and matrix/anchorPoint).
|
|
|
|
This does not include the childrenMatrix, since that is only applied
|
|
|
|
after this layer draws (but before its children draw).
|
|
|
|
*/
|
|
|
|
void getLocalTransform(SkMatrix* matrix) const;
|
|
|
|
|
|
|
|
/** Return, in matrix, the concatenation of transforms that are applied
|
|
|
|
from this layer's root parent to the layer itself.
|
|
|
|
This is the matrix that is applied to the layer during drawing.
|
|
|
|
*/
|
|
|
|
void localToGlobal(SkMatrix* matrix) const;
|
|
|
|
|
2010-02-12 17:17:10 +00:00
|
|
|
// paint method
|
|
|
|
|
2010-02-19 21:41:30 +00:00
|
|
|
void draw(SkCanvas*, SkScalar opacity);
|
|
|
|
void draw(SkCanvas* canvas) {
|
|
|
|
this->draw(canvas, SK_Scalar1);
|
|
|
|
}
|
2010-02-18 19:32:03 +00:00
|
|
|
|
|
|
|
protected:
|
2010-02-19 21:41:30 +00:00
|
|
|
virtual void onDraw(SkCanvas*, SkScalar opacity);
|
2010-02-18 19:32:03 +00:00
|
|
|
|
|
|
|
private:
|
2010-03-23 20:10:46 +00:00
|
|
|
enum Flags {
|
|
|
|
kInheritFromRootTransform_Flag = 0x01
|
|
|
|
};
|
|
|
|
|
2010-02-24 17:16:35 +00:00
|
|
|
SkLayer* fParent;
|
2010-02-19 21:41:30 +00:00
|
|
|
SkScalar m_opacity;
|
|
|
|
SkSize m_size;
|
|
|
|
SkPoint m_position;
|
|
|
|
SkPoint m_anchorPoint;
|
2010-02-18 19:32:03 +00:00
|
|
|
SkMatrix fMatrix;
|
|
|
|
SkMatrix fChildrenMatrix;
|
2010-03-23 20:10:46 +00:00
|
|
|
uint32_t fFlags;
|
2010-02-12 17:17:10 +00:00
|
|
|
|
|
|
|
SkTDArray<SkLayer*> m_children;
|
2011-01-25 19:05:12 +00:00
|
|
|
|
|
|
|
typedef SkRefCnt INHERITED;
|
2010-02-12 17:17:10 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|