<!-- /* ** Copyright (c) 2015 The Khronos Group Inc. ** ** Permission is hereby granted, free of charge, to any person obtaining a ** copy of this software and/or associated documentation files (the ** "Materials"), to deal in the Materials without restriction, including ** without limitation the rights to use, copy, modify, merge, publish, ** distribute, sublicense, and/or sell copies of the Materials, and to ** permit persons to whom the Materials are furnished to do so, subject to ** the following conditions: ** ** The above copyright notice and this permission notice shall be included ** in all copies or substantial portions of the Materials. ** ** THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, ** EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF ** MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. ** IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY ** CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, ** TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE ** MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS. */ --> <!DOCTYPE html> <html> <head> <title>Testing resolution of texture uploads</title> <style> .result { margin-bottom: 20px; display: -webkit-flex; display: flex; -webkit-flex-direction: row; flex-direction: row; } .description, .element, .render, .log { border: 1px solid black; margin: 5px; width: 200px; height: 200px; max-width: 200px; max-height: 200px; } .render canvas { width: 200px; height: 200px; } p { margin: 0; padding: 5px 10px; } .viacss { width: 200px; height: 200px; } </style> <script src="../js/webgl-test-utils.js"> </script> <script> var outOfPageSVG = new Image(); outOfPageSVG.src = "sample.svg"; function runTest() { var wtu = WebGLTestUtils; var results = document.querySelectorAll(".result"); for (var i = 0; i < results.length; i++) { var result = results[i]; var img = result.querySelector("img"); if (result.classList.contains("out-of-page")) { img = outOfPageSVG; } if (result.classList.contains("set-dimensions")) { img.width = 200; img.height = 200; } var out = result.querySelector(".output"); out.innerHTML = "img.width = " + img.width + "<br>img.height = " + img.height + "<br>img.naturalWidth = " + img.naturalWidth + "<br>img.naturalHeight = " + img.naturalHeight; var canvas = document.createElement("canvas"); canvas.width = 200 * window.devicePixelRatio; canvas.height = 200 * window.devicePixelRatio; result.querySelector(".render").appendChild(canvas); var gl = wtu.create3DContext(canvas); gl.enable(gl.BLEND); gl.disable(gl.DEPTH_TEST); var program = wtu.setupSimpleTextureProgram(gl, 0, 1); var buffers = wtu.setupUnitQuad(gl, 0, 1); var tex = gl.createTexture(); gl.bindTexture(gl.TEXTURE_2D, tex); gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR); gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE); gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE); gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE, img); var loc = gl.getUniformLocation(program, "tex"); gl.uniform1i(loc, 0); wtu.clearAndDrawUnitQuad(gl, [0, 255, 0, 255]); } } window.addEventListener("load", function () { runTest(); }, false); </script> </head> <body> <div class="result"> <div class="description"> <p>IMG to SVG with 200x200 attributes</p> </div> <div class="element"> <img src="sample.svg" width="200" height="200"> </div> <div class="render"> </div> <div class="log"> <p class="output"></p> </div> </div> <div class="result"> <div class="description"> <p>IMG to 100x100 PNG with 200x200 attributes</p> </div> <div class="element"> <img src="sample-100.png" width="200" height="200"> </div> <div class="render"> </div> <div class="log"> <p class="output"></p> </div> </div> <div class="result"> <div class="description"> <p>IMG to 200x200 PNG with 200x200 attributes</p> </div> <div class="element"> <img src="sample-200.png" width="200" height="200"> </div> <div class="render"> </div> <div class="log"> <p class="output"></p> </div> </div> <div class="result"> <div class="description"> <p>IMG to 400x400 PNG with 200x200 attributes</p> </div> <div class="element"> <img src="sample-400.png" width="200" height="200"> </div> <div class="render"> </div> <div class="log"> <p class="output"></p> </div> </div> <div class="result"> <div class="description"> <p>IMG SRCSET to multiple PNGs with 200x200 attributes</p> </div> <div class="element"> <img src="sample-100.png" srcset="sample-200.png 1x, sample-400.png 2x" width="200" height="200"> </div> <div class="render"> </div> <div class="log"> <p class="output"></p> </div> </div> <div class="result"> <div class="description"> <p>IMG to SVG with no attributes - 200x200 sizing via CSS</p> </div> <div class="element"> <img src="sample.svg" class="viacss"> </div> <div class="render"> </div> <div class="log"> <p class="output"></p> </div> </div> <div class="result"> <div class="description"> <p>IMG to 400x400 PNG with no attributes - 200x200 sizing via CSS</p> </div> <div class="element"> <img src="sample-400.png" class="viacss"> </div> <div class="render"> </div> <div class="log"> <p class="output"></p> </div> </div> <div class="result"> <div class="description"> <p> IMG to SVG with no attributes and no sizing via CSS<br> (although the width and height of the container set a size) </p> </div> <div class="element"> <img src="sample.svg"> </div> <div class="render"> </div> <div class="log"> <p class="output"></p> </div> </div> <div class="result out-of-page"> <div class="description"> <p>Out of page SVG with no dimensions</p> </div> <div class="element"> Not a child of document </div> <div class="render"> </div> <div class="log"> <p class="output"></p> </div> </div> <div class="result out-of-page set-dimensions"> <div class="description"> <p>Out of page SVG with 200x200 specified</p> </div> <div class="element"> Not a child of document </div> <div class="render"> </div> <div class="log"> <p class="output"></p> </div> </div> </body> </html>