Home | History | Annotate | Download | only in manual-tests
      1 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Strict//EN"
      2   "http://www.w3.org/TR/html4/strict.dtd">
      3 <html>
      4   <head>
      5     <title>Test for Bug 39139</title>
      6     <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
      7     <meta name="viewport" content="initial-scale=0.60, minimum-scale=0.60, maximum-scale=0.60">
      8     <style type="text/css">
      9 
     10       body {
     11         font-family: 'Lucida Grande', Verdana, Arial;
     12         font-size: 12px;
     13       }
     14 
     15       #stage {
     16         margin: 150px auto;
     17         width: 600px;
     18         height: 400px;
     19         /*
     20         
     21         Setting the perspective of the contents of the stage
     22         but not the stage itself
     23         
     24         */
     25         -webkit-perspective: 800;
     26       }
     27 
     28       #rotate {
     29         margin: 0 auto;
     30         width: 600px;
     31         height: 400px;
     32         /* Ensure that we're in 3D space */
     33         -webkit-transform-style: preserve-3d;
     34         /*
     35         Make the whole set of rows use the x-axis spin animation
     36         for a duration of 7 seconds, running infinitely and linearly
     37         */
     38         -webkit-animation-name: x-spin;
     39         -webkit-animation-duration: 7s;
     40         -webkit-animation-iteration-count: infinite;
     41         -webkit-animation-timing-function: linear;
     42       }
     43 
     44       .ring {
     45         margin: 0 auto;
     46         height: 110px;
     47         width: 600px;
     48         -webkit-transform-style: preserve-3d;
     49         -webkit-animation-iteration-count: infinite;
     50         -webkit-animation-timing-function: linear;
     51       }
     52       
     53       .ring > :nth-child(odd) {
     54         background-color: #995C7F;
     55       }
     56 
     57       .ring > :nth-child(even) {
     58         background-color: #835A99;
     59       }
     60 
     61       .poster {
     62         position: absolute;
     63         left: 250px;
     64         width: 100px;
     65         height: 100px;
     66         opacity: 0.7;
     67         color: rgba(0,0,0,0.9);
     68         -webkit-border-radius: 10px;
     69       }
     70       
     71       .poster > p {
     72         font-family: 'Georgia', serif;
     73         font-size: 36px;
     74         font-weight: bold;
     75         text-align: center;
     76         margin-top: 28px;
     77       }
     78 
     79       /*
     80       Set up each row to have a different animation duration
     81       and alternating y-axis rotation directions.
     82       */
     83       #ring-1 {
     84         -webkit-animation-name: y-spin;
     85         -webkit-animation-duration: 5s;
     86       }
     87 
     88       #ring-2 {
     89         -webkit-animation-name: back-y-spin;
     90         -webkit-animation-duration: 4s;
     91       }
     92 
     93       #ring-3 {
     94         -webkit-animation-name: y-spin;
     95         -webkit-animation-duration: 3s;
     96       }
     97 
     98       /*
     99 
    100       Here we define each of the three individual animations that
    101       we will be using to have our 3D rotation effect. The first
    102       animation will perform a full rotation on the x-axis, we'll
    103       use that on the whole set of objects. The second and third
    104       animations will perform a full rotation on the y-axis in
    105       opposite directions, alternating directions between rows.
    106     
    107       Note that you currently have to specify an intermediate step
    108       for rotations even when you are using individual transformation
    109       constructs.
    110 
    111       */
    112       @-webkit-keyframes x-spin {
    113         0%    { -webkit-transform: rotateX(0deg); }
    114         50%   { -webkit-transform: rotateX(180deg); }
    115         100%  { -webkit-transform: rotateX(360deg); }
    116       }
    117 
    118       @-webkit-keyframes y-spin {
    119         0%    { -webkit-transform: rotateY(0deg); }
    120         50%   { -webkit-transform: rotateY(180deg); }
    121         100%  { -webkit-transform: rotateY(360deg); }
    122       }
    123 
    124       @-webkit-keyframes back-y-spin {
    125         0%    { -webkit-transform: rotateY(360deg); }
    126         50%   { -webkit-transform: rotateY(180deg); }
    127         100%  { -webkit-transform: rotateY(0deg); }
    128       }
    129     </style>
    130 
    131     <script type="text/javascript">
    132 
    133       const POSTERS_PER_ROW = 12;
    134       const RING_RADIUS = 200;
    135 
    136       function setup_posters (row)
    137       {
    138         var posterAngle = 360 / POSTERS_PER_ROW;
    139         for (var i = 0; i < POSTERS_PER_ROW; i ++) {
    140           var poster = document.createElement('div');
    141           poster.className = 'poster';
    142           // compute and assign the transform for this poster
    143           var transform = 'rotateY(' + (posterAngle * i) + 'deg) translateZ(' + RING_RADIUS + 'px)';
    144           poster.style.webkitTransform = transform;
    145           // setup the number to show inside the poster
    146           var content = poster.appendChild(document.createElement('p'));
    147           content.textContent = i;
    148           // add the poster to the row
    149           row.appendChild(poster);
    150         }
    151 
    152       }
    153 
    154       function init ()
    155       {
    156         setup_posters(document.getElementById('ring-1'));
    157         setup_posters(document.getElementById('ring-2'));
    158         setup_posters(document.getElementById('ring-3'));
    159       }
    160 
    161       // call init once the document is fully loaded
    162       window.addEventListener('load', init, false);
    163 
    164     </script>
    165   </head>
    166   
    167   <body>
    168 
    169     <p>This is a test for <a href="https://bugs.webkit.org/show_bug.cgi?id=39139">Bug 39139: Pages
    170     that use hardware acceleration don't repaint after waking computer from sleep</a>. To test, put
    171     your computer to sleep (or "Standby", as Windows calls it). When you wake your computer up, the
    172     animation below should still be running.</p>
    173     <div id="stage">
    174       <div id="rotate">
    175         <div id="ring-1" class="ring"></div>
    176         <div id="ring-2" class="ring"></div>
    177         <div id="ring-3" class="ring"></div>
    178       </div>
    179     </div>
    180 
    181   </body>
    182   
    183 </html>
    184