// Copyright 2014 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_OZONE_PUBLIC_SURFACE_OZONE_CANVAS_H_
#define UI_OZONE_PUBLIC_SURFACE_OZONE_CANVAS_H_
#include "base/basictypes.h"
#include "base/memory/scoped_ptr.h"
#include "skia/ext/refptr.h"
#include "ui/ozone/ozone_base_export.h"
class SkCanvas;
namespace gfx {
class Size;
class VSyncProvider;
}
namespace ui {
// The platform-specific part of an software output. The class is intended
// for use when no EGL/GLES2 acceleration is possible.
// This class owns any bits that the ozone implementation needs freed when
// the software output is destroyed.
class OZONE_BASE_EXPORT SurfaceOzoneCanvas {
public:
virtual ~SurfaceOzoneCanvas() {}
// Returns an SkCanvas for drawing on the window.
virtual skia::RefPtr<SkCanvas> GetCanvas() = 0;
// Attempts to resize the canvas to match the viewport size. After
// resizing, the compositor must call GetCanvas() to get the next
// canvas - this invalidates any previous canvas from GetCanvas().
virtual void ResizeCanvas(const gfx::Size& viewport_size) = 0;
// Present the current canvas. After presenting, the compositor must
// call GetCanvas() to get the next canvas - this invalidates any
// previous canvas from GetCanvas().
//
// The implementation may assume that any pixels outside the damage
// rectangle are unchanged since the previous call to PresentCanvas().
virtual void PresentCanvas(const gfx::Rect& damage) = 0;
// Returns a gfx::VsyncProvider for this surface. Note that this may be
// called after we have entered the sandbox so if there are operations (e.g.
// opening a file descriptor providing vsync events) that must be done
// outside of the sandbox, they must have been completed in
// InitializeHardware. Returns an empty scoped_ptr on error.
virtual scoped_ptr<gfx::VSyncProvider> CreateVSyncProvider() = 0;
};
} // namespace ui
#endif // UI_OZONE_PUBLIC_SURFACE_OZONE_CANVAS_H_