/* * Copyright 2017 Google Inc. * * Use of this source code is governed by a BSD-style license that can be * found in the LICENSE file. */ #include "GrClearOp.h" #include "GrGpuCommandBuffer.h" #include "GrMemoryPool.h" #include "GrOpFlushState.h" #include "GrProxyProvider.h" #include "GrRecordingContext.h" #include "GrRecordingContextPriv.h" std::unique_ptr GrClearOp::Make(GrRecordingContext* context, const GrFixedClip& clip, const SkPMColor4f& color, GrSurfaceProxy* dstProxy) { const SkIRect rect = SkIRect::MakeWH(dstProxy->width(), dstProxy->height()); if (clip.scissorEnabled() && !SkIRect::Intersects(clip.scissorRect(), rect)) { return nullptr; } GrOpMemoryPool* pool = context->priv().opMemoryPool(); return pool->allocate(clip, color, dstProxy); } std::unique_ptr GrClearOp::Make(GrRecordingContext* context, const SkIRect& rect, const SkPMColor4f& color, bool fullScreen) { SkASSERT(fullScreen || !rect.isEmpty()); GrOpMemoryPool* pool = context->priv().opMemoryPool(); return pool->allocate(rect, color, fullScreen); } GrClearOp::GrClearOp(const GrFixedClip& clip, const SkPMColor4f& color, GrSurfaceProxy* proxy) : INHERITED(ClassID()) , fClip(clip) , fColor(color) { const SkIRect rtRect = SkIRect::MakeWH(proxy->width(), proxy->height()); if (fClip.scissorEnabled()) { // Don't let scissors extend outside the RT. This may improve op combining. if (!fClip.intersect(rtRect)) { SkASSERT(0); // should be caught upstream fClip = GrFixedClip(SkIRect::MakeEmpty()); } if (GrProxyProvider::IsFunctionallyExact(proxy) && fClip.scissorRect() == rtRect) { fClip.disableScissor(); } } this->setBounds(SkRect::Make(fClip.scissorEnabled() ? fClip.scissorRect() : rtRect), HasAABloat::kNo, IsZeroArea::kNo); } void GrClearOp::onExecute(GrOpFlushState* state, const SkRect& chainBounds) { SkASSERT(state->rtCommandBuffer()); state->rtCommandBuffer()->clear(fClip, fColor); }