Index: gpu/demos/app_framework/application.cc |
=================================================================== |
--- gpu/demos/app_framework/application.cc (revision 0) |
+++ gpu/demos/app_framework/application.cc (revision 0) |
@@ -0,0 +1,161 @@ |
+// Copyright (c) 2006-2009 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 "gpu/demos/app_framework/application.h" |
+ |
+#include "gpu/command_buffer/client/gles2_implementation.h" |
+#include "gpu/command_buffer/client/gles2_lib.h" |
+#include "gpu/command_buffer/service/command_buffer_service.h" |
+#include "gpu/command_buffer/service/gpu_processor.h" |
+ |
+using gpu::Buffer; |
+using gpu::CommandBufferService; |
+using gpu::GPUProcessor; |
+using gpu::gles2::GLES2CmdHelper; |
+using gpu::gles2::GLES2Implementation; |
+ |
+// TODO(alokp): Implement it on mac and linux when gpu process is functional |
+// on these OS'. |
+#if defined(OS_WIN) |
+namespace { |
+static const int32 kCommandBufferSize = 1024 * 1024; |
+static const int32 kTransferBufferSize = 512 * 1024; |
+ |
+static LRESULT CALLBACK WindowProc(HWND hwnd, UINT msg, |
+ WPARAM w_param, LPARAM l_param) { |
+ LRESULT result = 0; |
+ switch (msg) { |
+ case WM_CLOSE: |
+ ::DestroyWindow(hwnd); |
+ break; |
+ case WM_DESTROY: |
+ ::PostQuitMessage(0); |
+ break; |
+ case WM_PAINT: { |
+ using gpu_demos::Application; |
+ Application* app = reinterpret_cast<Application*>( |
+ GetWindowLongPtr(hwnd, GWL_USERDATA)); |
+ if (app != NULL) app->OnPaint(); |
+ ::ValidateRect(hwnd, NULL); |
+ break; |
+ } |
+ default: |
+ result = ::DefWindowProc(hwnd, msg, w_param, l_param); |
+ break; |
+ } |
+ return result; |
+} |
+} // namespace. |
+ |
+namespace gpu_demos { |
+ |
+Application::Application() |
+ : width_(512), |
+ height_(512), |
+ window_handle_(NULL) { |
+} |
+ |
+Application::~Application() { |
+} |
+ |
+void Application::MainLoop() { |
+ MSG msg; |
+ bool done = false; |
+ while (!done) { |
+ while (PeekMessage(&msg, NULL, 0, 0, PM_REMOVE)) { |
+ if (msg.message == WM_QUIT) done = true; |
+ TranslateMessage(&msg); |
+ DispatchMessage(&msg); |
+ } |
+ // Message queue is empty and application has not quit yet - keep painting. |
+ if (!done) SendMessage(window_handle_, WM_PAINT, 0, 0); |
+ } |
+} |
+ |
+void Application::OnPaint() { |
+ Draw(); |
+ gles2::GetGLContext()->SwapBuffers(); |
+} |
+ |
+bool Application::InitRenderContext() { |
+ window_handle_ = CreateNativeWindow(); |
+ if (window_handle_ == NULL) { |
+ return false; |
+ } |
+ |
+ scoped_ptr<CommandBufferService> command_buffer(new CommandBufferService); |
+ if (!command_buffer->Initialize(kCommandBufferSize)) { |
+ return false; |
+ } |
+ |
+ scoped_refptr<GPUProcessor> gpu_processor( |
+ new GPUProcessor(command_buffer.get())); |
+ if (!gpu_processor->Initialize(window_handle_)) { |
+ return false; |
+ } |
+ |
+ command_buffer->SetPutOffsetChangeCallback( |
+ NewCallback(gpu_processor.get(), &GPUProcessor::ProcessCommands)); |
+ |
+ GLES2CmdHelper* helper = new GLES2CmdHelper(command_buffer.get()); |
+ if (!helper->Initialize()) { |
+ // TODO(alokp): cleanup. |
+ return false; |
+ } |
+ |
+ int32 transfer_buffer_id = |
+ command_buffer->CreateTransferBuffer(kTransferBufferSize); |
+ Buffer transfer_buffer = |
+ command_buffer->GetTransferBuffer(transfer_buffer_id); |
+ if (transfer_buffer.ptr == NULL) return false; |
+ |
+ gles2::g_gl_impl = new GLES2Implementation(helper, |
+ transfer_buffer.size, |
+ transfer_buffer.ptr, |
+ transfer_buffer_id); |
+ |
+ return command_buffer.release() != NULL; |
+} |
+ |
+NativeWindowHandle Application::CreateNativeWindow() { |
+ WNDCLASS wnd_class = {0}; |
+ HINSTANCE instance = GetModuleHandle(NULL); |
+ wnd_class.style = CS_OWNDC; |
+ wnd_class.lpfnWndProc = (WNDPROC)WindowProc; |
+ wnd_class.hInstance = instance; |
+ wnd_class.hbrBackground = (HBRUSH)GetStockObject(BLACK_BRUSH); |
+ wnd_class.lpszClassName = L"opengles2.0"; |
+ if (!RegisterClass(&wnd_class)) return NULL; |
+ |
+ DWORD wnd_style = WS_VISIBLE | WS_POPUP | WS_BORDER | WS_SYSMENU | WS_CAPTION; |
+ RECT wnd_rect; |
+ wnd_rect.left = 0; |
+ wnd_rect.top = 0; |
+ wnd_rect.right = width_; |
+ wnd_rect.bottom = height_; |
+ AdjustWindowRect(&wnd_rect, wnd_style, FALSE); |
+ |
+ HWND hwnd = CreateWindow( |
+ wnd_class.lpszClassName, |
+ wnd_class.lpszClassName, |
+ wnd_style, |
+ 0, |
+ 0, |
+ wnd_rect.right - wnd_rect.left, |
+ wnd_rect.bottom - wnd_rect.top, |
+ NULL, |
+ NULL, |
+ instance, |
+ NULL); |
+ if (hwnd == NULL) return NULL; |
+ |
+ ShowWindow(hwnd, SW_SHOWNORMAL); |
+ // Set this to the GWL_USERDATA so that it is available to WindowProc. |
+ SetWindowLongPtr(hwnd, GWL_USERDATA, (LONG_PTR)this); |
+ |
+ return hwnd; |
+} |
+ |
+} // namespace gpu_demos |
+#endif // defined(OS_WIN) |
Property changes on: gpu\demos\app_framework\application.cc |
___________________________________________________________________ |
Added: svn:eol-style |
+ LF |