blob: dbf3ae736b45d9cd37c5236c416a80bd23d14cb2 [file] [log] [blame]
<!DOCTYPE html>
<meta charset="UTF-8">
<style>
.target {
color: white;
width: 100px;
height: 100px;
background-color: black;
display: inline-block;
overflow: hidden;
}
.expected {
background-color: green;
}
.target div {
width: 10px;
height: 10px;
display: inline-block;
background: orange;
margin: 1px;
}
.test {
overflow: hidden;
}
</style>
<body>
<template id="target-template">
<div></div>
</template>
<script src="resources/interpolation-test.js"></script>
<script>
// Perspective
assertInterpolation({
property: '-webkit-transform',
from: 'perspective(400px)',
to: 'perspective(500px)'
}, [
{at: -1, is: 'perspective(300px)'},
{at: 0, is: 'perspective(400px)'},
{at: 0.25, is: 'perspective(425px)'},
{at: 0.75, is: 'perspective(475px)'},
{at: 1, is: 'perspective(500px)'},
{at: 2, is: 'perspective(600px)'},
]);
assertInterpolation({
property: '-webkit-transform',
from: 'skewX(10rad) perspective(400px)',
to: 'skewX(20rad) perspective(500px)'
}, [
{at: -1, is: 'skewX(0rad) perspective(300px)'},
{at: 0, is: 'skewX(10rad) perspective(400px)'},
{at: 0.25, is: 'skewX(12.5rad) perspective(425px)'},
{at: 0.75, is: 'skewX(17.5rad) perspective(475px)'},
{at: 1, is: 'skewX(20rad) perspective(500px)'},
{at: 2, is: 'skewX(30rad) perspective(600px)'},
]);
assertInterpolation({
property: '-webkit-transform',
from: 'scaleZ(1) perspective(400px)',
to: 'scaleZ(2) perspective(500px)'
}, [
{at: -1, is: 'scaleZ(0) perspective(300px)'},
{at: 0, is: 'scaleZ(1) perspective(400px)'},
{at: 0.25, is: 'scaleZ(1.25) perspective(425px)'},
{at: 0.75, is: 'scaleZ(1.75) perspective(475px)'},
{at: 1, is: 'scaleZ(2) perspective(500px)'},
{at: 2, is: 'scaleZ(3) perspective(600px)'},
]);
// Rotate
assertInterpolation({
property: '-webkit-transform',
from: 'rotate(30deg)',
to: 'rotate(330deg)'
}, [
{at: -1, is: 'rotate(-270deg)'},
{at: 0, is: 'rotate(30deg)'},
{at: 0.25, is: 'rotate(105deg)'},
{at: 0.75, is: 'rotate(255deg)'},
{at: 1, is: 'rotate(330deg)'},
{at: 2, is: 'rotate(630deg)'},
]);
assertInterpolation({
property: '-webkit-transform',
from: 'rotateX(0deg)',
to: 'rotateX(700deg)'
}, [
{at: -1, is: 'rotateX(-700deg)'},
{at: 0, is: 'rotateX(0deg)'},
{at: 0.25, is: 'rotateX(175deg)'},
{at: 0.75, is: 'rotateX(525deg)'},
{at: 1, is: 'rotateX(700deg)'},
{at: 2, is: 'rotateX(1400deg)'},
]);
assertInterpolation({
property: '-webkit-transform',
from: 'rotateY(0deg)',
to: 'rotateY(800deg)'
}, [
{at: -1, is: 'rotateY(-800deg)'},
{at: 0, is: 'rotateY(0deg)'},
{at: 0.25, is: 'rotateY(200deg)'},
{at: 0.75, is: 'rotateY(600deg)'},
{at: 1, is: 'rotateY(800deg)'},
{at: 2, is: 'rotateY(1600deg)'},
]);
assertInterpolation({
property: '-webkit-transform',
from: 'rotateZ(0deg)',
to: 'rotateZ(900deg)'
}, [
{at: -1, is: 'rotateZ(-900deg)'},
{at: 0, is: 'rotateZ(0deg)'},
{at: 0.25, is: 'rotateZ(225deg)'},
{at: 0.75, is: 'rotateZ(675deg)'},
{at: 1, is: 'rotateZ(900deg)'},
{at: 2, is: 'rotateZ(1800deg)'},
]);
assertInterpolation({
property: '-webkit-transform',
from: 'rotate3d(7, 8, 9, 100deg)',
to: 'rotate3d(7, 8, 9, 260deg)'
}, [
{at: -1, is: 'rotate3d(7, 8, 9, -60deg)'},
{at: 0, is: 'rotate3d(7, 8, 9, 100deg)'},
{at: 0.25, is: 'rotate3d(7, 8, 9, 140deg)'},
{at: 0.75, is: 'rotate3d(7, 8, 9, 220deg)'},
{at: 1, is: 'rotate3d(7, 8, 9, 260deg)'},
{at: 2, is: 'rotate3d(7, 8, 9, 420deg)'},
]);
assertInterpolation({
property: '-webkit-transform',
from: 'none',
to: 'rotate(90deg)'
}, [
{at: -1, is: 'rotate(-90deg)'},
{at: 0, is: 'rotate(0deg)'},
{at: 0.25, is: 'rotate(22.5deg)'},
{at: 0.75, is: 'rotate(67.5deg)'},
{at: 1, is: 'rotate(90deg)'},
{at: 2, is: 'rotate(180deg)'},
]);
assertInterpolation({
property: '-webkit-transform',
from: 'rotate(90deg)',
to: 'none'
}, [
{at: -1, is: 'rotate(180deg)'},
{at: 0, is: 'rotate(90deg)'},
{at: 0.25, is: 'rotate(67.5deg)'},
{at: 0.75, is: 'rotate(22.5deg)'},
{at: 1, is: 'rotate(0deg)'},
{at: 2, is: 'rotate(-90deg)'},
]);
assertInterpolation({
property: '-webkit-transform',
from: 'rotateX(0deg) rotateY(0deg) rotateZ(0deg)',
to: 'rotateX(700deg) rotateY(800deg) rotateZ(900deg)'
}, [
{at: -1, is: 'rotateX(-700deg) rotateY(-800deg) rotateZ(-900deg)'},
{at: 0, is: 'rotateX(0deg) rotateY(0deg) rotateZ(0deg)'},
{at: 0.25, is: 'rotateX(175deg) rotateY(200deg) rotateZ(225deg)'},
{at: 0.75, is: 'rotateX(525deg) rotateY(600deg) rotateZ(675deg)'},
{at: 1, is: 'rotateX(700deg) rotateY(800deg) rotateZ(900deg)'},
{at: 2, is: 'rotateX(1400deg) rotateY(1600deg) rotateZ(1800deg)'},
]);
</script>
</body>