Index: ppapi/native_client/tests/ppapi_simple_tests/graphics2d.cc |
=================================================================== |
--- ppapi/native_client/tests/ppapi_simple_tests/graphics2d.cc (revision 0) |
+++ ppapi/native_client/tests/ppapi_simple_tests/graphics2d.cc (revision 0) |
@@ -0,0 +1,104 @@ |
+// Copyright (c) 2011 The Native Client 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 <stdint.h> |
+ |
+#include <cmath> |
+#include <limits> |
+#include <string> |
+ |
+#include <nacl/nacl_check.h> |
+#include <nacl/nacl_log.h> |
+ |
+#include "ppapi/c/pp_rect.h" |
+#include "ppapi/c/pp_bool.h" |
+#include "ppapi/c/pp_errors.h" |
+#include "ppapi/cpp/rect.h" |
+#include "ppapi/cpp/graphics_2d.h" |
+#include "ppapi/cpp/image_data.h" |
+#include "ppapi/cpp/completion_callback.h" |
+#include "ppapi/cpp/instance.h" |
+#include "ppapi/cpp/module.h" |
+ |
+const uint32_t kDefaultColor = 0x2266aa; |
+ |
+void FillRect(pp::ImageData* image, int left, int top, int width, int height, |
+ uint32_t color) { |
+ for (int y = std::max(0, top); |
+ y < std::min(image->size().height() - 1, top + height); |
+ y++) { |
+ for (int x = std::max(0, left); |
+ x < std::min(image->size().width() - 1, left + width); |
+ x++) |
+ *image->GetAddr32(pp::Point(x, y)) = color; |
+ } |
+} |
+ |
+class MyInstance : public pp::Instance { |
+ private: |
+ uint32_t color_; |
+ pp::Size size_; |
+ pp::Graphics2D device_context_; |
+ |
+ void ParseArgs(uint32_t argc, const char* argn[], const char* argv[]) { |
+ for (uint32_t i = 0; i < argc; ++i) { |
+ const std::string tag = argn[i]; |
+ if (tag == "color") color_ = strtol(argv[i], 0, 0); |
+ } |
+ } |
+ |
+ static void FlushCallback(void* thiz, int32_t result) { |
+ // If necessary we can get at the instabce like so: |
+ // MyInstance* instance = static_cast<MyInstance*>(thiz); |
+ } |
+ |
+ public: |
+ explicit MyInstance(PP_Instance instance) |
+ : pp::Instance(instance), color_(kDefaultColor), size_(0, 0) {} |
+ |
+ virtual bool Init(uint32_t argc, const char* argn[], const char* argv[]) { |
+ ParseArgs(argc, argn, argv); |
+ return true; |
+ } |
+ |
+ virtual void DidChangeView(const pp::Rect& position, const pp::Rect& clip) { |
+ if (position.size().width() == size_.width() && |
+ position.size().height() == size_.height()) { |
+ // No change. We don't care about the position, only the size. |
+ return; |
+ } |
+ |
+ device_context_ = pp::Graphics2D(this, position.size(), false); |
+ CHECK(BindGraphics(device_context_)); |
+ size_ = position.size(); |
+ |
+ pp::ImageData image(this, PP_IMAGEDATAFORMAT_BGRA_PREMUL, size_, true); |
+ CHECK(!image.is_null()); |
+ FillRect(&image, 0, 0, size_.width(), size_.height(), color_); |
+ |
+ device_context_.ReplaceContents(&image); |
+ pp::CompletionCallback cc(FlushCallback, this); |
+ |
+ device_context_.Flush(cc); |
+ } |
+}; |
+ |
+ |
+class MyModule : public pp::Module { |
+ public: |
+ // Override CreateInstance to create your customized Instance object. |
+ virtual pp::Instance* CreateInstance(PP_Instance instance) { |
+ return new MyInstance(instance); |
+ } |
+}; |
+ |
+namespace pp { |
+ |
+// Factory function for your specialization of the Module object. |
+Module* CreateModule() { |
+ return new MyModule(); |
+} |
+ |
+} // namespace pp |