| OLD | NEW |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "modules/canvas/HTMLCanvasElementModule.h" | 5 #include "modules/canvas/HTMLCanvasElementModule.h" |
| 6 | 6 |
| 7 #include "core/dom/DOMNodeIds.h" | 7 #include "core/dom/DOMNodeIds.h" |
| 8 #include "core/html/canvas/CanvasContextCreationAttributes.h" | 8 #include "core/html/canvas/CanvasContextCreationAttributes.h" |
| 9 #include "core/html/canvas/CanvasRenderingContext.h" | 9 #include "core/html/canvas/CanvasRenderingContext.h" |
| 10 #include "core/offscreencanvas/OffscreenCanvas.h" | 10 #include "core/offscreencanvas/OffscreenCanvas.h" |
| (...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 58 HTMLCanvasElement& canvas, | 58 HTMLCanvasElement& canvas, |
| 59 ExceptionState& exceptionState) { | 59 ExceptionState& exceptionState) { |
| 60 if (canvas.renderingContext()) { | 60 if (canvas.renderingContext()) { |
| 61 exceptionState.throwDOMException( | 61 exceptionState.throwDOMException( |
| 62 InvalidStateError, | 62 InvalidStateError, |
| 63 "Cannot transfer control from a canvas that has a rendering context."); | 63 "Cannot transfer control from a canvas that has a rendering context."); |
| 64 return nullptr; | 64 return nullptr; |
| 65 } | 65 } |
| 66 OffscreenCanvas* offscreenCanvas = | 66 OffscreenCanvas* offscreenCanvas = |
| 67 OffscreenCanvas::create(canvas.width(), canvas.height()); | 67 OffscreenCanvas::create(canvas.width(), canvas.height()); |
| 68 offscreenCanvas->setAssociatedCanvasId(DOMNodeIds::idForNode(&canvas)); | 68 |
| 69 int canvasId = DOMNodeIds::idForNode(&canvas); |
| 70 offscreenCanvas->setPlaceholderCanvasId(canvasId); |
| 71 canvas.registerPlaceholder(canvasId); |
| 69 | 72 |
| 70 CanvasSurfaceLayerBridge* bridge = canvas.surfaceLayerBridge(); | 73 CanvasSurfaceLayerBridge* bridge = canvas.surfaceLayerBridge(); |
| 71 if (bridge) { | 74 if (bridge) { |
| 72 // If a bridge exists, it means canvas.createSurfaceLayer() has been called | 75 // If a bridge exists, it means canvas.createSurfaceLayer() has been called |
| 73 // and its SurfaceId has been populated as well. | 76 // and its SurfaceId has been populated as well. |
| 74 offscreenCanvas->setSurfaceId( | 77 offscreenCanvas->setSurfaceId( |
| 75 bridge->getSurfaceId().frame_sink_id().client_id(), | 78 bridge->getSurfaceId().frame_sink_id().client_id(), |
| 76 bridge->getSurfaceId().frame_sink_id().sink_id(), | 79 bridge->getSurfaceId().frame_sink_id().sink_id(), |
| 77 bridge->getSurfaceId().local_frame_id().local_id(), | 80 bridge->getSurfaceId().local_frame_id().local_id(), |
| 78 bridge->getSurfaceId() | 81 bridge->getSurfaceId() |
| 79 .local_frame_id() | 82 .local_frame_id() |
| 80 .nonce() | 83 .nonce() |
| 81 .GetHighForSerialization(), | 84 .GetHighForSerialization(), |
| 82 bridge->getSurfaceId() | 85 bridge->getSurfaceId() |
| 83 .local_frame_id() | 86 .local_frame_id() |
| 84 .nonce() | 87 .nonce() |
| 85 .GetLowForSerialization()); | 88 .GetLowForSerialization()); |
| 86 } | 89 } |
| 87 return offscreenCanvas; | 90 return offscreenCanvas; |
| 88 } | 91 } |
| 89 } | 92 } |
| OLD | NEW |