blob: 3fd56a57231fe3b83b376129617761af3add82f2 [file] [log] [blame]
<!DOCTYPE html>
<head>
<style>
div.container {
display: inline-block;
margin-right: 20px;
margin-bottom: 10px;
width: 100px;
vertical-align: top;
}
div.horizontal {
width: 102px;
height: 52px;
}
div.vertical {
width: 52px;
height: 102px;
}
canvas {
border: 1px solid black;
width: 100px;
height: 50px;
}
</style>
</head>
<script id="vertexShaderSource" type="text/glsl">
attribute vec4 a_position;
varying vec2 v_texturePosition;
void main() {
v_texturePosition = vec2((a_position.x + 1.0) / 2.0, (a_position.y + 1.0) / 2.0);
gl_Position = a_position;
}
</script>
<script id="fragmentShaderSource" type="text/glsl">
precision mediump float;
varying vec2 v_texturePosition;
uniform sampler2D texture;
void main() {
gl_FragColor = texture2D(texture, v_texturePosition);
}
</script>
<script src="resources/webgl-draw-image.js"></script>
<body>
<b>WebGLRenderingContext.texImage2D() should rotate the images respecting their EXIF orientation.</b>
<br>
<br>
<div class ="container">
<div class ="horizontal">
<canvas class="horizontal" id="canvas2" style="transform: scaleX(-1);"></canvas>
</div>
<br>Flipped horizontally
</div>
<div class ="container">
<div class ="horizontal">
<canvas class="horizontal" id="canvas3" style="transform: rotate(180deg);"></canvas>
</div>
<br>Rotated 180&deg;
</div>
<div class ="container">
<div class ="horizontal">
<canvas class="horizontal" id="canvas4" style="transform: scaleX(-1) rotate(180deg);"></canvas>
</div>
<br>Flipped vertically
</div>
<br>
<div class ="container">
<div class ="vertical">
<canvas class="vertical" id="canvas5" style="transform: translate(-25px, 25px) rotate(90deg) scaleY(-1);"></canvas>
</div>
<br>Rotated 90&deg; CCW and flipped vertically
</div>
<div class ="container">
<div class ="vertical">
<canvas class="vertical" id="canvas6" style="transform: translate(-25px, 25px) rotate(90deg);"></canvas>
</div>
<br>Rotated 90&deg; CCW
</div>
<div class ="container">
<div class ="vertical">
<canvas class="vertical" id="canvas7" style="transform: translate(-25px, 25px) rotate(270deg) scaleY(-1);"></canvas>
</div>
<br>Rotated 90&deg; CW and flipped vertically
</div>
<div class ="container">
<div class ="vertical">
<canvas class="vertical" id="canvas8" style="transform: translate(-25px, 25px) rotate(270deg);"></canvas>
</div>
<br>Rotated 90&deg; CW
</div>
<br>
<script>
if (window.testRunner)
window.testRunner.waitUntilDone();
window.onload = function() {
document.querySelectorAll("canvas").forEach(canvas => {
canvas.width = 100 * window.devicePixelRatio;
canvas.height = 50 * window.devicePixelRatio;
});
var image = new Image;
image.src = "' width='100' height='50'/></svg>";
image.decode().then(() => {
setTimeout(function() {
document.querySelectorAll("canvas").forEach(canvas => {
canvas.width = image.width * window.devicePixelRatio;
canvas.height = image.height * window.devicePixelRatio;
webglDrawImage(canvas, image);
});
if (window.testRunner)
window.testRunner.notifyDone();
}, 100);
});
}
</script>
</body>