blob: 6f14b936fde195b6e0ad69a599af7ddb7aeac03a [file] [log] [blame]
// Copyright (c) 2012 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.
#include "base/memory/ref_counted.h"
#include "ppapi/c/pp_bool.h"
#include "ppapi/c/pp_completion_callback.h"
#include "ppapi/c/pp_point.h"
#include "ppapi/c/pp_rect.h"
#include "ppapi/c/pp_resource.h"
#include "ppapi/c/pp_size.h"
namespace ppapi {
class TrackedCallback;
namespace thunk {
class PPB_Graphics2D_API {
public:
virtual ~PPB_Graphics2D_API() {}
virtual PP_Bool Describe(PP_Size* size, PP_Bool* is_always_opaque) = 0;
virtual void PaintImageData(PP_Resource image_data,
const PP_Point* top_left,
const PP_Rect* src_rect) = 0;
virtual void Scroll(const PP_Rect* clip_rect,
const PP_Point* amount) = 0;
virtual void ReplaceContents(PP_Resource image_data) = 0;
virtual bool SetScale(float scale) = 0;
virtual float GetScale() = 0;
// When |old_image_data| is non-null and the flush is executing a replace
// contents (which leaves the "old" ImageData unowned), the resource ID of
// the old image data will be placed into |*old_image_data| synchronously
// (not when the flush callback completes).
//
// When this happens, a reference to this resource will be transferred to the
// caller. If there is no replace contents operation, old_image_data will be
// ignored. If |*old_image_data| is null, then the old image data will be
// destroyed if there was one.
virtual int32_t Flush(scoped_refptr<TrackedCallback> callback,
PP_Resource* old_image_data) = 0;
};
} // namespace thunk
} // namespace ppapi