Skip to content
Permalink
Browse files
Web Inspector: tint all pixels drawn by shader program when hovering …
…ShaderProgramTreeElement

https://bugs.webkit.org/show_bug.cgi?id=175223

Reviewed by Matt Baker.

Source/JavaScriptCore:

* inspector/protocol/Canvas.json:
Add `setShaderProgramHighlighted` command that will cause a blend to be applied to the
canvas if the given shader program is active immediately before `drawArrays` or `drawElements`
is called. The blend is removed and the previous value is applied once the draw is complete.

Source/WebCore:

Test: inspector/canvas/setShaderProgramHighlighted.html

* html/canvas/InspectorShaderProgram.h:
(WebCore::InspectorShaderProgram::highlighted):
(WebCore::InspectorShaderProgram::setHighlighted):

* html/canvas/WebGLRenderingContextBase.cpp:
(WebCore::InspectorScopedShaderProgramHighlight::InspectorScopedShaderProgramHighlight):
(WebCore::InspectorScopedShaderProgramHighlight::~InspectorScopedShaderProgramHighlight):
(WebCore::InspectorScopedShaderProgramHighlight::showHighlight):
(WebCore::InspectorScopedShaderProgramHighlight::hideHighlight):
(WebCore::InspectorScopedShaderProgramHighlight::saveBlendValue):
(WebCore::InspectorScopedShaderProgramHighlight::hasBufferBinding):
(WebCore::InspectorScopedShaderProgramHighlight::hasFramebufferParameterAttachment):
(WebCore::WebGLRenderingContextBase::drawArrays):
(WebCore::WebGLRenderingContextBase::drawElements):
If the current shader program has been marked as highlighted, apply a blend right before
`drawArrays` and `drawElements` is called, tinting the resulting pixels so that they are
visually distinguished from pixels drawn by other shader programs.

* inspector/InspectorCanvasAgent.h:
* inspector/InspectorCanvasAgent.cpp:
(WebCore::InspectorCanvasAgent::setShaderProgramHighlighted):
(WebCore::InspectorCanvasAgent::isShaderProgramHighlighted):

* inspector/InspectorInstrumentation.h:
* inspector/InspectorInstrumentation.cpp:
(WebCore::InspectorInstrumentation::isShaderProgramHighlighted):
(WebCore::InspectorInstrumentation::isShaderProgramHighlightedImpl):

Source/WebInspectorUI:

* UserInterface/Models/ShaderProgram.js:
(WI.ShaderProgram):
(WI.ShaderProgram.prototype.showHighlight):
(WI.ShaderProgram.prototype.hideHighlight):

* UserInterface/Views/ShaderProgramTreeElement.js:
(WI.ShaderProgramTreeElement.prototype.onattach):
(WI.ShaderProgramTreeElement.prototype._handleMouseOver):
(WI.ShaderProgramTreeElement.prototype._handleMouseOut):
Whenever a ShaderProgramTreeElement is hovered, highlight the corresponding shader program
by tinting the pixels it draws via a blend.

LayoutTests:

* inspector/canvas/setShaderProgramHighlighted-expected.txt: Added.
* inspector/canvas/setShaderProgramHighlighted.html: Added.


Canonical link: https://commits.webkit.org/199753@main
git-svn-id: https://svn.webkit.org/repository/webkit/trunk@230127 268f45cc-cd09-0410-ab3c-d52691b4dbfc
  • Loading branch information
dcrousso committed Mar 31, 2018
1 parent ab204e7 commit 871c5f431bafe7d2b9b48751cc9a69062336870e
@@ -1,3 +1,13 @@
2018-03-30 Devin Rousso <webkit@devinrousso.com>

Web Inspector: tint all pixels drawn by shader program when hovering ShaderProgramTreeElement
https://bugs.webkit.org/show_bug.cgi?id=175223

Reviewed by Matt Baker.

* inspector/canvas/setShaderProgramHighlighted-expected.txt: Added.
* inspector/canvas/setShaderProgramHighlighted.html: Added.

2018-03-30 Ryan Haddad <ryanhaddad@apple.com>

Skip http/tests/resourceLoadStatistics/prevalent-resource-with-user-interaction-timeout.html
@@ -0,0 +1,20 @@
Test highlighting of shader programs.


== Running test suite: Canvas.setShaderProgramHighlighted
-- Running test case: Canvas.setShaderProgramHighlighted.highlightedDrawArrays


-- Running test case: Canvas.setShaderProgramHighlighted.highlightedDrawElements


-- Running test case: Canvas.setShaderProgramHighlighted.unhighlightedDrawArrays


-- Running test case: Canvas.setShaderProgramHighlighted.unhighlightedDrawElements


-- Running test case: Canvas.setShaderProgramHighlighted.invalidProgramId
PASS: Should produce an error.
Error: No shader program for given identifier.

@@ -0,0 +1,158 @@
<!DOCTYPE html>
<html>
<head>
<script src="../../http/tests/inspector/resources/inspector-test.js"></script>
<script src="resources/shaderProgram-utilities.js"></script>
<script id="vertex-shader" type="x-shader/x-vertex">
attribute vec3 position;
void main(void) {
gl_Position = vec4(position, 1.0);
}
</script>
<script id="fragment-shader" type="x-shader/x-fragment">
precision mediump float;

void main(void) {
gl_FragColor = vec4(1.0, 1.0, 1.0, 1.0);
}
</script>
<script>
function load() {
createProgram("webgl");
linkProgram("vertex-shader", "fragment-shader");
context.useProgram(program);

clearContext();

runTest();
}

function clearContext() {
context.clearColor(0.0, 0.0, 0.0, 1.0);
context.clear(context.COLOR_BUFFER_BIT);
}

function drawArrays() {
clearContext();

let vertexes = [
-0.5, 0.5, 0.0,
-0.5, -0.5, 0.0,
0.5, -0.5, 0.0,
];
let vertexBuffer = context.createBuffer();
context.bindBuffer(context.ARRAY_BUFFER, vertexBuffer);
context.bufferData(context.ARRAY_BUFFER, new Float32Array(vertexes), context.STATIC_DRAW);

let position = context.getAttribLocation(program, "position");
context.vertexAttribPointer(position, 3, context.FLOAT, false, 0, 0);
context.enableVertexAttribArray(position);

context.drawArrays(context.TRIANGLES, 0, 3);
}

function drawElements() {
clearContext();

let vertexes = [
0.5, 0.5, 0.0,
-0.5, -0.5, 0.0,
0.5, -0.5, 0.0,
];
let vertexBuffer = context.createBuffer();
context.bindBuffer(context.ARRAY_BUFFER, vertexBuffer);
context.bufferData(context.ARRAY_BUFFER, new Float32Array(vertexes), context.STATIC_DRAW);

let indexes = [0, 1, 2];
let indexBuffer = context.createBuffer();
context.bindBuffer(context.ELEMENT_ARRAY_BUFFER, indexBuffer);
context.bufferData(context.ELEMENT_ARRAY_BUFFER, new Uint16Array(indexes), context.STATIC_DRAW);

let position = context.getAttribLocation(program, "position");
context.vertexAttribPointer(position, 3, context.FLOAT, false, 0, 0);
context.enableVertexAttribArray(position);

context.drawElements(context.TRIANGLES, indexes.length, context.UNSIGNED_SHORT, 0);
}

function test() {
let suite = InspectorTest.createAsyncSuite("Canvas.setShaderProgramHighlighted");

let shaderProgram = WI.canvasManager.shaderPrograms[0];
let originalContent = null;

function validTest({name, highlighted, evaluateString}) {
suite.addTestCase({
name,
test(resolve, reject) {
CanvasAgent.setShaderProgramHighlighted(shaderProgram.identifier, highlighted, (error) => {
if (error) {
reject(error);
return;
}

InspectorTest.evaluateInPage(evaluateString, (error) => {
if (error) {
reject(error);
return;
}

CanvasAgent.requestContent(shaderProgram.canvas.identifier)
.then(({content}) => InspectorTest.log(content))
.then(resolve, reject);
});
});
}
});
}

validTest({
name: "Canvas.setShaderProgramHighlighted.highlightedDrawArrays",
highlighted: true,
evaluateString: `drawArrays()`,
});

validTest({
name: "Canvas.setShaderProgramHighlighted.highlightedDrawElements",
highlighted: true,
evaluateString: `drawElements()`,
});

validTest({
name: "Canvas.setShaderProgramHighlighted.unhighlightedDrawArrays",
highlighted: false,
evaluateString: `drawArrays()`,
});

validTest({
name: "Canvas.setShaderProgramHighlighted.unhighlightedDrawElements",
highlighted: false,
evaluateString: `drawElements()`,
});

suite.addTestCase({
name: "Canvas.setShaderProgramHighlighted.invalidProgramId",
description: "Invalid program identifiers should cause an error.",
test(resolve, reject) {
const programId = "INVALID_PROGRAM_ID";
const highlighted = false;
CanvasAgent.setShaderProgramHighlighted(programId, highlighted, (error) => {
InspectorTest.expectThat(error, "Should produce an error.");
InspectorTest.log("Error: " + error);
resolve();
});
}
});

CanvasAgent.requestContent(shaderProgram.canvas.identifier, (error, content) => {
originalContent = content;

suite.runTestCasesAndFinish();
});
}
</script>
</head>
<body onload="load()">
<p>Test highlighting of shader programs.</p>
</body>
</html>
@@ -1,3 +1,15 @@
2018-03-30 Devin Rousso <webkit@devinrousso.com>

Web Inspector: tint all pixels drawn by shader program when hovering ShaderProgramTreeElement
https://bugs.webkit.org/show_bug.cgi?id=175223

Reviewed by Matt Baker.

* inspector/protocol/Canvas.json:
Add `setShaderProgramHighlighted` command that will cause a blend to be applied to the
canvas if the given shader program is active immediately before `drawArrays` or `drawElements`
is called. The blend is removed and the previous value is applied once the draw is complete.

2018-03-30 JF Bastien <jfbastien@apple.com>

WebAssembly: support DataView compilation
@@ -147,6 +147,14 @@
{ "name": "programId", "$ref": "ProgramId" },
{ "name": "disabled", "type": "boolean" }
]
},
{
"name": "setShaderProgramHighlighted",
"description": "Enable/disable highlighting of the given shader program.",
"parameters": [
{ "name": "programId", "$ref": "ProgramId" },
{ "name": "highlighted", "type": "boolean" }
]
}
],
"events": [
@@ -1,3 +1,40 @@
2018-03-30 Devin Rousso <webkit@devinrousso.com>

Web Inspector: tint all pixels drawn by shader program when hovering ShaderProgramTreeElement
https://bugs.webkit.org/show_bug.cgi?id=175223

Reviewed by Matt Baker.

Test: inspector/canvas/setShaderProgramHighlighted.html

* html/canvas/InspectorShaderProgram.h:
(WebCore::InspectorShaderProgram::highlighted):
(WebCore::InspectorShaderProgram::setHighlighted):

* html/canvas/WebGLRenderingContextBase.cpp:
(WebCore::InspectorScopedShaderProgramHighlight::InspectorScopedShaderProgramHighlight):
(WebCore::InspectorScopedShaderProgramHighlight::~InspectorScopedShaderProgramHighlight):
(WebCore::InspectorScopedShaderProgramHighlight::showHighlight):
(WebCore::InspectorScopedShaderProgramHighlight::hideHighlight):
(WebCore::InspectorScopedShaderProgramHighlight::saveBlendValue):
(WebCore::InspectorScopedShaderProgramHighlight::hasBufferBinding):
(WebCore::InspectorScopedShaderProgramHighlight::hasFramebufferParameterAttachment):
(WebCore::WebGLRenderingContextBase::drawArrays):
(WebCore::WebGLRenderingContextBase::drawElements):
If the current shader program has been marked as highlighted, apply a blend right before
`drawArrays` and `drawElements` is called, tinting the resulting pixels so that they are
visually distinguished from pixels drawn by other shader programs.

* inspector/InspectorCanvasAgent.h:
* inspector/InspectorCanvasAgent.cpp:
(WebCore::InspectorCanvasAgent::setShaderProgramHighlighted):
(WebCore::InspectorCanvasAgent::isShaderProgramHighlighted):

* inspector/InspectorInstrumentation.h:
* inspector/InspectorInstrumentation.cpp:
(WebCore::InspectorInstrumentation::isShaderProgramHighlighted):
(WebCore::InspectorInstrumentation::isShaderProgramHighlightedImpl):

2018-03-30 Wenson Hsieh <wenson_hsieh@apple.com>

[Extra zoom mode] Adopt list view controller UI for numeric input types

0 comments on commit 871c5f4

Please sign in to comment.