Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "content/browser/renderer_host/input/touch_event_queue.h" | 5 #include "content/browser/renderer_host/input/touch_event_queue.h" |
| 6 | 6 |
| 7 #include <stddef.h> | 7 #include <stddef.h> |
| 8 | 8 |
| 9 #include <memory> | 9 #include <memory> |
| 10 #include <utility> | 10 #include <utility> |
| (...skipping 1371 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1382 EXPECT_EQ(0U, GetAndResetAckedEventCount()); | 1382 EXPECT_EQ(0U, GetAndResetAckedEventCount()); |
| 1383 EXPECT_EQ(0U, GetAndResetSentEventCount()); | 1383 EXPECT_EQ(0U, GetAndResetSentEventCount()); |
| 1384 | 1384 |
| 1385 // Subsequent events should be handled normally. | 1385 // Subsequent events should be handled normally. |
| 1386 PressTouchPoint(0, 1); | 1386 PressTouchPoint(0, 1); |
| 1387 EXPECT_EQ(1U, GetAndResetSentEventCount()); | 1387 EXPECT_EQ(1U, GetAndResetSentEventCount()); |
| 1388 EXPECT_EQ(0U, GetAndResetAckedEventCount()); | 1388 EXPECT_EQ(0U, GetAndResetAckedEventCount()); |
| 1389 } | 1389 } |
| 1390 | 1390 |
| 1391 // Tests that TouchMove's are dropped if within the boundary-inclusive slop | 1391 // Tests that TouchMove's are dropped if within the boundary-inclusive slop |
| 1392 // suppression region for an unconsumed TouchStart. | 1392 // suppression region for an unconsumed TouchStart. |
|
tdresser
2017/02/02 21:30:54
Remove references in this file to slop suppression
lanwei
2017/02/03 21:39:33
Done.
| |
| 1393 TEST_F(TouchEventQueueTest, TouchMoveSuppressionIncludingSlopBoundary) { | 1393 TEST_F(TouchEventQueueTest, TouchMoveSuppressionIncludingSlopBoundary) { |
| 1394 SetUpForTouchMoveSlopTesting(kSlopLengthDips); | 1394 SetUpForTouchMoveSlopTesting(kSlopLengthDips); |
| 1395 | 1395 |
| 1396 // Queue a TouchStart. | 1396 // Queue a TouchStart. |
| 1397 PressTouchPoint(0, 0); | 1397 PressTouchPoint(0, 0); |
| 1398 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); | 1398 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); |
| 1399 ASSERT_EQ(1U, GetAndResetSentEventCount()); | 1399 ASSERT_EQ(1U, GetAndResetSentEventCount()); |
| 1400 ASSERT_EQ(1U, GetAndResetAckedEventCount()); | 1400 ASSERT_EQ(1U, GetAndResetAckedEventCount()); |
| 1401 | 1401 |
| 1402 // TouchMove's within the region should be suppressed. | 1402 // TouchMove's within the region will not be suppressed in the browser side, |
| 1403 // but its movedBeyondSlopRegion is set to false. | |
| 1403 MoveTouchPoint(0, 0, kHalfSlopLengthDips); | 1404 MoveTouchPoint(0, 0, kHalfSlopLengthDips); |
| 1404 EXPECT_EQ(0U, queued_event_count()); | 1405 EXPECT_EQ(1U, queued_event_count()); |
| 1405 EXPECT_EQ(0U, GetAndResetSentEventCount()); | 1406 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); |
| 1407 EXPECT_EQ(1U, GetAndResetSentEventCount()); | |
| 1406 EXPECT_EQ(1U, GetAndResetAckedEventCount()); | 1408 EXPECT_EQ(1U, GetAndResetAckedEventCount()); |
| 1407 EXPECT_EQ(INPUT_EVENT_ACK_STATE_NOT_CONSUMED, acked_event_state()); | 1409 EXPECT_FALSE(acked_event().movedBeyondSlopRegion); |
| 1408 | 1410 |
| 1409 MoveTouchPoint(0, kHalfSlopLengthDips, 0); | 1411 MoveTouchPoint(0, kHalfSlopLengthDips, 0); |
| 1410 EXPECT_EQ(0U, queued_event_count()); | 1412 EXPECT_EQ(1U, queued_event_count()); |
| 1411 EXPECT_EQ(0U, GetAndResetSentEventCount()); | 1413 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); |
| 1414 EXPECT_EQ(1U, GetAndResetSentEventCount()); | |
| 1412 EXPECT_EQ(1U, GetAndResetAckedEventCount()); | 1415 EXPECT_EQ(1U, GetAndResetAckedEventCount()); |
| 1413 EXPECT_EQ(INPUT_EVENT_ACK_STATE_NOT_CONSUMED, acked_event_state()); | 1416 EXPECT_FALSE(acked_event().movedBeyondSlopRegion); |
| 1414 | 1417 |
| 1415 MoveTouchPoint(0, -kHalfSlopLengthDips, 0); | 1418 MoveTouchPoint(0, -kHalfSlopLengthDips, 0); |
| 1416 EXPECT_EQ(0U, queued_event_count()); | 1419 EXPECT_EQ(1U, queued_event_count()); |
| 1417 EXPECT_EQ(0U, GetAndResetSentEventCount()); | 1420 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); |
| 1421 EXPECT_EQ(1U, GetAndResetSentEventCount()); | |
| 1418 EXPECT_EQ(1U, GetAndResetAckedEventCount()); | 1422 EXPECT_EQ(1U, GetAndResetAckedEventCount()); |
| 1419 EXPECT_EQ(INPUT_EVENT_ACK_STATE_NOT_CONSUMED, acked_event_state()); | 1423 EXPECT_FALSE(acked_event().movedBeyondSlopRegion); |
| 1420 | 1424 |
| 1421 MoveTouchPoint(0, -kSlopLengthDips, 0); | 1425 MoveTouchPoint(0, -kSlopLengthDips, 0); |
| 1422 EXPECT_EQ(0U, queued_event_count()); | 1426 EXPECT_EQ(1U, queued_event_count()); |
| 1423 EXPECT_EQ(0U, GetAndResetSentEventCount()); | 1427 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); |
| 1428 EXPECT_EQ(1U, GetAndResetSentEventCount()); | |
| 1424 EXPECT_EQ(1U, GetAndResetAckedEventCount()); | 1429 EXPECT_EQ(1U, GetAndResetAckedEventCount()); |
| 1425 EXPECT_EQ(INPUT_EVENT_ACK_STATE_NOT_CONSUMED, acked_event_state()); | 1430 EXPECT_FALSE(acked_event().movedBeyondSlopRegion); |
| 1426 | 1431 |
| 1427 MoveTouchPoint(0, 0, kSlopLengthDips); | 1432 MoveTouchPoint(0, 0, kSlopLengthDips); |
| 1428 EXPECT_EQ(0U, queued_event_count()); | 1433 EXPECT_EQ(1U, queued_event_count()); |
| 1429 EXPECT_EQ(0U, GetAndResetSentEventCount()); | 1434 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); |
| 1435 EXPECT_EQ(1U, GetAndResetSentEventCount()); | |
| 1430 EXPECT_EQ(1U, GetAndResetAckedEventCount()); | 1436 EXPECT_EQ(1U, GetAndResetAckedEventCount()); |
| 1431 EXPECT_EQ(INPUT_EVENT_ACK_STATE_NOT_CONSUMED, acked_event_state()); | 1437 EXPECT_FALSE(acked_event().movedBeyondSlopRegion); |
| 1432 | 1438 |
| 1433 // As soon as a TouchMove exceeds the (Euclidean) distance, no more | 1439 // When a TouchMove exceeds the (Euclidean) distance, the TouchMove's should |
| 1434 // TouchMove's should be suppressed. | 1440 // not be suppressed and its movedBeyondSlopRegion is set to true. |
|
tdresser
2017/02/02 21:30:54
Don't refer to suppression here anymore. It implie
lanwei
2017/02/03 21:39:33
Done.
| |
| 1435 const float kFortyFiveDegreeSlopLengthXY = | 1441 const float kFortyFiveDegreeSlopLengthXY = |
| 1436 kSlopLengthDips * std::sqrt(2.f) / 2; | 1442 kSlopLengthDips * std::sqrt(2.f) / 2; |
| 1437 MoveTouchPoint(0, kFortyFiveDegreeSlopLengthXY + .2f, | 1443 MoveTouchPoint(0, kFortyFiveDegreeSlopLengthXY + .2f, |
| 1438 kFortyFiveDegreeSlopLengthXY + .2f); | 1444 kFortyFiveDegreeSlopLengthXY + .2f); |
| 1439 EXPECT_EQ(1U, queued_event_count()); | 1445 EXPECT_EQ(1U, queued_event_count()); |
| 1440 EXPECT_EQ(1U, GetAndResetSentEventCount()); | 1446 EXPECT_EQ(1U, GetAndResetSentEventCount()); |
| 1441 EXPECT_EQ(0U, GetAndResetAckedEventCount()); | 1447 EXPECT_EQ(0U, GetAndResetAckedEventCount()); |
| 1442 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); | 1448 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); |
| 1443 EXPECT_EQ(1U, GetAndResetAckedEventCount()); | 1449 EXPECT_EQ(1U, GetAndResetAckedEventCount()); |
| 1450 EXPECT_TRUE(acked_event().movedBeyondSlopRegion); | |
| 1444 | 1451 |
| 1445 // Even TouchMove's within the original slop region should now be forwarded. | 1452 // Even TouchMove's within the original slop region should now be forwarded. |
| 1446 MoveTouchPoint(0, 0, 0); | 1453 MoveTouchPoint(0, 0, 0); |
| 1447 EXPECT_EQ(1U, queued_event_count()); | 1454 EXPECT_EQ(1U, queued_event_count()); |
| 1448 EXPECT_EQ(1U, GetAndResetSentEventCount()); | 1455 EXPECT_EQ(1U, GetAndResetSentEventCount()); |
| 1449 EXPECT_EQ(0U, GetAndResetAckedEventCount()); | 1456 EXPECT_EQ(0U, GetAndResetAckedEventCount()); |
| 1450 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); | 1457 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); |
| 1451 EXPECT_EQ(1U, GetAndResetAckedEventCount()); | 1458 EXPECT_EQ(1U, GetAndResetAckedEventCount()); |
| 1452 | 1459 |
| 1453 // A new touch sequence should reset suppression. | 1460 // A new touch sequence should reset suppression. |
| 1454 ReleaseTouchPoint(0); | 1461 ReleaseTouchPoint(0); |
| 1455 PressTouchPoint(0, 0); | 1462 PressTouchPoint(0, 0); |
| 1456 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); | 1463 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); |
| 1457 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); | 1464 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); |
| 1458 ASSERT_EQ(2U, GetAndResetSentEventCount()); | 1465 ASSERT_EQ(2U, GetAndResetSentEventCount()); |
| 1459 ASSERT_EQ(2U, GetAndResetAckedEventCount()); | 1466 ASSERT_EQ(2U, GetAndResetAckedEventCount()); |
| 1460 ASSERT_EQ(0U, queued_event_count()); | 1467 ASSERT_EQ(0U, queued_event_count()); |
| 1461 | 1468 |
| 1462 // The slop region is boundary-inclusive. | 1469 // The slop region is boundary-inclusive. |
| 1463 MoveTouchPoint(0, kSlopLengthDips - 1, 0); | 1470 MoveTouchPoint(0, kSlopLengthDips - 1, 0); |
| 1464 EXPECT_EQ(0U, queued_event_count()); | 1471 EXPECT_EQ(1U, queued_event_count()); |
| 1465 EXPECT_EQ(0U, GetAndResetSentEventCount()); | 1472 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); |
| 1473 EXPECT_EQ(1U, GetAndResetSentEventCount()); | |
| 1466 EXPECT_EQ(1U, GetAndResetAckedEventCount()); | 1474 EXPECT_EQ(1U, GetAndResetAckedEventCount()); |
| 1475 EXPECT_FALSE(acked_event().movedBeyondSlopRegion); | |
| 1476 | |
| 1467 | 1477 |
| 1468 MoveTouchPoint(0, kSlopLengthDips, 0); | 1478 MoveTouchPoint(0, kSlopLengthDips, 0); |
| 1469 EXPECT_EQ(0U, queued_event_count()); | 1479 EXPECT_EQ(1U, queued_event_count()); |
| 1470 EXPECT_EQ(0U, GetAndResetSentEventCount()); | 1480 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); |
| 1481 EXPECT_EQ(1U, GetAndResetSentEventCount()); | |
| 1471 EXPECT_EQ(1U, GetAndResetAckedEventCount()); | 1482 EXPECT_EQ(1U, GetAndResetAckedEventCount()); |
| 1483 EXPECT_FALSE(acked_event().movedBeyondSlopRegion); | |
| 1472 } | 1484 } |
| 1473 | 1485 |
| 1474 // Tests that TouchMove's are not dropped within the slop suppression region if | 1486 // Tests that TouchMove's are not dropped within the slop suppression region if |
| 1475 // the touchstart was consumed. | 1487 // the touchstart was consumed. |
| 1476 TEST_F(TouchEventQueueTest, NoTouchMoveSuppressionAfterTouchConsumed) { | 1488 TEST_F(TouchEventQueueTest, NoTouchMoveSuppressionAfterTouchConsumed) { |
| 1477 SetUpForTouchMoveSlopTesting(kSlopLengthDips); | 1489 SetUpForTouchMoveSlopTesting(kSlopLengthDips); |
| 1478 | 1490 |
| 1479 // Queue a TouchStart. | 1491 // Queue a TouchStart. |
| 1480 PressTouchPoint(0, 0); | 1492 PressTouchPoint(0, 0); |
| 1481 SendTouchEventAck(INPUT_EVENT_ACK_STATE_CONSUMED); | 1493 SendTouchEventAck(INPUT_EVENT_ACK_STATE_CONSUMED); |
| (...skipping 28 matching lines...) Expand all Loading... | |
| 1510 // during any movement. | 1522 // during any movement. |
| 1511 TEST_F(TouchEventQueueTest, NoTouchMoveSuppressionAfterMultiTouch) { | 1523 TEST_F(TouchEventQueueTest, NoTouchMoveSuppressionAfterMultiTouch) { |
| 1512 SetUpForTouchMoveSlopTesting(kSlopLengthDips); | 1524 SetUpForTouchMoveSlopTesting(kSlopLengthDips); |
| 1513 | 1525 |
| 1514 // Queue a TouchStart. | 1526 // Queue a TouchStart. |
| 1515 PressTouchPoint(0, 0); | 1527 PressTouchPoint(0, 0); |
| 1516 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); | 1528 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); |
| 1517 ASSERT_EQ(1U, GetAndResetSentEventCount()); | 1529 ASSERT_EQ(1U, GetAndResetSentEventCount()); |
| 1518 ASSERT_EQ(1U, GetAndResetAckedEventCount()); | 1530 ASSERT_EQ(1U, GetAndResetAckedEventCount()); |
| 1519 | 1531 |
| 1520 // TouchMove's within the region should be suppressed. | 1532 // TouchMove's within the region will not be suppressed in the browser side, |
| 1533 // but its movedBeyondSlopRegion is set to true. | |
| 1521 MoveTouchPoint(0, 0, kHalfSlopLengthDips); | 1534 MoveTouchPoint(0, 0, kHalfSlopLengthDips); |
| 1522 EXPECT_EQ(0U, queued_event_count()); | 1535 EXPECT_EQ(1U, queued_event_count()); |
| 1523 EXPECT_EQ(0U, GetAndResetSentEventCount()); | 1536 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); |
| 1537 EXPECT_EQ(1U, GetAndResetSentEventCount()); | |
| 1524 EXPECT_EQ(1U, GetAndResetAckedEventCount()); | 1538 EXPECT_EQ(1U, GetAndResetAckedEventCount()); |
| 1539 EXPECT_FALSE(acked_event().movedBeyondSlopRegion); | |
| 1525 | 1540 |
| 1526 // Simulate a secondary pointer press. | 1541 // Simulate a secondary pointer press. |
| 1527 PressTouchPoint(kSlopLengthDips, 0); | 1542 PressTouchPoint(kSlopLengthDips, 0); |
| 1528 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); | 1543 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); |
| 1529 EXPECT_EQ(1U, GetAndResetSentEventCount()); | 1544 EXPECT_EQ(1U, GetAndResetSentEventCount()); |
| 1530 EXPECT_EQ(1U, GetAndResetAckedEventCount()); | 1545 EXPECT_EQ(1U, GetAndResetAckedEventCount()); |
| 1531 | 1546 |
| 1532 // TouchMove with a secondary pointer should not be suppressed. | 1547 // TouchMove with a secondary pointer should not be suppressed. |
| 1533 MoveTouchPoint(1, kSlopLengthDips+1, 0); | 1548 MoveTouchPoint(1, kSlopLengthDips+1, 0); |
| 1534 EXPECT_EQ(1U, queued_event_count()); | 1549 EXPECT_EQ(1U, queued_event_count()); |
| 1535 EXPECT_EQ(1U, GetAndResetSentEventCount()); | 1550 EXPECT_EQ(1U, GetAndResetSentEventCount()); |
| 1536 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); | 1551 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); |
| 1537 EXPECT_EQ(1U, GetAndResetAckedEventCount()); | 1552 EXPECT_EQ(1U, GetAndResetAckedEventCount()); |
| 1538 | 1553 |
| 1539 // Release the secondary pointer. | 1554 // Release the secondary pointer. |
| 1540 ReleaseTouchPoint(0); | 1555 ReleaseTouchPoint(0); |
| 1541 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); | 1556 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); |
| 1542 EXPECT_EQ(1U, GetAndResetSentEventCount()); | 1557 EXPECT_EQ(1U, GetAndResetSentEventCount()); |
| 1543 EXPECT_EQ(1U, GetAndResetAckedEventCount()); | 1558 EXPECT_EQ(1U, GetAndResetAckedEventCount()); |
| 1544 | 1559 |
| 1545 // TouchMove's should not should be suppressed, even with the original | 1560 // TouchMove's should not be suppressed, even with the original |
|
tdresser
2017/02/02 21:30:54
Don't talk about suppression anymore.
lanwei
2017/02/03 21:39:33
Done.
| |
| 1546 // unmoved pointer. | 1561 // unmoved pointer. |
| 1547 MoveTouchPoint(0, 0, 0); | 1562 MoveTouchPoint(0, 0, 0); |
| 1548 EXPECT_EQ(1U, queued_event_count()); | 1563 EXPECT_EQ(1U, queued_event_count()); |
| 1549 EXPECT_EQ(1U, GetAndResetSentEventCount()); | 1564 EXPECT_EQ(1U, GetAndResetSentEventCount()); |
| 1550 EXPECT_EQ(0U, GetAndResetAckedEventCount()); | 1565 EXPECT_EQ(0U, GetAndResetAckedEventCount()); |
| 1551 } | 1566 } |
| 1552 | 1567 |
| 1553 // Tests that secondary touch points can be forwarded even if the primary touch | 1568 // Tests that secondary touch points can be forwarded even if the primary touch |
| 1554 // point had no consumer. | 1569 // point had no consumer. |
| 1555 TEST_F(TouchEventQueueTest, SecondaryTouchForwardedAfterPrimaryHadNoConsumer) { | 1570 TEST_F(TouchEventQueueTest, SecondaryTouchForwardedAfterPrimaryHadNoConsumer) { |
| (...skipping 1196 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 2752 EXPECT_EQ(WebInputEvent::TouchMove, sent_event().type()); | 2767 EXPECT_EQ(WebInputEvent::TouchMove, sent_event().type()); |
| 2753 EXPECT_FALSE(sent_event().touchStartOrFirstTouchMove); | 2768 EXPECT_FALSE(sent_event().touchStartOrFirstTouchMove); |
| 2754 | 2769 |
| 2755 ReleaseTouchPoint(0); | 2770 ReleaseTouchPoint(0); |
| 2756 SendTouchEventAck(INPUT_EVENT_ACK_STATE_CONSUMED); | 2771 SendTouchEventAck(INPUT_EVENT_ACK_STATE_CONSUMED); |
| 2757 EXPECT_EQ(WebInputEvent::TouchEnd, sent_event().type()); | 2772 EXPECT_EQ(WebInputEvent::TouchEnd, sent_event().type()); |
| 2758 EXPECT_FALSE(sent_event().touchStartOrFirstTouchMove); | 2773 EXPECT_FALSE(sent_event().touchStartOrFirstTouchMove); |
| 2759 } | 2774 } |
| 2760 | 2775 |
| 2761 } // namespace content | 2776 } // namespace content |
| OLD | NEW |