// 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 callback, PP_Resource* old_image_data) = 0; }; } // namespace thunk } // namespace ppapi