| Index: ui/views/paint_info.h
|
| diff --git a/ui/views/paint_info.h b/ui/views/paint_info.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..8545f04e959ac36045852c756c49018ccd9e1777
|
| --- /dev/null
|
| +++ b/ui/views/paint_info.h
|
| @@ -0,0 +1,119 @@
|
| +// Copyright 2017 The Chromium Authors. All rights reserved.
|
| +// Use of this source code is governed by a BSD-style license that can be
|
| +// found in the LICENSE file.
|
| +
|
| +#ifndef UI_VIEWS_PAINT_INFO_H_
|
| +#define UI_VIEWS_PAINT_INFO_H_
|
| +
|
| +#include "ui/compositor/paint_context.h"
|
| +#include "ui/gfx/geometry/rect.h"
|
| +#include "ui/views/views_export.h"
|
| +
|
| +namespace views {
|
| +
|
| +// This class manages the context required during View::Paint(). It is
|
| +// responsible for setting the paint recording size and the paint recording
|
| +// scale factors for an individual View.
|
| +// Each PaintInfo instance has paint recording offset relative to a root
|
| +// PaintInfo.
|
| +// All coordinates are in paint recording space. If pixel canvas is enabled this
|
| +// essentially becomes pixel coordinate space.
|
| +class VIEWS_EXPORT PaintInfo {
|
| + public:
|
| + enum class ScaleType {
|
| + // Scale the recordings by the default dsf. Use this if you don't want any
|
| + // form of distortion during scaling.
|
| + kScaleToScaleFactor = 0,
|
| +
|
| + // Scale the recordings based on the effective dsf. This may lead to minor
|
| + // distortion during scaling due to edge snapping.
|
| + kScaleToFit
|
| + };
|
| +
|
| + // Instantiates a root PaintInfo. This should only be initialized at the Paint
|
| + // root, ie., a layer or the root of a widget.
|
| + static PaintInfo CreateRootPaintInfo(const ui::PaintContext& root_context,
|
| + const gfx::Size& size);
|
| +
|
| + // Instantiate a child PaintInfo instance. All bounds for this object are
|
| + // relative to its root PaintInfo.
|
| + static PaintInfo CreateChildPaintInfo(const PaintInfo& parent_paint_info,
|
| + const gfx::Rect& bounds,
|
| + const gfx::Size& parent_size,
|
| + ScaleType scale_type);
|
| +
|
| + // Clones a given paint info, |other|, without the invalidation from its
|
| + // PaintContext.
|
| + static PaintInfo ClonePaintInfo(const PaintInfo& other);
|
| +
|
| + PaintInfo(const PaintInfo& other);
|
| + ~PaintInfo();
|
| +
|
| + // Returns true if all paint commands are recorded at pixel size.
|
| + bool IsPixelCanvas() const;
|
| +
|
| + const ui::PaintContext& context() const {
|
| + return root_context_ ? *root_context_ : context_;
|
| + }
|
| +
|
| + gfx::Vector2d offset_from_root() const {
|
| + return paint_recording_bounds_.OffsetFromOrigin();
|
| + }
|
| +
|
| + const gfx::Vector2d& offset_from_parent() const {
|
| + return offset_from_parent_;
|
| + }
|
| +
|
| + float paint_recording_scale_x() const { return paint_recording_scale_x_; }
|
| +
|
| + float paint_recording_scale_y() const { return paint_recording_scale_y_; }
|
| +
|
| + const gfx::Size& paint_recording_size() const {
|
| + return paint_recording_bounds_.size();
|
| + }
|
| +
|
| + const gfx::Rect& paint_recording_bounds() const {
|
| + return paint_recording_bounds_;
|
| + }
|
| +
|
| + private:
|
| + friend class PaintInfoTest;
|
| +
|
| + PaintInfo(const ui::PaintContext& root_context, const gfx::Size& size);
|
| + PaintInfo(const PaintInfo& parent_paint_info,
|
| + const gfx::Rect& bounds,
|
| + const gfx::Size& parent_size,
|
| + ScaleType scale_type);
|
| + PaintInfo(const PaintInfo& other,
|
| + ui::PaintContext::CloneWithoutInvalidation c);
|
| +
|
| + // Scales the |child_bounds| to its recording bounds based on the
|
| + // |context.device_scale_factor()|. The recording bounds are snapped to the
|
| + // parent's right and/or bottom edge if required.
|
| + // If pixel canvas is disabled, this function returns |child_bounds| as is.
|
| + gfx::Rect GetSnappedRecordingBounds(const gfx::Size& parent_size,
|
| + const gfx::Rect& child_bounds) const;
|
| +
|
| + // The scale at which the paint commands are recorded at. Due to the decimal
|
| + // rounding and snapping to edges during the scale operation, the effective
|
| + // paint recording scale may end up being slightly different between the x and
|
| + // y axis.
|
| + float paint_recording_scale_x_;
|
| + float paint_recording_scale_y_;
|
| +
|
| + // Paint Recording bounds of the view. The offset is relative to the root
|
| + // PaintInfo.
|
| + const gfx::Rect paint_recording_bounds_;
|
| +
|
| + // Offset relative to the parent view's paint recording bounds. Returns 0
|
| + // offset if this is the root.
|
| + gfx::Vector2d offset_from_parent_;
|
| +
|
| + // Compositor PaintContext associated with the view this object belongs to.
|
| + ui::PaintContext context_;
|
| + const ui::PaintContext* root_context_;
|
| +};
|
| +
|
| +} // namespace views
|
| +
|
| +#endif // UI_VIEWS_PAINT_INFO_H_
|
|
|