blob: 6f5d8e5c5f437a36976909472fc90fbf5d8cba56 [file] [log] [blame]
// Copyright 2025 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CC_LAYERS_APPEND_QUADS_CONTEXT_H_
#define CC_LAYERS_APPEND_QUADS_CONTEXT_H_
#include "base/containers/flat_set.h"
#include "cc/cc_export.h"
#include "cc/layers/draw_mode.h"
#include "third_party/blink/public/common/tokens/tokens.h"
namespace cc {
struct CC_EXPORT AppendQuadsContext {
AppendQuadsContext();
AppendQuadsContext(
DrawMode draw_mode,
base::flat_set<blink::ViewTransitionToken> capture_view_transition_tokens,
bool for_view_transition_capture);
~AppendQuadsContext();
// The draw mode used.
DrawMode draw_mode = DRAW_MODE_NONE;
// A set of all view transition tokens in the capture phase.
// During view transition capture phase, the transitions that are in this
// state (as indicated by these tokens) are treated differently from other
// view transitions. Specifically, the capture phase generates two render
// passes -- one for capture which isn't displayed and one for display. The
// reason this is important is that the captured render passes are filtered
// to exclude ancestor clips as well as nested view transiiton elements,
// which may not be appropriate for display. Note that this is only set if
// ViewTransitionCaptureAndDisplay feature is enabled.
base::flat_set<blink::ViewTransitionToken> capture_view_transition_tokens;
// In separate render pass appends, this indicates whether we're appending for
// view transition capture or for display
bool for_view_transition_capture = false;
};
} // namespace cc
#endif // CC_LAYERS_APPEND_QUADS_CONTEXT_H_