Expanded PropertyObserver interface to include Node Type
Change-Id: I86b0ab3445f8fe4790492fa1b942c97e3053af9e Reviewed-on: https://skia-review.googlesource.com/c/skia/+/417264 Reviewed-by: Florin Malita <fmalita@google.com> Commit-Queue: Florin Malita <fmalita@google.com>
This commit is contained in:
parent
bc215ba3bb
commit
1907f9051e
@ -119,6 +119,8 @@ using TransformPropertyHandle = PropertyHandle<TransformPropertyValue,
|
|||||||
*/
|
*/
|
||||||
class SK_API PropertyObserver : public SkRefCnt {
|
class SK_API PropertyObserver : public SkRefCnt {
|
||||||
public:
|
public:
|
||||||
|
enum class NodeType {COMPOSITION, LAYER, EFFECT, OTHER};
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
using LazyHandle = std::function<std::unique_ptr<T>()>;
|
using LazyHandle = std::function<std::unique_ptr<T>()>;
|
||||||
|
|
||||||
@ -130,8 +132,8 @@ public:
|
|||||||
const LazyHandle<TextPropertyHandle>&);
|
const LazyHandle<TextPropertyHandle>&);
|
||||||
virtual void onTransformProperty(const char node_name[],
|
virtual void onTransformProperty(const char node_name[],
|
||||||
const LazyHandle<TransformPropertyHandle>&);
|
const LazyHandle<TransformPropertyHandle>&);
|
||||||
virtual void onEnterNode(const char node_name[]);
|
virtual void onEnterNode(const char node_name[], NodeType node_type);
|
||||||
virtual void onLeavingNode(const char node_name[]);
|
virtual void onLeavingNode(const char node_name[], NodeType node_type);
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace skottie
|
} // namespace skottie
|
||||||
|
@ -344,7 +344,7 @@ sk_sp<sksg::Transform> LayerBuilder::getTransform(const AnimationBuilder& abuild
|
|||||||
// Set valid flag upfront to break cycles.
|
// Set valid flag upfront to break cycles.
|
||||||
fFlags |= cache_valid_mask;
|
fFlags |= cache_valid_mask;
|
||||||
|
|
||||||
const AnimationBuilder::AutoPropertyTracker apt(&abuilder, fJlayer);
|
const AnimationBuilder::AutoPropertyTracker apt(&abuilder, fJlayer, PropertyObserver::NodeType::LAYER);
|
||||||
AnimationBuilder::AutoScope ascope(&abuilder, std::move(fLayerScope));
|
AnimationBuilder::AutoScope ascope(&abuilder, std::move(fLayerScope));
|
||||||
fTransformCache[ttype] = this->doAttachTransform(abuilder, cbuilder, ttype);
|
fTransformCache[ttype] = this->doAttachTransform(abuilder, cbuilder, ttype);
|
||||||
fLayerScope = ascope.release();
|
fLayerScope = ascope.release();
|
||||||
@ -410,7 +410,7 @@ bool LayerBuilder::hasMotionBlur(const CompositionBuilder* cbuilder) const {
|
|||||||
sk_sp<sksg::RenderNode> LayerBuilder::buildRenderTree(const AnimationBuilder& abuilder,
|
sk_sp<sksg::RenderNode> LayerBuilder::buildRenderTree(const AnimationBuilder& abuilder,
|
||||||
CompositionBuilder* cbuilder,
|
CompositionBuilder* cbuilder,
|
||||||
const LayerBuilder* prev_layer) {
|
const LayerBuilder* prev_layer) {
|
||||||
const AnimationBuilder::AutoPropertyTracker apt(&abuilder, fJlayer);
|
const AnimationBuilder::AutoPropertyTracker apt(&abuilder, fJlayer, PropertyObserver::NodeType::LAYER);
|
||||||
|
|
||||||
using LayerBuilder =
|
using LayerBuilder =
|
||||||
sk_sp<sksg::RenderNode> (AnimationBuilder::*)(const skjson::ObjectValue&,
|
sk_sp<sksg::RenderNode> (AnimationBuilder::*)(const skjson::ObjectValue&,
|
||||||
|
@ -184,6 +184,7 @@ AnimationBuilder::AnimationInfo AnimationBuilder::parse(const skjson::ObjectValu
|
|||||||
this->parseFonts(jroot["fonts"], jroot["chars"]);
|
this->parseFonts(jroot["fonts"], jroot["chars"]);
|
||||||
|
|
||||||
AutoScope ascope(this);
|
AutoScope ascope(this);
|
||||||
|
AutoPropertyTracker apt(this, jroot, PropertyObserver::NodeType::COMPOSITION);
|
||||||
auto root = CompositionBuilder(*this, fCompSize, jroot).build(*this);
|
auto root = CompositionBuilder(*this, fCompSize, jroot).build(*this);
|
||||||
|
|
||||||
auto animators = ascope.release();
|
auto animators = ascope.release();
|
||||||
|
@ -146,19 +146,19 @@ public:
|
|||||||
|
|
||||||
class AutoPropertyTracker {
|
class AutoPropertyTracker {
|
||||||
public:
|
public:
|
||||||
AutoPropertyTracker(const AnimationBuilder* builder, const skjson::ObjectValue& obj)
|
AutoPropertyTracker(const AnimationBuilder* builder, const skjson::ObjectValue& obj, const PropertyObserver::NodeType node_type)
|
||||||
: fBuilder(builder)
|
: fBuilder(builder)
|
||||||
, fPrevContext(builder->fPropertyObserverContext) {
|
, fPrevContext(builder->fPropertyObserverContext), fNodeType(node_type) {
|
||||||
if (fBuilder->fPropertyObserver) {
|
if (fBuilder->fPropertyObserver) {
|
||||||
auto observer = builder->fPropertyObserver.get();
|
auto observer = builder->fPropertyObserver.get();
|
||||||
this->updateContext(observer, obj);
|
this->updateContext(observer, obj);
|
||||||
observer->onEnterNode(fBuilder->fPropertyObserverContext);
|
observer->onEnterNode(fBuilder->fPropertyObserverContext, fNodeType);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
~AutoPropertyTracker() {
|
~AutoPropertyTracker() {
|
||||||
if (fBuilder->fPropertyObserver) {
|
if (fBuilder->fPropertyObserver) {
|
||||||
fBuilder->fPropertyObserver->onLeavingNode(fBuilder->fPropertyObserverContext);
|
fBuilder->fPropertyObserver->onLeavingNode(fBuilder->fPropertyObserverContext, fNodeType);
|
||||||
fBuilder->fPropertyObserverContext = fPrevContext;
|
fBuilder->fPropertyObserverContext = fPrevContext;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -167,6 +167,7 @@ public:
|
|||||||
|
|
||||||
const AnimationBuilder* fBuilder;
|
const AnimationBuilder* fBuilder;
|
||||||
const char* fPrevContext;
|
const char* fPrevContext;
|
||||||
|
const PropertyObserver::NodeType fNodeType;
|
||||||
};
|
};
|
||||||
|
|
||||||
bool dispatchColorProperty(const sk_sp<sksg::Color>&) const;
|
bool dispatchColorProperty(const sk_sp<sksg::Color>&) const;
|
||||||
|
@ -128,8 +128,8 @@ void PropertyObserver::onTextProperty(const char[],
|
|||||||
void PropertyObserver::onTransformProperty(const char[],
|
void PropertyObserver::onTransformProperty(const char[],
|
||||||
const LazyHandle<TransformPropertyHandle>&) {}
|
const LazyHandle<TransformPropertyHandle>&) {}
|
||||||
|
|
||||||
void PropertyObserver::onEnterNode(const char node_name[]) {}
|
void PropertyObserver::onEnterNode(const char node_name[], NodeType) {}
|
||||||
|
|
||||||
void PropertyObserver::onLeavingNode(const char node_name[]) {}
|
void PropertyObserver::onLeavingNode(const char node_name[], NodeType) {}
|
||||||
|
|
||||||
} // namespace skottie
|
} // namespace skottie
|
||||||
|
@ -173,11 +173,17 @@ DEF_TEST(Skottie_Properties, reporter) {
|
|||||||
fTransforms.push_back({SkString(node_name), lh()});
|
fTransforms.push_back({SkString(node_name), lh()});
|
||||||
}
|
}
|
||||||
|
|
||||||
void onEnterNode(const char node_name[]) override {
|
void onEnterNode(const char node_name[], PropertyObserver::NodeType node_type) override {
|
||||||
|
if (node_name == nullptr) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
fCurrentNode = fCurrentNode.empty() ? node_name : fCurrentNode + "." + node_name;
|
fCurrentNode = fCurrentNode.empty() ? node_name : fCurrentNode + "." + node_name;
|
||||||
}
|
}
|
||||||
|
|
||||||
void onLeavingNode(const char node_name[]) override {
|
void onLeavingNode(const char node_name[], PropertyObserver::NodeType node_type) override {
|
||||||
|
if (node_name == nullptr) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
auto length = strlen(node_name);
|
auto length = strlen(node_name);
|
||||||
fCurrentNode =
|
fCurrentNode =
|
||||||
fCurrentNode.length() > length
|
fCurrentNode.length() > length
|
||||||
|
@ -115,7 +115,7 @@ sk_sp<sksg::RenderNode> EffectBuilder::attachEffects(const skjson::ArrayValue& j
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
const AnimationBuilder::AutoPropertyTracker apt(fBuilder, *jeffect);
|
const AnimationBuilder::AutoPropertyTracker apt(fBuilder, *jeffect, PropertyObserver::NodeType::EFFECT);
|
||||||
layer = (this->*builder)(*jprops, std::move(layer));
|
layer = (this->*builder)(*jprops, std::move(layer));
|
||||||
|
|
||||||
if (!layer) {
|
if (!layer) {
|
||||||
|
@ -233,7 +233,7 @@ sk_sp<sksg::RenderNode> AnimationBuilder::attachShape(const skjson::ArrayValue*
|
|||||||
};
|
};
|
||||||
|
|
||||||
for (auto rec = recs.rbegin(); rec != recs.rend(); ++rec) {
|
for (auto rec = recs.rbegin(); rec != recs.rend(); ++rec) {
|
||||||
const AutoPropertyTracker apt(this, rec->fJson);
|
const AutoPropertyTracker apt(this, rec->fJson, PropertyObserver::NodeType::OTHER);
|
||||||
|
|
||||||
switch (rec->fInfo.fShapeType) {
|
switch (rec->fInfo.fShapeType) {
|
||||||
case ShapeType::kGeometry: {
|
case ShapeType::kGeometry: {
|
||||||
@ -328,7 +328,7 @@ sk_sp<sksg::RenderNode> AnimationBuilder::attachShape(const skjson::ArrayValue*
|
|||||||
|
|
||||||
sk_sp<sksg::Transform> shape_transform;
|
sk_sp<sksg::Transform> shape_transform;
|
||||||
if (jtransform) {
|
if (jtransform) {
|
||||||
const AutoPropertyTracker apt(this, *jtransform);
|
const AutoPropertyTracker apt(this, *jtransform, PropertyObserver::NodeType::OTHER);
|
||||||
|
|
||||||
// This is tricky due to the interaction with ctx->fCommittedAnimators: we want any
|
// This is tricky due to the interaction with ctx->fCommittedAnimators: we want any
|
||||||
// animators related to tranform/opacity to be committed => they must be inserted in front
|
// animators related to tranform/opacity to be committed => they must be inserted in front
|
||||||
|
@ -45,12 +45,18 @@ public:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void onEnterNode(const char node_name[]) override {
|
void onEnterNode(const char node_name[], PropertyObserver::NodeType node_type) override {
|
||||||
|
if (node_name == nullptr) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
fMgr->fCurrentNode =
|
fMgr->fCurrentNode =
|
||||||
fMgr->fCurrentNode.empty() ? node_name : fMgr->fCurrentNode + "." + node_name;
|
fMgr->fCurrentNode.empty() ? node_name : fMgr->fCurrentNode + "." + node_name;
|
||||||
}
|
}
|
||||||
|
|
||||||
void onLeavingNode(const char node_name[]) override {
|
void onLeavingNode(const char node_name[], PropertyObserver::NodeType node_type) override {
|
||||||
|
if (node_name == nullptr) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
auto length = strlen(node_name);
|
auto length = strlen(node_name);
|
||||||
fMgr->fCurrentNode =
|
fMgr->fCurrentNode =
|
||||||
fMgr->fCurrentNode.length() > length
|
fMgr->fCurrentNode.length() > length
|
||||||
|
Loading…
Reference in New Issue
Block a user