| 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 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 49 VideoFrameProvider* pr
ovider) | 49 VideoFrameProvider* pr
ovider) |
| 50 { | 50 { |
| 51 return adoptRef(new VideoLayerChromium(owner, provider)); | 51 return adoptRef(new VideoLayerChromium(owner, provider)); |
| 52 } | 52 } |
| 53 | 53 |
| 54 VideoLayerChromium::VideoLayerChromium(GraphicsLayerChromium* owner, VideoFrameP
rovider* provider) | 54 VideoLayerChromium::VideoLayerChromium(GraphicsLayerChromium* owner, VideoFrameP
rovider* provider) |
| 55 : LayerChromium(owner) | 55 : LayerChromium(owner) |
| 56 , m_skipsDraw(true) | 56 , m_skipsDraw(true) |
| 57 , m_frameFormat(VideoFrameChromium::Invalid) | 57 , m_frameFormat(VideoFrameChromium::Invalid) |
| 58 , m_provider(provider) | 58 , m_provider(provider) |
| 59 , m_currentFrame(0) | |
| 60 { | 59 { |
| 61 } | 60 } |
| 62 | 61 |
| 63 VideoLayerChromium::~VideoLayerChromium() | 62 VideoLayerChromium::~VideoLayerChromium() |
| 64 { | 63 { |
| 65 cleanupResources(); | 64 cleanupResources(); |
| 66 } | 65 } |
| 67 | 66 |
| 68 PassRefPtr<CCLayerImpl> VideoLayerChromium::createCCLayerImpl() | 67 PassRefPtr<CCLayerImpl> VideoLayerChromium::createCCLayerImpl() |
| 69 { | 68 { |
| 70 return CCVideoLayerImpl::create(m_layerId); | 69 return CCVideoLayerImpl::create(m_layerId); |
| 71 } | 70 } |
| 72 | 71 |
| 73 void VideoLayerChromium::cleanupResources() | 72 void VideoLayerChromium::cleanupResources() |
| 74 { | 73 { |
| 75 LayerChromium::cleanupResources(); | 74 LayerChromium::cleanupResources(); |
| 76 for (size_t i = 0; i < 3; ++i) | 75 for (size_t i = 0; i < 3; ++i) |
| 77 m_textures[i].m_texture.clear(); | 76 m_textures[i].m_texture.clear(); |
| 78 releaseCurrentFrame(); | |
| 79 } | 77 } |
| 80 | 78 |
| 81 void VideoLayerChromium::updateCompositorResources(GraphicsContext3D* context) | 79 void VideoLayerChromium::updateCompositorResources(GraphicsContext3D* context) |
| 82 { | 80 { |
| 83 if (!m_contentsDirty || !m_owner) | 81 if (!m_contentsDirty || !m_owner || !m_provider) |
| 84 return; | 82 return; |
| 85 | 83 |
| 86 RenderLayerBacking* backing = static_cast<RenderLayerBacking*>(m_owner->clie
nt()); | 84 RenderLayerBacking* backing = static_cast<RenderLayerBacking*>(m_owner->clie
nt()); |
| 87 if (!backing || backing->paintingGoesToWindow()) | 85 if (!backing || backing->paintingGoesToWindow()) |
| 88 return; | 86 return; |
| 89 | 87 |
| 90 ASSERT(drawsContent()); | 88 ASSERT(drawsContent()); |
| 91 | 89 |
| 92 m_skipsDraw = false; | 90 m_skipsDraw = false; |
| 93 VideoFrameChromium* frame = m_provider->getCurrentFrame(); | 91 VideoFrameChromium* frame = m_provider->getCurrentFrame(); |
| (...skipping 145 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 239 memcpy(mem, data, dimensions.width() * dimensions.height()); | 237 memcpy(mem, data, dimensions.width() * dimensions.height()); |
| 240 GLC(context, static_cast<Extensions3DChromium*>(context->getExtensions()
)->unmapTexSubImage2DCHROMIUM(mem)); | 238 GLC(context, static_cast<Extensions3DChromium*>(context->getExtensions()
)->unmapTexSubImage2DCHROMIUM(mem)); |
| 241 } else { | 239 } else { |
| 242 // If mapTexSubImage2DCHROMIUM fails, then do the slower texSubImage2D | 240 // If mapTexSubImage2DCHROMIUM fails, then do the slower texSubImage2D |
| 243 // upload. This does twice the copies as mapTexSubImage2DCHROMIUM, one | 241 // upload. This does twice the copies as mapTexSubImage2DCHROMIUM, one |
| 244 // in the command buffer and another to the texture. | 242 // in the command buffer and another to the texture. |
| 245 GLC(context, context->texSubImage2D(GraphicsContext3D::TEXTURE_2D, 0, 0,
0, dimensions.width(), dimensions.height(), format, GraphicsContext3D::UNSIGNED
_BYTE, data)); | 243 GLC(context, context->texSubImage2D(GraphicsContext3D::TEXTURE_2D, 0, 0,
0, dimensions.width(), dimensions.height(), format, GraphicsContext3D::UNSIGNED
_BYTE, data)); |
| 246 } | 244 } |
| 247 } | 245 } |
| 248 | 246 |
| 249 void VideoLayerChromium::releaseCurrentFrame() | 247 void VideoLayerChromium::releaseProvider() |
| 250 { | 248 { |
| 251 if (!m_currentFrame) | 249 m_provider = 0; |
| 252 return; | |
| 253 | |
| 254 m_provider->putCurrentFrame(m_currentFrame); | |
| 255 m_currentFrame = 0; | |
| 256 } | 250 } |
| 257 | 251 |
| 258 } // namespace WebCore | 252 } // namespace WebCore |
| 259 | 253 |
| 260 #endif // USE(ACCELERATED_COMPOSITING) | 254 #endif // USE(ACCELERATED_COMPOSITING) |
| OLD | NEW |