blob: 334e690aaee64c410b2e6969713078e3418ba24d [file] [log] [blame]
// Copyright 2015 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 SERVICES_GFX_COMPOSITOR_RENDER_RENDER_FRAME_H_
#define SERVICES_GFX_COMPOSITOR_RENDER_RENDER_FRAME_H_
#include "base/macros.h"
#include "base/memory/ref_counted.h"
#include "mojo/services/gfx/composition/interfaces/scheduling.mojom.h"
#include "skia/ext/refptr.h"
#include "third_party/skia/include/core/SkRect.h"
class SkCanvas;
class SkPicture;
namespace compositor {
// Describes a frame to be rendered.
//
// Render objects are thread-safe, immutable, and reference counted.
// They have no direct references to the scene graph.
class RenderFrame : public base::RefCountedThreadSafe<RenderFrame> {
public:
// Creates an empty render frame with no content.
RenderFrame(const SkIRect& viewport,
const mojo::gfx::composition::FrameInfo& frame_info);
// Creates render frame backed by a picture.
RenderFrame(const SkIRect& viewport,
const mojo::gfx::composition::FrameInfo& frame_info,
const skia::RefPtr<SkPicture>& picture);
// Gets the frame's viewport in pixels.
const SkIRect& viewport() const { return viewport_; }
// Gets information about the frame to be rendered.
const mojo::gfx::composition::FrameInfo& frame_info() const {
return frame_info_;
}
// Gets the underlying picture to rasterize, or null if the frame is empty.
const skia::RefPtr<SkPicture>& picture() const { return picture_; }
// Paints the frame to a canvas.
void Paint(SkCanvas* canvas) const;
private:
friend class base::RefCountedThreadSafe<RenderFrame>;
friend class RenderFrameBuilder;
~RenderFrame();
SkIRect viewport_;
mojo::gfx::composition::FrameInfo frame_info_;
skia::RefPtr<SkPicture> picture_;
DISALLOW_COPY_AND_ASSIGN(RenderFrame);
};
} // namespace compositor
#endif // SERVICES_GFX_COMPOSITOR_RENDER_RENDER_FRAME_H_