Add initial benchmarks for CanvasOp
Also some minor other tweaks
Test: this
Change-Id: Idb8a5955839893ff000de87d4899fd130ede061c
diff --git a/libs/hwui/canvas/CanvasFrontend.h b/libs/hwui/canvas/CanvasFrontend.h
index 5fccccb..d749d2f 100644
--- a/libs/hwui/canvas/CanvasFrontend.h
+++ b/libs/hwui/canvas/CanvasFrontend.h
@@ -57,9 +57,7 @@
}
bool internalSave(SaveEntry saveEntry);
- bool internalSave(SaveFlags::Flags flags) {
- return internalSave(flagsToSaveEntry(flags));
- }
+
void internalSaveLayer(const SkCanvas::SaveLayerRec& layerRec) {
internalSave({
.clip = true,
@@ -90,6 +88,8 @@
return mClipStack[mCurrentClipIndex];
}
+ void resetState(int width, int height);
+
public:
int saveCount() const { return mSaveStack.size(); }
@@ -186,14 +186,26 @@
submit(std::move(op));
}
- const CanvasOpReceiver& receiver() const { return mReceiver; }
+ const CanvasOpReceiver& receiver() const { return *mReceiver; }
+
+ CanvasOpReceiver finish() {
+ auto ret = std::move(mReceiver.value());
+ mReceiver.reset();
+ return std::move(ret);
+ }
+
+ template<class... Args>
+ void reset(int newWidth, int newHeight, Args&&... args) {
+ resetState(newWidth, newHeight);
+ mReceiver.emplace(std::forward<Args>(args)...);
+ }
private:
- CanvasOpReceiver mReceiver;
+ std::optional<CanvasOpReceiver> mReceiver;
template <CanvasOpType T>
void submit(CanvasOp<T>&& op) {
- mReceiver.push_container(CanvasOpContainer(std::move(op), transform()));
+ mReceiver->push_container(CanvasOpContainer(std::move(op), transform()));
}
};