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

Unified Diff: src/gpu/batches/GrAAFillRectBatch.cpp

Issue 1353553002: Create append methods in batch namespaces (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: tweaks Created 5 years, 3 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: src/gpu/batches/GrAAFillRectBatch.cpp
diff --git a/src/gpu/batches/GrAAFillRectBatch.cpp b/src/gpu/batches/GrAAFillRectBatch.cpp
index 69fd0ef65bc23325eed5ea5a1cd59148d7887850..4ba9c1822ee315072d31db6b2c4cda85ab771011 100644
--- a/src/gpu/batches/GrAAFillRectBatch.cpp
+++ b/src/gpu/batches/GrAAFillRectBatch.cpp
@@ -199,6 +199,11 @@ public:
static void SetBounds(const Geometry& geo, SkRect* outBounds) {
*outBounds = geo.fDevRect;
}
+
+ template <class Geometry>
+ static void UpdateBounds(const Geometry& geo, SkRect* outBounds) {
+ outBounds->join(geo.fDevRect);
+ }
};
class AAFillRectBatchNoLocalMatrixImp : public AAFillRectBatchBase {
@@ -283,6 +288,26 @@ public:
typedef GrTInstanceBatch<AAFillRectBatchNoLocalMatrixImp> AAFillRectBatchNoLocalMatrix;
typedef GrTInstanceBatch<AAFillRectBatchLocalMatrixImp> AAFillRectBatchLocalMatrix;
robertphillips 2015/09/18 17:42:25 "inline" these to document our hopes & prayers ?
joshualitt 2015/09/18 18:34:10 Acknowledged.
+static void append_to_batch(AAFillRectBatchNoLocalMatrix* batch, GrColor color,
+ const SkMatrix& viewMatrix, const SkRect& rect, const SkRect& devRect) {
+ AAFillRectBatchNoLocalMatrix::Geometry& geo = batch->geoData()->push_back();
+ geo.fColor = color;
+ geo.fViewMatrix = viewMatrix;
+ geo.fRect = rect;
+ geo.fDevRect = devRect;
+}
+
+static void append_to_batch(AAFillRectBatchLocalMatrix* batch, GrColor color,
+ const SkMatrix& viewMatrix, const SkMatrix& localMatrix,
+ const SkRect& rect, const SkRect& devRect) {
+ AAFillRectBatchLocalMatrix::Geometry& geo = batch->geoData()->push_back();
+ geo.fColor = color;
+ geo.fViewMatrix = viewMatrix;
+ geo.fLocalMatrix = localMatrix;
+ geo.fRect = rect;
+ geo.fDevRect = devRect;
+}
+
namespace GrAAFillRectBatch {
GrDrawBatch* Create(GrColor color,
@@ -290,11 +315,7 @@ GrDrawBatch* Create(GrColor color,
const SkRect& rect,
const SkRect& devRect) {
AAFillRectBatchNoLocalMatrix* batch = AAFillRectBatchNoLocalMatrix::Create();
- AAFillRectBatchNoLocalMatrix::Geometry& geo = *batch->geometry();
- geo.fColor = color;
- geo.fViewMatrix = viewMatrix;
- geo.fRect = rect;
- geo.fDevRect = devRect;
+ append_to_batch(batch, color, viewMatrix, rect, devRect);
batch->init();
return batch;
}
@@ -305,16 +326,32 @@ GrDrawBatch* Create(GrColor color,
const SkRect& rect,
const SkRect& devRect) {
AAFillRectBatchLocalMatrix* batch = AAFillRectBatchLocalMatrix::Create();
- AAFillRectBatchLocalMatrix::Geometry& geo = *batch->geometry();
- geo.fColor = color;
- geo.fViewMatrix = viewMatrix;
- geo.fLocalMatrix = localMatrix;
- geo.fRect = rect;
- geo.fDevRect = devRect;
+ append_to_batch(batch, color, viewMatrix, localMatrix, rect, devRect);
batch->init();
return batch;
}
+void Append(GrBatch* origBatch,
+ GrColor color,
+ const SkMatrix& viewMatrix,
+ const SkRect& rect,
+ const SkRect& devRect) {
+ AAFillRectBatchNoLocalMatrix* batch = origBatch->cast<AAFillRectBatchNoLocalMatrix>();
+ append_to_batch(batch, color, viewMatrix, rect, devRect);
+ batch->updateBounds();
+}
+
+void Append(GrBatch* origBatch,
+ GrColor color,
+ const SkMatrix& viewMatrix,
+ const SkMatrix& localMatrix,
+ const SkRect& rect,
+ const SkRect& devRect) {
+ AAFillRectBatchLocalMatrix* batch = origBatch->cast<AAFillRectBatchLocalMatrix>();
+ append_to_batch(batch, color, viewMatrix, localMatrix, rect, devRect);
+ batch->updateBounds();
+}
+
};
///////////////////////////////////////////////////////////////////////////////////////////////////

Powered by Google App Engine
This is Rietveld 408576698