pointerevent_touch-action-pan-x-pan-y_touch.html (6190B)
1 <!doctype html> 2 <html> 3 <head> 4 <title>touch-action: pan-x pan-y</title> 5 <meta name="viewport" content="width=device-width"> 6 <link rel="stylesheet" type="text/css" href="pointerevent_styles.css"> 7 <script src="/resources/testharness.js"></script> 8 <script src="/resources/testharnessreport.js"></script> 9 <script src="/resources/testdriver.js"></script> 10 <script src="/resources/testdriver-actions.js"></script> 11 <script src="/resources/testdriver-vendor.js"></script> 12 <script src="pointerevent_support.js"></script> 13 <style> 14 #target0 { 15 width: 700px; 16 height: 430px; 17 touch-action: pan-x pan-y; 18 } 19 </style> 20 </head> 21 <body onload="run()"> 22 <h1>Pointer Events touch-action attribute support</h1> 23 <h4 id="desc">Test Description: Try to scroll text DOWN. Wait for description update. Expected: pan enabled</h4> 24 <p>Note: this test is for touch-devices only</p> 25 <div id="target0"> 26 <p> 27 Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diem 28 nonummy nibh euismod tincidunt ut lacreet dolore magna aliguam erat volutpat. 29 Ut wisis enim ad minim veniam, quis nostrud exerci tution ullamcorper suscipit 30 lobortis nisl ut aliquip ex ea commodo consequat. 31 </p> 32 <p>Lorem ipsum dolor sit amet...</p> 33 <p>Lorem ipsum dolor sit amet...</p> 34 <p>Lorem ipsum dolor sit amet...</p> 35 <p>Lorem ipsum dolor sit amet...</p> 36 <p>Lorem ipsum dolor sit amet...</p> 37 <p>Lorem ipsum dolor sit amet...</p> 38 <p>Lorem ipsum dolor sit amet...</p> 39 <p> 40 Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diem 41 nonummy nibh euismod tincidunt ut lacreet dolore magna aliguam erat volutpat. 42 Ut wisis enim ad minim veniam, quis nostrud exerci tution ullamcorper suscipit 43 lobortis nisl ut aliquip ex ea commodo consequat. 44 </p> 45 <p>Lorem ipsum dolor sit amet...</p> 46 <p>Lorem ipsum dolor sit amet...</p> 47 <p>Lorem ipsum dolor sit amet...</p> 48 <p>Lorem ipsum dolor sit amet...</p> 49 <p>Lorem ipsum dolor sit amet...</p> 50 <p>Lorem ipsum dolor sit amet...</p> 51 <p>Lorem ipsum dolor sit amet...</p> 52 <p> 53 Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diem 54 nonummy nibh euismod tincidunt ut lacreet dolore magna aliguam erat volutpat. 55 Ut wisis enim ad minim veniam, quis nostrud exerci tution ullamcorper suscipit 56 lobortis nisl ut aliquip ex ea commodo consequat. 57 </p> 58 <p>Lorem ipsum dolor sit amet...</p> 59 <p>Lorem ipsum dolor sit amet...</p> 60 <p>Lorem ipsum dolor sit amet...</p> 61 <p>Lorem ipsum dolor sit amet...</p> 62 <p>Lorem ipsum dolor sit amet...</p> 63 <p>Lorem ipsum dolor sit amet...</p> 64 <p>Lorem ipsum dolor sit amet...</p> 65 <p> 66 Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diem 67 nonummy nibh euismod tincidunt ut lacreet dolore magna aliguam erat volutpat. 68 Ut wisis enim ad minim veniam, quis nostrud exerci tution ullamcorper suscipit 69 lobortis nisl ut aliquip ex ea commodo consequat. 70 </p> 71 <p>Lorem ipsum dolor sit amet...</p> 72 <p>Lorem ipsum dolor sit amet...</p> 73 <p>Lorem ipsum dolor sit amet...</p> 74 <p>Lorem ipsum dolor sit amet...</p> 75 <p>Lorem ipsum dolor sit amet...</p> 76 <p>Lorem ipsum dolor sit amet...</p> 77 <p>Lorem ipsum dolor sit amet...</p> 78 </div> 79 <script type='text/javascript'> 80 var detected_pointertypes = {}; 81 82 var xScrollIsReceived = false; 83 var yScrollIsReceived = false; 84 var xScr0, yScr0, xScr1, yScr1; 85 86 add_completion_callback(showPointerTypes); 87 88 function run() { 89 var target0 = document.getElementById("target0"); 90 91 var test_touchaction = async_test("touch-action attribute test"); 92 var actions_promise; 93 94 xScr0 = target0.scrollLeft; 95 yScr0 = target0.scrollTop; 96 97 on_event(target0, 'pointerdown', function(event) { 98 detected_pointertypes[event.pointerType] = true; 99 }); 100 101 on_event(target0, 'scroll', function(event) { 102 xScr1 = target0.scrollLeft; 103 yScr1 = target0.scrollTop; 104 105 if(xScr1 != xScr0) { 106 xScrollIsReceived = true; 107 } 108 109 if(yScr1 != yScr0) { 110 test_touchaction.step(function () { 111 yScrollIsReceived = true; 112 assert_true(true, "y-scroll received."); 113 }); 114 updateDescriptionNextStep(); 115 } 116 117 if(xScrollIsReceived && yScrollIsReceived) { 118 // Make sure the test finishes after all the input actions are completed. 119 actions_promise.then( () => { 120 test_touchaction.done(); 121 }); 122 updateDescriptionComplete(); 123 } 124 }); 125 126 // Inject touch inputs and wait for all the actions finish to end the test. 127 actions_promise = touchScrollInTarget(target0, 'down').then(function() { 128 return touchScrollInTarget(target0, 'right'); 129 }); 130 } 131 </script> 132 <h1>touch-action: pan-x pan-y</h1> 133 <div id="complete-notice"> 134 <p>The following pointer types were detected: <span id="pointertype-log"></span>.</p> 135 </div> 136 <div id="log"></div> 137 </body> 138 </html>