| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (c) 2010, Google Inc. All rights reserved. | 2 * Copyright (c) 2010, Google Inc. All rights reserved. |
| 3 * | 3 * |
| 4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
| 5 * modification, are permitted provided that the following conditions are | 5 * modification, are permitted provided that the following conditions are |
| 6 * met: | 6 * met: |
| 7 * | 7 * |
| 8 * * Redistributions of source code must retain the above copyright | 8 * * Redistributions of source code must retain the above copyright |
| 9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
| 10 * * Redistributions in binary form must reproduce the above | 10 * * Redistributions in binary form must reproduce the above |
| (...skipping 18 matching lines...) Expand all Loading... |
| 29 */ | 29 */ |
| 30 | 30 |
| 31 #include "config.h" | 31 #include "config.h" |
| 32 | 32 |
| 33 #include "core/platform/graphics/gpu/DrawingBuffer.h" | 33 #include "core/platform/graphics/gpu/DrawingBuffer.h" |
| 34 | 34 |
| 35 #include <algorithm> | 35 #include <algorithm> |
| 36 #include "core/html/ImageData.h" | 36 #include "core/html/ImageData.h" |
| 37 #include "core/html/canvas/CanvasRenderingContext.h" | 37 #include "core/html/canvas/CanvasRenderingContext.h" |
| 38 #include "core/platform/chromium/TraceEvent.h" | 38 #include "core/platform/chromium/TraceEvent.h" |
| 39 #include "core/platform/chromium/support/GraphicsContext3DPrivate.h" | |
| 40 #include "core/platform/graphics/Extensions3D.h" | 39 #include "core/platform/graphics/Extensions3D.h" |
| 41 #include "core/platform/graphics/GraphicsContext3D.h" | 40 #include "core/platform/graphics/GraphicsContext3D.h" |
| 42 #include "core/platform/graphics/chromium/GraphicsLayerChromium.h" | 41 #include "core/platform/graphics/chromium/GraphicsLayerChromium.h" |
| 43 #include <public/Platform.h> | 42 #include <public/Platform.h> |
| 44 #include <public/WebCompositorSupport.h> | 43 #include <public/WebCompositorSupport.h> |
| 45 #include <public/WebExternalTextureLayer.h> | 44 #include <public/WebExternalTextureLayer.h> |
| 46 #include <public/WebGraphicsContext3D.h> | 45 #include <public/WebGraphicsContext3D.h> |
| 47 | 46 |
| 48 using namespace std; | 47 using namespace std; |
| 49 | 48 |
| (...skipping 120 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 170 if (requiresCopyFromBackToFrontBuffer()) | 169 if (requiresCopyFromBackToFrontBuffer()) |
| 171 updater.appendCopy(colorBuffer(), textureId, size()); | 170 updater.appendCopy(colorBuffer(), textureId, size()); |
| 172 | 171 |
| 173 return textureId; | 172 return textureId; |
| 174 } | 173 } |
| 175 | 174 |
| 176 WebKit::WebGraphicsContext3D* DrawingBuffer::context() | 175 WebKit::WebGraphicsContext3D* DrawingBuffer::context() |
| 177 { | 176 { |
| 178 if (!m_context) | 177 if (!m_context) |
| 179 return 0; | 178 return 0; |
| 180 return GraphicsContext3DPrivate::extractWebGraphicsContext3D(m_context.get()
); | 179 return m_context->webContext(); |
| 181 } | 180 } |
| 182 | 181 |
| 183 bool DrawingBuffer::prepareMailbox(WebKit::WebExternalTextureMailbox* outMailbox
) | 182 bool DrawingBuffer::prepareMailbox(WebKit::WebExternalTextureMailbox* outMailbox
) |
| 184 { | 183 { |
| 185 if (!m_context || !m_contentsChanged || !m_lastColorBuffer) | 184 if (!m_context || !m_contentsChanged || !m_lastColorBuffer) |
| 186 return false; | 185 return false; |
| 187 | 186 |
| 188 m_context->makeContextCurrent(); | 187 m_context->makeContextCurrent(); |
| 189 | 188 |
| 190 // Resolve the multisampled buffer into the texture referenced by m_lastColo
rBuffer mailbox. | 189 // Resolve the multisampled buffer into the texture referenced by m_lastColo
rBuffer mailbox. |
| (...skipping 627 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 818 | 817 |
| 819 void DrawingBuffer::bind() | 818 void DrawingBuffer::bind() |
| 820 { | 819 { |
| 821 if (!m_context) | 820 if (!m_context) |
| 822 return; | 821 return; |
| 823 | 822 |
| 824 m_context->bindFramebuffer(GraphicsContext3D::FRAMEBUFFER, m_multisampleFBO
? m_multisampleFBO : m_fbo); | 823 m_context->bindFramebuffer(GraphicsContext3D::FRAMEBUFFER, m_multisampleFBO
? m_multisampleFBO : m_fbo); |
| 825 } | 824 } |
| 826 | 825 |
| 827 } // namespace WebCore | 826 } // namespace WebCore |
| OLD | NEW |