| /* |
| * 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 |