pointerevent_touch-action-mouse.html (6544B)
1 <!doctype html> 2 <html> 3 <head> 4 <title>touch-action: mouse</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: none; 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 using mouse (use mouse wheel or click on the scrollbar). Wait for description update.</h4> 24 <p>Note: this test is for mouse 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 updateDescriptionNextStepMouse(); 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 const posOffsetX = 0; 127 const posOffsetY = 0; 128 const scrollDeltaX = 200; 129 const scrollDeltaY = 200; 130 actions_promise = new test_driver.Actions() 131 .scroll(posOffsetX, posOffsetY, scrollDeltaX, scrollDeltaY, 132 {origin: target0}) 133 .send(); 134 } 135 136 function updateDescriptionNextStepMouse() { 137 document.getElementById('desc').innerHTML = "Test Description: Try to scroll text right using mouse (use mouse wheel or click on the scrollbar)."; 138 } 139 </script> 140 <h1>touch-action: none</h1> 141 <div id="complete-notice"> 142 <p>The following pointer types were detected: <span id="pointertype-log"></span>.</p> 143 </div> 144 <div id="log"></div> 145 </body> 146 </html>