/* * Copyright 2012 Google Inc. * * Use of this source code is governed by a BSD-style license that can be * found in the LICENSE file. */ #ifndef GrReducedClip_DEFINED #define GrReducedClip_DEFINED #include "SkClipStack.h" #include "SkTLList.h" class SK_API GrReducedClip { public: typedef SkTLList<SkClipStack::Element, 16> ElementList; enum InitialState { kAllIn_InitialState, kAllOut_InitialState, }; /** * This function takes a clip stack and a query rectangle and it produces a * reduced set of SkClipStack::Elements that are equivalent to applying the * full stack to the rectangle. The clip stack generation id that represents * the list of elements is returned in resultGenID. The initial state of the * query rectangle before the first clip element is applied is returned via * initialState. Optionally, the caller can request a tighter bounds on the * clip be returned via tighterBounds. If not nullptr, tighterBounds will * always be contained by queryBounds after return. If tighterBounds is * specified then it is assumed that the caller will implicitly clip against * it. If the caller specifies non-nullptr for requiresAA then it will indicate * whether anti-aliasing is required to process any of the elements in the * result. * * This may become a member function of SkClipStack when its interface is * determined to be stable. */ static void ReduceClipStack(const SkClipStack& stack, const SkIRect& queryBounds, ElementList* result, int32_t* resultGenID, InitialState* initialState, SkIRect* tighterBounds = nullptr, bool* requiresAA = nullptr); }; #endif