| Index: ash/touch/touch_transformer_controller_unittest.cc
|
| diff --git a/ash/touch/touch_transformer_controller_unittest.cc b/ash/touch/touch_transformer_controller_unittest.cc
|
| deleted file mode 100644
|
| index 0b6b9a3703f73f4f41cfa57127f196880dfe79eb..0000000000000000000000000000000000000000
|
| --- a/ash/touch/touch_transformer_controller_unittest.cc
|
| +++ /dev/null
|
| @@ -1,828 +0,0 @@
|
| -// Copyright 2014 The Chromium Authors. All rights reserved.
|
| -// Use of this source code is governed by a BSD-style license that can be
|
| -// found in the LICENSE file.
|
| -
|
| -#include "ash/touch/touch_transformer_controller.h"
|
| -
|
| -#include "ash/shell.h"
|
| -#include "ash/test/ash_test_base.h"
|
| -#include "base/rand_util.h"
|
| -#include "base/strings/string_number_conversions.h"
|
| -#include "ui/aura/window_tree_host.h"
|
| -#include "ui/events/devices/device_data_manager.h"
|
| -
|
| -namespace ash {
|
| -
|
| -namespace {
|
| -
|
| -constexpr int kDisplayId1 = 1;
|
| -constexpr int kTouchId1 = 5;
|
| -
|
| -display::ManagedDisplayInfo CreateDisplayInfo(int64_t id,
|
| - unsigned int touch_device_id,
|
| - const gfx::Rect& bounds) {
|
| - display::ManagedDisplayInfo info(id, std::string(), false);
|
| - info.SetBounds(bounds);
|
| - info.AddInputDevice(touch_device_id);
|
| -
|
| - // Create a default mode.
|
| - display::ManagedDisplayInfo::ManagedDisplayModeList default_modes(
|
| - 1, make_scoped_refptr(
|
| - new display::ManagedDisplayMode(bounds.size(), 60, false, true)));
|
| - info.SetManagedDisplayModes(default_modes);
|
| -
|
| - return info;
|
| -}
|
| -
|
| -ui::TouchscreenDevice CreateTouchscreenDevice(unsigned int id,
|
| - const gfx::Size& size) {
|
| - return ui::TouchscreenDevice(id, ui::InputDeviceType::INPUT_DEVICE_EXTERNAL,
|
| - std::string(), size, 0);
|
| -}
|
| -
|
| -std::string GetTouchPointString(
|
| - const display::TouchCalibrationData::CalibrationPointPairQuad& pts) {
|
| - std::string str = "Failed for point pairs: ";
|
| - for (std::size_t row = 0; row < pts.size(); row++) {
|
| - str += "{(" + base::IntToString(pts[row].first.x()) + "," +
|
| - base::IntToString(pts[row].first.y()) + "), (" +
|
| - base::IntToString(pts[row].second.x()) + "," +
|
| - base::IntToString(pts[row].second.y()) + ")} ";
|
| - }
|
| - return str;
|
| -}
|
| -
|
| -// Checks if the touch input has been calibrated properly. The input is said to
|
| -// be calibrated if any touch input is transformed to the correct corresponding
|
| -// display point within an error delta of |max_error_delta.width()| along the X
|
| -// axis and |max_error_delta.height()| along the Y axis;
|
| -void CheckPointsOfInterests(const int touch_id,
|
| - const gfx::Size& touch_size,
|
| - const gfx::Size& display_size,
|
| - const gfx::Size& max_error_delta,
|
| - const std::string& error_msg) {
|
| - ui::DeviceDataManager* device_manager = ui::DeviceDataManager::GetInstance();
|
| - float x, y;
|
| -
|
| - // Origin of the touch device should correspond to origin of the display.
|
| - x = y = 0.0;
|
| - device_manager->ApplyTouchTransformer(touch_id, &x, &y);
|
| - EXPECT_NEAR(0, x, max_error_delta.width()) << error_msg;
|
| - EXPECT_NEAR(0, y, max_error_delta.height()) << error_msg;
|
| -
|
| - // Center of the touch device should correspond to the center of the display
|
| - // device.
|
| - x = touch_size.width() / 2;
|
| - y = touch_size.height() / 2;
|
| - device_manager->ApplyTouchTransformer(touch_id, &x, &y);
|
| - EXPECT_NEAR(display_size.width() / 2, x, max_error_delta.width())
|
| - << error_msg;
|
| - EXPECT_NEAR(display_size.height() / 2, y, max_error_delta.height())
|
| - << error_msg;
|
| -
|
| - // Bottom right corner of the touch device should correspond to rightmost
|
| - // corner of display device.
|
| - x = touch_size.width();
|
| - y = touch_size.height();
|
| - device_manager->ApplyTouchTransformer(touch_id, &x, &y);
|
| - EXPECT_NEAR(display_size.width(), x, max_error_delta.width()) << error_msg;
|
| - EXPECT_NEAR(display_size.height(), y, max_error_delta.height()) << error_msg;
|
| -}
|
| -
|
| -} // namespace
|
| -
|
| -class TouchTransformerControllerTest : public test::AshTestBase {
|
| - public:
|
| - TouchTransformerControllerTest() {}
|
| - ~TouchTransformerControllerTest() override {}
|
| -
|
| - gfx::Transform GetTouchTransform(
|
| - const display::ManagedDisplayInfo& display,
|
| - const display::ManagedDisplayInfo& touch_display,
|
| - const ui::TouchscreenDevice& touchscreen,
|
| - const gfx::Size& framebuffer_size) const {
|
| - return Shell::GetInstance()
|
| - ->touch_transformer_controller()
|
| - ->GetTouchTransform(display, touch_display, touchscreen,
|
| - framebuffer_size);
|
| - }
|
| -
|
| - double GetTouchResolutionScale(
|
| - const display::ManagedDisplayInfo& touch_display,
|
| - const ui::TouchscreenDevice& touch_device) const {
|
| - return Shell::GetInstance()
|
| - ->touch_transformer_controller()
|
| - ->GetTouchResolutionScale(touch_display, touch_device);
|
| - }
|
| -
|
| - private:
|
| - DISALLOW_COPY_AND_ASSIGN(TouchTransformerControllerTest);
|
| -};
|
| -
|
| -TEST_F(TouchTransformerControllerTest, MirrorModeLetterboxing) {
|
| - // The internal display has native resolution of 2560x1700, and in
|
| - // mirror mode it is configured as 1920x1200. This is in letterboxing
|
| - // mode.
|
| - display::ManagedDisplayInfo internal_display_info =
|
| - CreateDisplayInfo(1, 10u, gfx::Rect(0, 0, 1920, 1200));
|
| - internal_display_info.set_is_aspect_preserving_scaling(true);
|
| -
|
| - display::ManagedDisplayInfo::ManagedDisplayModeList internal_modes;
|
| -
|
| - internal_modes.push_back(make_scoped_refptr(
|
| - new display::ManagedDisplayMode(gfx::Size(2560, 1700), 60, false, true)));
|
| - internal_modes.push_back(make_scoped_refptr(new display::ManagedDisplayMode(
|
| - gfx::Size(1920, 1200), 60, false, false)));
|
| - internal_display_info.SetManagedDisplayModes(internal_modes);
|
| -
|
| - display::ManagedDisplayInfo external_display_info =
|
| - CreateDisplayInfo(2, 11u, gfx::Rect(0, 0, 1920, 1200));
|
| -
|
| - gfx::Size fb_size(1920, 1200);
|
| -
|
| - // Create the touchscreens with the same size as the framebuffer so we can
|
| - // share the tests between Ozone & X11.
|
| - ui::TouchscreenDevice internal_touchscreen =
|
| - CreateTouchscreenDevice(10, fb_size);
|
| - ui::TouchscreenDevice external_touchscreen =
|
| - CreateTouchscreenDevice(11, fb_size);
|
| -
|
| - ui::DeviceDataManager* device_manager = ui::DeviceDataManager::GetInstance();
|
| -
|
| - device_manager->UpdateTouchInfoForDisplay(
|
| - internal_display_info.id(), internal_touchscreen.id,
|
| - GetTouchTransform(internal_display_info, internal_display_info,
|
| - internal_touchscreen, fb_size));
|
| -
|
| - device_manager->UpdateTouchInfoForDisplay(
|
| - internal_display_info.id(), external_touchscreen.id,
|
| - GetTouchTransform(external_display_info, external_display_info,
|
| - external_touchscreen, fb_size));
|
| -
|
| - EXPECT_EQ(1, device_manager->GetTargetDisplayForTouchDevice(10));
|
| - EXPECT_EQ(1, device_manager->GetTargetDisplayForTouchDevice(11));
|
| -
|
| - // External touch display has the default TouchTransformer.
|
| - float x = 100.0;
|
| - float y = 100.0;
|
| - device_manager->ApplyTouchTransformer(11, &x, &y);
|
| - EXPECT_EQ(100, x);
|
| - EXPECT_EQ(100, y);
|
| -
|
| - // In letterboxing, there is (1-2560*(1200/1920)/1700)/2 = 2.95% of the
|
| - // height on both the top & bottom region of the screen is blank.
|
| - // When touch events coming at Y range [0, 1200), the mapping should be
|
| - // [0, ~35] ---> < 0
|
| - // [~35, ~1165] ---> [0, 1200)
|
| - // [~1165, 1200] ---> >= 1200
|
| - x = 100.0;
|
| - y = 35.0;
|
| - device_manager->ApplyTouchTransformer(10, &x, &y);
|
| - EXPECT_NEAR(100, x, 0.5);
|
| - EXPECT_NEAR(0, y, 0.5);
|
| -
|
| - x = 100.0;
|
| - y = 1165.0;
|
| - device_manager->ApplyTouchTransformer(10, &x, &y);
|
| - EXPECT_NEAR(100, x, 0.5);
|
| - EXPECT_NEAR(1200, y, 0.5);
|
| -}
|
| -
|
| -TEST_F(TouchTransformerControllerTest, MirrorModePillarboxing) {
|
| - // The internal display has native resolution of 1366x768, and in
|
| - // mirror mode it is configured as 1024x768. This is in pillarboxing
|
| - // mode.
|
| - display::ManagedDisplayInfo internal_display_info =
|
| - CreateDisplayInfo(1, 10, gfx::Rect(0, 0, 1024, 768));
|
| - internal_display_info.set_is_aspect_preserving_scaling(true);
|
| - display::ManagedDisplayInfo::ManagedDisplayModeList internal_modes;
|
| - internal_modes.push_back(make_scoped_refptr(
|
| - new display::ManagedDisplayMode(gfx::Size(1366, 768), 60, false, true)));
|
| - internal_modes.push_back(make_scoped_refptr(
|
| - new display::ManagedDisplayMode(gfx::Size(1024, 768), 60, false, false)));
|
| - internal_display_info.SetManagedDisplayModes(internal_modes);
|
| -
|
| - display::ManagedDisplayInfo external_display_info =
|
| - CreateDisplayInfo(2, 11, gfx::Rect(0, 0, 1024, 768));
|
| -
|
| - gfx::Size fb_size(1024, 768);
|
| -
|
| - // Create the touchscreens with the same size as the framebuffer so we can
|
| - // share the tests between Ozone & X11.
|
| - ui::TouchscreenDevice internal_touchscreen =
|
| - CreateTouchscreenDevice(10, fb_size);
|
| - ui::TouchscreenDevice external_touchscreen =
|
| - CreateTouchscreenDevice(11, fb_size);
|
| -
|
| - ui::DeviceDataManager* device_manager = ui::DeviceDataManager::GetInstance();
|
| -
|
| - device_manager->UpdateTouchInfoForDisplay(
|
| - internal_display_info.id(), internal_touchscreen.id,
|
| - GetTouchTransform(internal_display_info, internal_display_info,
|
| - internal_touchscreen, fb_size));
|
| -
|
| - device_manager->UpdateTouchInfoForDisplay(
|
| - internal_display_info.id(), external_touchscreen.id,
|
| - GetTouchTransform(external_display_info, external_display_info,
|
| - external_touchscreen, fb_size));
|
| -
|
| - EXPECT_EQ(1, device_manager->GetTargetDisplayForTouchDevice(10));
|
| - EXPECT_EQ(1, device_manager->GetTargetDisplayForTouchDevice(11));
|
| -
|
| - // External touch display has the default TouchTransformer.
|
| - float x = 100.0;
|
| - float y = 100.0;
|
| - device_manager->ApplyTouchTransformer(11, &x, &y);
|
| - EXPECT_EQ(100, x);
|
| - EXPECT_EQ(100, y);
|
| -
|
| - // In pillarboxing, there is (1-768*(1024/768)/1366)/2 = 12.5% of the
|
| - // width on both the left & rigth region of the screen is blank.
|
| - // When touch events coming at X range [0, 1024), the mapping should be
|
| - // [0, ~128] ---> < 0
|
| - // [~128, ~896] ---> [0, 1024)
|
| - // [~896, 1024] ---> >= 1024
|
| - x = 128.0;
|
| - y = 100.0;
|
| - device_manager->ApplyTouchTransformer(10, &x, &y);
|
| - EXPECT_NEAR(0, x, 0.5);
|
| - EXPECT_NEAR(100, y, 0.5);
|
| -
|
| - x = 896.0;
|
| - y = 100.0;
|
| - device_manager->ApplyTouchTransformer(10, &x, &y);
|
| - EXPECT_NEAR(1024, x, 0.5);
|
| - EXPECT_NEAR(100, y, 0.5);
|
| -}
|
| -
|
| -TEST_F(TouchTransformerControllerTest, SoftwareMirrorMode) {
|
| - // External display 1 has size 1280x850. External display 2 has size
|
| - // 1920x1080. When using software mirroring to mirror display 1 onto
|
| - // display 2, the displays are in extended mode and we map touches from both
|
| - // displays to display 1.
|
| - // The total frame buffer is 1920x1990,
|
| - // where 1990 = 850 + 60 (hidden gap) + 1080 and the second monitor is
|
| - // translated to point (0, 950) in the framebuffer.
|
| - display::ManagedDisplayInfo display1_info =
|
| - CreateDisplayInfo(1, 10u, gfx::Rect(0, 0, 1280, 850));
|
| - display::ManagedDisplayInfo::ManagedDisplayModeList display1_modes;
|
| - display1_modes.push_back(make_scoped_refptr(
|
| - new display::ManagedDisplayMode(gfx::Size(1280, 850), 60, false, true)));
|
| - display1_info.SetManagedDisplayModes(display1_modes);
|
| -
|
| - display::ManagedDisplayInfo display2_info =
|
| - CreateDisplayInfo(2, 11u, gfx::Rect(0, 950, 1920, 1080));
|
| - display::ManagedDisplayInfo::ManagedDisplayModeList display2_modes;
|
| - display2_modes.push_back(make_scoped_refptr(
|
| - new display::ManagedDisplayMode(gfx::Size(1920, 1080), 60, false, true)));
|
| - display2_info.SetManagedDisplayModes(display2_modes);
|
| -
|
| - gfx::Size fb_size(1920, 1990);
|
| -
|
| - // Create the touchscreens with the same size as the framebuffer so we can
|
| - // share the tests between Ozone & X11.
|
| - ui::TouchscreenDevice display1_touchscreen =
|
| - CreateTouchscreenDevice(10, fb_size);
|
| - ui::TouchscreenDevice display2_touchscreen =
|
| - CreateTouchscreenDevice(11, fb_size);
|
| -
|
| - ui::DeviceDataManager* device_manager = ui::DeviceDataManager::GetInstance();
|
| -
|
| - device_manager->UpdateTouchInfoForDisplay(
|
| - display1_info.id(), display1_touchscreen.id,
|
| - GetTouchTransform(display1_info, display1_info, display1_touchscreen,
|
| - fb_size));
|
| -
|
| - device_manager->UpdateTouchInfoForDisplay(
|
| - display1_info.id(), display2_touchscreen.id,
|
| - GetTouchTransform(display1_info, display2_info, display2_touchscreen,
|
| - fb_size));
|
| -
|
| - EXPECT_EQ(1, device_manager->GetTargetDisplayForTouchDevice(10));
|
| - EXPECT_EQ(1, device_manager->GetTargetDisplayForTouchDevice(11));
|
| -
|
| - // Mapping for touch events from display 1's touchscreen:
|
| - // [0, 1920) x [0, 1990) -> [0, 1280) x [0, 850)
|
| - float x = 0.0;
|
| - float y = 0.0;
|
| - device_manager->ApplyTouchTransformer(10, &x, &y);
|
| - EXPECT_NEAR(0, x, 0.5);
|
| - EXPECT_NEAR(0, y, 0.5);
|
| -
|
| - x = 1920.0;
|
| - y = 1990.0;
|
| - device_manager->ApplyTouchTransformer(10, &x, &y);
|
| - EXPECT_NEAR(1280, x, 0.5);
|
| - EXPECT_NEAR(850, y, 0.5);
|
| -
|
| - // In pillarboxing, there is (1-1280*(1080/850)/1920)/2 = 7.65% of the
|
| - // width on both the left & right region of the screen is blank.
|
| - // Events come in the range [0, 1920) x [0, 1990).
|
| - //
|
| - // X mapping:
|
| - // [0, ~147] ---> < 0
|
| - // [~147, ~1773] ---> [0, 1280)
|
| - // [~1773, 1920] ---> >= 1280
|
| - // Y mapping:
|
| - // [0, 1990) -> [0, 1080)
|
| - x = 147.0;
|
| - y = 0.0;
|
| - device_manager->ApplyTouchTransformer(11, &x, &y);
|
| - EXPECT_NEAR(0, x, 0.5);
|
| - EXPECT_NEAR(0, y, 0.5);
|
| -
|
| - x = 1773.0;
|
| - y = 1990.0;
|
| - device_manager->ApplyTouchTransformer(11, &x, &y);
|
| - EXPECT_NEAR(1280, x, 0.5);
|
| - EXPECT_NEAR(850, y, 0.5);
|
| -}
|
| -
|
| -TEST_F(TouchTransformerControllerTest, ExtendedMode) {
|
| - // The internal display has size 1366 x 768. The external display has
|
| - // size 2560x1600. The total frame buffer is 2560x2428,
|
| - // where 2428 = 768 + 60 (hidden gap) + 1600
|
| - // and the second monitor is translated to Point (0, 828) in the
|
| - // framebuffer.
|
| - display::ManagedDisplayInfo display1 =
|
| - CreateDisplayInfo(1, 5u, gfx::Rect(0, 0, 1366, 768));
|
| - display::ManagedDisplayInfo display2 =
|
| - CreateDisplayInfo(2, 6u, gfx::Rect(0, 828, 2560, 1600));
|
| - gfx::Size fb_size(2560, 2428);
|
| -
|
| - // Create the touchscreens with the same size as the framebuffer so we can
|
| - // share the tests between Ozone & X11.
|
| - ui::TouchscreenDevice touchscreen1 = CreateTouchscreenDevice(5, fb_size);
|
| - ui::TouchscreenDevice touchscreen2 = CreateTouchscreenDevice(6, fb_size);
|
| -
|
| - ui::DeviceDataManager* device_manager = ui::DeviceDataManager::GetInstance();
|
| -
|
| - device_manager->UpdateTouchInfoForDisplay(
|
| - display1.id(), touchscreen1.id,
|
| - GetTouchTransform(display1, display1, touchscreen1, fb_size));
|
| -
|
| - device_manager->UpdateTouchInfoForDisplay(
|
| - display2.id(), touchscreen2.id,
|
| - GetTouchTransform(display2, display2, touchscreen2, fb_size));
|
| -
|
| - EXPECT_EQ(1, device_manager->GetTargetDisplayForTouchDevice(5));
|
| - EXPECT_EQ(2, device_manager->GetTargetDisplayForTouchDevice(6));
|
| -
|
| - // Mapping for touch events from internal touch display:
|
| - // [0, 2560) x [0, 2428) -> [0, 1366) x [0, 768)
|
| - float x = 0.0;
|
| - float y = 0.0;
|
| - device_manager->ApplyTouchTransformer(5, &x, &y);
|
| - EXPECT_NEAR(0, x, 0.5);
|
| - EXPECT_NEAR(0, y, 0.5);
|
| -
|
| - x = 2559.0;
|
| - y = 2427.0;
|
| - device_manager->ApplyTouchTransformer(5, &x, &y);
|
| - EXPECT_NEAR(1365, x, 0.5);
|
| - EXPECT_NEAR(768, y, 0.5);
|
| -
|
| - // Mapping for touch events from external touch display:
|
| - // [0, 2560) x [0, 2428) -> [0, 2560) x [0, 1600)
|
| - x = 0.0;
|
| - y = 0.0;
|
| - device_manager->ApplyTouchTransformer(6, &x, &y);
|
| -#if defined(USE_OZONE)
|
| - // On ozone we expect screen coordinates so add display origin.
|
| - EXPECT_NEAR(0 + 0, x, 0.5);
|
| - EXPECT_NEAR(0 + 828, y, 0.5);
|
| -#else
|
| - EXPECT_NEAR(0, x, 0.5);
|
| - EXPECT_NEAR(0, y, 0.5);
|
| -#endif
|
| -
|
| - x = 2559.0;
|
| - y = 2427.0;
|
| - device_manager->ApplyTouchTransformer(6, &x, &y);
|
| -#if defined(USE_OZONE)
|
| - // On ozone we expect screen coordinates so add display origin.
|
| - EXPECT_NEAR(2559 + 0, x, 0.5);
|
| - EXPECT_NEAR(1599 + 828, y, 0.5);
|
| -#else
|
| - EXPECT_NEAR(2559, x, 0.5);
|
| - EXPECT_NEAR(1599, y, 0.5);
|
| -#endif
|
| -}
|
| -
|
| -TEST_F(TouchTransformerControllerTest, TouchRadiusScale) {
|
| - display::ManagedDisplayInfo display =
|
| - CreateDisplayInfo(1, 5u, gfx::Rect(0, 0, 2560, 1600));
|
| - ui::TouchscreenDevice touch_device =
|
| - CreateTouchscreenDevice(5, gfx::Size(1001, 1001));
|
| -
|
| - // Default touchscreen position range is 1001x1001;
|
| - EXPECT_EQ(sqrt((2560.0 * 1600.0) / (1001.0 * 1001.0)),
|
| - GetTouchResolutionScale(display, touch_device));
|
| -}
|
| -
|
| -TEST_F(TouchTransformerControllerTest, OzoneTranslation) {
|
| -#if defined(USE_OZONE)
|
| - // The internal display has size 1920 x 1200. The external display has
|
| - // size 1920x1200. The total frame buffer is 1920x2450,
|
| - // where 2458 = 1200 + 50 (hidden gap) + 1200
|
| - // and the second monitor is translated to Point (0, 1250) in the
|
| - // framebuffer.
|
| - const int kDisplayId2 = 2;
|
| - const int kTouchId2 = 6;
|
| - const gfx::Size kDisplaySize(1920, 1200);
|
| - const gfx::Size kTouchSize(1920, 1200);
|
| - const int kHiddenGap = 50;
|
| -
|
| - display::ManagedDisplayInfo display1 = CreateDisplayInfo(
|
| - kDisplayId1, kTouchId1,
|
| - gfx::Rect(0, 0, kDisplaySize.width(), kDisplaySize.height()));
|
| - display::ManagedDisplayInfo display2 =
|
| - CreateDisplayInfo(kDisplayId2, kTouchId2,
|
| - gfx::Rect(0, kDisplaySize.height() + kHiddenGap,
|
| - kDisplaySize.width(), kDisplaySize.height()));
|
| -
|
| - gfx::Size fb_size(1920, 2450);
|
| -
|
| - ui::TouchscreenDevice touchscreen1 =
|
| - CreateTouchscreenDevice(kTouchId1, kDisplaySize);
|
| - ui::TouchscreenDevice touchscreen2 =
|
| - CreateTouchscreenDevice(kTouchId2, kDisplaySize);
|
| -
|
| - ui::DeviceDataManager* device_manager = ui::DeviceDataManager::GetInstance();
|
| -
|
| - // Mirror displays. Touch screen 2 is associated to display 1.
|
| - device_manager->UpdateTouchInfoForDisplay(
|
| - display1.id(), touchscreen1.id,
|
| - GetTouchTransform(display1, display1, touchscreen1, kTouchSize));
|
| -
|
| - device_manager->UpdateTouchInfoForDisplay(
|
| - display1.id(), touchscreen2.id,
|
| - GetTouchTransform(display1, display2, touchscreen2, kTouchSize));
|
| -
|
| - EXPECT_EQ(kDisplayId1,
|
| - device_manager->GetTargetDisplayForTouchDevice(kTouchId1));
|
| - EXPECT_EQ(kDisplayId1,
|
| - device_manager->GetTargetDisplayForTouchDevice(kTouchId2));
|
| -
|
| - float x, y;
|
| -
|
| - x = y = 0.0;
|
| - device_manager->ApplyTouchTransformer(kTouchId1, &x, &y);
|
| - EXPECT_NEAR(0, x, 0.5);
|
| - EXPECT_NEAR(0, y, 0.5);
|
| -
|
| - x = y = 0.0;
|
| - device_manager->ApplyTouchTransformer(kTouchId2, &x, &y);
|
| - EXPECT_NEAR(0, x, 0.5);
|
| - EXPECT_NEAR(0, y, 0.5);
|
| -
|
| - x = 1920.0;
|
| - y = 1200.0;
|
| - device_manager->ApplyTouchTransformer(kTouchId1, &x, &y);
|
| - EXPECT_NEAR(1920, x, 0.5);
|
| - EXPECT_NEAR(1200, y, 0.5);
|
| -
|
| - x = 1920.0;
|
| - y = 1200.0;
|
| - device_manager->ApplyTouchTransformer(kTouchId2, &x, &y);
|
| - EXPECT_NEAR(1920, x, 0.5);
|
| - EXPECT_NEAR(1200, y, 0.5);
|
| -
|
| - // Remove mirroring of displays.
|
| - device_manager->UpdateTouchInfoForDisplay(
|
| - display2.id(), touchscreen2.id,
|
| - GetTouchTransform(display2, display2, touchscreen2, kTouchSize));
|
| -
|
| - x = 1920.0;
|
| - y = 1200.0;
|
| - device_manager->ApplyTouchTransformer(kTouchId1, &x, &y);
|
| - EXPECT_NEAR(1920, x, 0.5);
|
| - EXPECT_NEAR(1200, y, 0.5);
|
| -
|
| - x = 1920.0;
|
| - y = 1200.0;
|
| - device_manager->ApplyTouchTransformer(kTouchId2, &x, &y);
|
| - EXPECT_NEAR(1920, x, 0.5);
|
| - EXPECT_NEAR(1200 + kDisplaySize.height() + kHiddenGap, y, 0.5);
|
| -#endif // USE_OZONE
|
| -}
|
| -
|
| -TEST_F(TouchTransformerControllerTest, AccurateUserTouchCalibration) {
|
| - const gfx::Size kDisplaySize(1920, 1200);
|
| - const gfx::Size kTouchSize(1920, 1200);
|
| -
|
| - display::ManagedDisplayInfo display = CreateDisplayInfo(
|
| - kDisplayId1, kTouchId1,
|
| - gfx::Rect(0, 0, kDisplaySize.width(), kDisplaySize.height()));
|
| -
|
| - // Assuming the user provided accurate inputs during calibration. ie the user
|
| - // actually tapped (100,100) when asked to tap (100,100) with no human error.
|
| - display::TouchCalibrationData::CalibrationPointPairQuad user_input = {{
|
| - std::make_pair(gfx::Point(100, 100), gfx::Point(100, 100)),
|
| - std::make_pair(gfx::Point(1820, 100), gfx::Point(1820, 100)),
|
| - std::make_pair(gfx::Point(100, 1100), gfx::Point(100, 1100)),
|
| - std::make_pair(gfx::Point(1820, 1100), gfx::Point(1820, 1100)),
|
| - }};
|
| - display::TouchCalibrationData touch_data(user_input, kDisplaySize);
|
| - display.SetTouchCalibrationData(touch_data);
|
| - EXPECT_TRUE(display.has_touch_calibration_data());
|
| -
|
| - const std::string msg = GetTouchPointString(user_input);
|
| -
|
| - gfx::Size fb_size(1920, 1200);
|
| -
|
| - ui::TouchscreenDevice touchscreen =
|
| - CreateTouchscreenDevice(kTouchId1, kTouchSize);
|
| -
|
| - ui::DeviceDataManager* device_manager = ui::DeviceDataManager::GetInstance();
|
| -
|
| - device_manager->UpdateTouchInfoForDisplay(
|
| - display.id(), touchscreen.id,
|
| - GetTouchTransform(display, display, touchscreen, kTouchSize));
|
| -
|
| - EXPECT_EQ(kDisplayId1,
|
| - device_manager->GetTargetDisplayForTouchDevice(kTouchId1));
|
| -
|
| - CheckPointsOfInterests(kTouchId1, kTouchSize, kDisplaySize, gfx::Size(1, 1),
|
| - msg);
|
| -}
|
| -
|
| -TEST_F(TouchTransformerControllerTest, ErrorProneUserTouchCalibration) {
|
| - const gfx::Size kDisplaySize(1920, 1200);
|
| - const gfx::Size kTouchSize(1920, 1200);
|
| - // User touch inputs have a max error of 5%.
|
| - const float kError = 0.05;
|
| - // The maximum user error rate is |kError|%. Since the calibration is
|
| - // performed with a best fit algorithm, the error rate observed should be less
|
| - // than |kError|.
|
| - const gfx::Size kMaxErrorDelta = gfx::ScaleToCeiledSize(kTouchSize, kError);
|
| -
|
| - display::ManagedDisplayInfo display = CreateDisplayInfo(
|
| - kDisplayId1, kTouchId1,
|
| - gfx::Rect(0, 0, kDisplaySize.width(), kDisplaySize.height()));
|
| -
|
| - // Assuming the user provided inaccurate inputs during calibration. ie the
|
| - // user did not tap (100,100) when asked to tap (100,100) due to human error.
|
| - display::TouchCalibrationData::CalibrationPointPairQuad user_input = {
|
| - {std::make_pair(gfx::Point(100, 100), gfx::Point(130, 60)),
|
| - std::make_pair(gfx::Point(1820, 100), gfx::Point(1878, 130)),
|
| - std::make_pair(gfx::Point(100, 1100), gfx::Point(158, 1060)),
|
| - std::make_pair(gfx::Point(1820, 1100), gfx::Point(1790, 1140))}};
|
| - display::TouchCalibrationData touch_data(user_input, kDisplaySize);
|
| - display.SetTouchCalibrationData(touch_data);
|
| - EXPECT_TRUE(display.has_touch_calibration_data());
|
| -
|
| - const std::string msg = GetTouchPointString(user_input);
|
| -
|
| - ui::TouchscreenDevice touchscreen =
|
| - CreateTouchscreenDevice(kTouchId1, kTouchSize);
|
| -
|
| - ui::DeviceDataManager* device_manager = ui::DeviceDataManager::GetInstance();
|
| -
|
| - device_manager->UpdateTouchInfoForDisplay(
|
| - display.id(), touchscreen.id,
|
| - GetTouchTransform(display, display, touchscreen, kTouchSize));
|
| -
|
| - EXPECT_EQ(kDisplayId1,
|
| - device_manager->GetTargetDisplayForTouchDevice(kTouchId1));
|
| -
|
| - CheckPointsOfInterests(kTouchId1, kTouchSize, kDisplaySize, kMaxErrorDelta,
|
| - msg);
|
| -}
|
| -
|
| -TEST_F(TouchTransformerControllerTest, ResolutionChangeUserTouchCalibration) {
|
| - const gfx::Size kDisplaySize(2560, 1600);
|
| - const gfx::Size kTouchSize(1920, 1200);
|
| - // User touch inputs have a max error of 5%.
|
| - const float kError = 0.05;
|
| - // The maximum user error rate is |kError|%. Since the calibration is
|
| - // performed with a best fit algorithm, the error rate observed should be less
|
| - // tha |kError|.
|
| - gfx::Size kMaxErrorDelta = gfx::ScaleToCeiledSize(kDisplaySize, kError);
|
| -
|
| - display::ManagedDisplayInfo display = CreateDisplayInfo(
|
| - kDisplayId1, kTouchId1,
|
| - gfx::Rect(0, 0, kDisplaySize.width(), kDisplaySize.height()));
|
| -
|
| - // The calibration was performed at a resolution different from the curent
|
| - // resolution of the display.
|
| - const gfx::Size CALIBRATION_SIZE(1920, 1200);
|
| - display::TouchCalibrationData::CalibrationPointPairQuad user_input = {
|
| - {std::make_pair(gfx::Point(100, 100), gfx::Point(50, 70)),
|
| - std::make_pair(gfx::Point(1820, 100), gfx::Point(1780, 70)),
|
| - std::make_pair(gfx::Point(100, 1100), gfx::Point(70, 1060)),
|
| - std::make_pair(gfx::Point(1820, 1100), gfx::Point(1770, 1140))}};
|
| -
|
| - display::TouchCalibrationData touch_data(user_input, CALIBRATION_SIZE);
|
| - display.SetTouchCalibrationData(touch_data);
|
| - EXPECT_TRUE(display.has_touch_calibration_data());
|
| -
|
| - const std::string msg = GetTouchPointString(user_input);
|
| -
|
| - ui::TouchscreenDevice touchscreen =
|
| - CreateTouchscreenDevice(kTouchId1, kTouchSize);
|
| -
|
| - ui::DeviceDataManager* device_manager = ui::DeviceDataManager::GetInstance();
|
| -
|
| - device_manager->UpdateTouchInfoForDisplay(
|
| - display.id(), touchscreen.id,
|
| - GetTouchTransform(display, display, touchscreen, kTouchSize));
|
| -
|
| - EXPECT_EQ(kDisplayId1,
|
| - device_manager->GetTargetDisplayForTouchDevice(kTouchId1));
|
| -
|
| - CheckPointsOfInterests(kTouchId1, kTouchSize, kDisplaySize, kMaxErrorDelta,
|
| - msg);
|
| -}
|
| -
|
| -TEST_F(TouchTransformerControllerTest, DifferentBoundsUserTouchCalibration) {
|
| - // The display bounds is different from the touch device bounds in this test.
|
| - const gfx::Size kDisplaySize(1024, 600);
|
| - const gfx::Size kTouchSize(4096, 4096);
|
| - const float kAcceptableError = 0.04;
|
| - gfx::Size kMaxErrorDelta =
|
| - gfx::ScaleToCeiledSize(kDisplaySize, kAcceptableError);
|
| -
|
| - display::ManagedDisplayInfo display = CreateDisplayInfo(
|
| - kDisplayId1, kTouchId1,
|
| - gfx::Rect(0, 0, kDisplaySize.width(), kDisplaySize.height()));
|
| -
|
| - // Real world data.
|
| - display::TouchCalibrationData::CalibrationPointPairQuad user_input = {
|
| - {std::make_pair(gfx::Point(136, 136), gfx::Point(538, 931)),
|
| - std::make_pair(gfx::Point(873, 136), gfx::Point(3475, 922)),
|
| - std::make_pair(gfx::Point(136, 411), gfx::Point(611, 2800)),
|
| - std::make_pair(gfx::Point(873, 411), gfx::Point(3535, 2949))}};
|
| - display::TouchCalibrationData touch_data(user_input, kDisplaySize);
|
| - display.SetTouchCalibrationData(touch_data);
|
| - EXPECT_TRUE(display.has_touch_calibration_data());
|
| -
|
| - const std::string msg = GetTouchPointString(user_input);
|
| -
|
| - ui::TouchscreenDevice touchscreen =
|
| - CreateTouchscreenDevice(kTouchId1, kTouchSize);
|
| -
|
| - ui::DeviceDataManager* device_manager = ui::DeviceDataManager::GetInstance();
|
| -
|
| - device_manager->UpdateTouchInfoForDisplay(
|
| - display.id(), touchscreen.id,
|
| - GetTouchTransform(display, display, touchscreen, kTouchSize));
|
| -
|
| - EXPECT_EQ(kDisplayId1,
|
| - device_manager->GetTargetDisplayForTouchDevice(kTouchId1));
|
| -
|
| - CheckPointsOfInterests(kTouchId1, kTouchSize, kDisplaySize, kMaxErrorDelta,
|
| - msg);
|
| -}
|
| -
|
| -TEST_F(TouchTransformerControllerTest, LetterboxingUserTouchCalibration) {
|
| - // The internal display has native resolution of 2560x1700, and in
|
| - // mirror mode it is configured as 1920x1200. This is in letterboxing
|
| - // mode.
|
| - const gfx::Size kNativeDisplaySize(2560, 1700);
|
| - const gfx::Size kDisplaySize(1920, 1200);
|
| - const gfx::Size kTouchSize(1920, 1200);
|
| -
|
| - display::ManagedDisplayInfo internal_display_info = CreateDisplayInfo(
|
| - kDisplayId1, kTouchId1,
|
| - gfx::Rect(0, 0, kDisplaySize.width(), kDisplaySize.height()));
|
| - internal_display_info.set_is_aspect_preserving_scaling(true);
|
| -
|
| - display::ManagedDisplayInfo::ManagedDisplayModeList internal_modes;
|
| -
|
| - internal_modes.push_back(make_scoped_refptr(new display::ManagedDisplayMode(
|
| - gfx::Size(kNativeDisplaySize.width(), kNativeDisplaySize.height()), 60,
|
| - false, true)));
|
| - internal_modes.push_back(make_scoped_refptr(new display::ManagedDisplayMode(
|
| - gfx::Size(kDisplaySize.width(), kDisplaySize.height()), 60, false,
|
| - false)));
|
| - internal_display_info.SetManagedDisplayModes(internal_modes);
|
| -
|
| - gfx::Size fb_size(kDisplaySize);
|
| -
|
| - // Create the touchscreens with the same size as the framebuffer so we can
|
| - // share the tests between Ozone & X11.
|
| - ui::TouchscreenDevice internal_touchscreen =
|
| - CreateTouchscreenDevice(kTouchId1, fb_size);
|
| -
|
| - ui::DeviceDataManager* device_manager = ui::DeviceDataManager::GetInstance();
|
| -
|
| - // Assuming the user provided inaccurate inputs during calibration. ie the
|
| - // user did not tap (100,100) when asked to tap (100,100) due to human error.
|
| - // Since the display is of size 2560x1700 and the touch device is of size
|
| - // 1920x1200, the corresponding points have to be scaled.
|
| - display::TouchCalibrationData::CalibrationPointPairQuad user_input = {{
|
| - std::make_pair(gfx::Point(100, 100), gfx::Point(75, 71)),
|
| - std::make_pair(gfx::Point(2460, 100), gfx::Point(1845, 71)),
|
| - std::make_pair(gfx::Point(100, 1600), gfx::Point(75, 1130)),
|
| - std::make_pair(gfx::Point(2460, 1600), gfx::Point(1845, 1130)),
|
| - }};
|
| - // The calibration was performed at the native display resolution.
|
| - display::TouchCalibrationData touch_data(user_input, kNativeDisplaySize);
|
| - internal_display_info.SetTouchCalibrationData(touch_data);
|
| - EXPECT_TRUE(internal_display_info.has_touch_calibration_data());
|
| -
|
| - device_manager->UpdateTouchInfoForDisplay(
|
| - internal_display_info.id(), internal_touchscreen.id,
|
| - GetTouchTransform(internal_display_info, internal_display_info,
|
| - internal_touchscreen, fb_size));
|
| -
|
| - EXPECT_EQ(kDisplayId1,
|
| - device_manager->GetTargetDisplayForTouchDevice(kTouchId1));
|
| -
|
| - float x, y;
|
| - // In letterboxing, there is (1-2560*(1200/1920)/1700)/2 = 2.95% of the
|
| - // height on both the top & bottom region of the screen is blank.
|
| - // When touch events coming at Y range [0, 1200), the mapping should be
|
| - // [0, ~35] ---> < 0
|
| - // [~35, ~1165] ---> [0, 1200)
|
| - // [~1165, 1200] ---> >= 1200
|
| - x = 100.0;
|
| - y = 35.0;
|
| - device_manager->ApplyTouchTransformer(kTouchId1, &x, &y);
|
| - EXPECT_NEAR(100, x, 0.5);
|
| - EXPECT_NEAR(0, y, 0.5);
|
| -
|
| - x = 100.0;
|
| - y = 1165.0;
|
| - device_manager->ApplyTouchTransformer(kTouchId1, &x, &y);
|
| - EXPECT_NEAR(100, x, 0.5);
|
| - EXPECT_NEAR(1200, y, 0.5);
|
| -}
|
| -
|
| -TEST_F(TouchTransformerControllerTest, PillarBoxingUserTouchCalibration) {
|
| - // The internal display has native resolution of 2560x1700, and in
|
| - // mirror mode it is configured as 1920x1200. This is in letterboxing
|
| - // mode.
|
| - const gfx::Size kNativeDisplaySize(2560, 1600);
|
| - const gfx::Size kDisplaySize(1920, 1400);
|
| - const gfx::Size kTouchSize(1920, 1400);
|
| -
|
| - display::ManagedDisplayInfo internal_display_info = CreateDisplayInfo(
|
| - kDisplayId1, kTouchId1,
|
| - gfx::Rect(0, 0, kDisplaySize.width(), kDisplaySize.height()));
|
| - internal_display_info.set_is_aspect_preserving_scaling(true);
|
| -
|
| - display::ManagedDisplayInfo::ManagedDisplayModeList internal_modes;
|
| -
|
| - internal_modes.push_back(make_scoped_refptr(new display::ManagedDisplayMode(
|
| - gfx::Size(kNativeDisplaySize.width(), kNativeDisplaySize.height()), 60,
|
| - false, true)));
|
| - internal_modes.push_back(make_scoped_refptr(new display::ManagedDisplayMode(
|
| - gfx::Size(kDisplaySize.width(), kDisplaySize.height()), 60, false,
|
| - false)));
|
| - internal_display_info.SetManagedDisplayModes(internal_modes);
|
| -
|
| - gfx::Size fb_size(kDisplaySize);
|
| -
|
| - // Create the touchscreens with the same size as the framebuffer so we can
|
| - // share the tests between Ozone & X11.
|
| - ui::TouchscreenDevice internal_touchscreen =
|
| - CreateTouchscreenDevice(kTouchId1, fb_size);
|
| -
|
| - ui::DeviceDataManager* device_manager = ui::DeviceDataManager::GetInstance();
|
| -
|
| - // Assuming the user provided accurate inputs during calibration. ie the user
|
| - // actually tapped (100,100) when asked to tap (100,100) with no human error.
|
| - // Since the display is of size 2560x1600 and the touch device is of size
|
| - // 1920x1400, the corresponding points have to be scaled.
|
| - display::TouchCalibrationData::CalibrationPointPairQuad user_input = {{
|
| - std::make_pair(gfx::Point(100, 100), gfx::Point(75, 88)),
|
| - std::make_pair(gfx::Point(2460, 100), gfx::Point(1845, 88)),
|
| - std::make_pair(gfx::Point(100, 1500), gfx::Point(75, 1313)),
|
| - std::make_pair(gfx::Point(2460, 1500), gfx::Point(1845, 1313)),
|
| - }};
|
| - // The calibration was performed at the native display resolution.
|
| - display::TouchCalibrationData touch_data(user_input, kNativeDisplaySize);
|
| - internal_display_info.SetTouchCalibrationData(touch_data);
|
| - EXPECT_TRUE(internal_display_info.has_touch_calibration_data());
|
| -
|
| - device_manager->UpdateTouchInfoForDisplay(
|
| - internal_display_info.id(), internal_touchscreen.id,
|
| - GetTouchTransform(internal_display_info, internal_display_info,
|
| - internal_touchscreen, fb_size));
|
| -
|
| - EXPECT_EQ(kDisplayId1,
|
| - device_manager->GetTargetDisplayForTouchDevice(kTouchId1));
|
| -
|
| - float x, y;
|
| - // In pillarboxing, there is (1-1600*(1920/1400)/2560)/2 = 7.14% of the
|
| - // width on both the left & region region of the screen is blank.
|
| - // When touch events coming at X range [0, 1920), the mapping should be
|
| - // [0, ~137] ---> < 0
|
| - // [~137, ~1782] ---> [0, 1920)
|
| - // [~1782, 1920] ---> >= 1920
|
| - x = 137.0;
|
| - y = 0.0;
|
| - device_manager->ApplyTouchTransformer(kTouchId1, &x, &y);
|
| - EXPECT_NEAR(0, x, 0.5);
|
| - EXPECT_NEAR(0, y, 0.5);
|
| -
|
| - x = 1782.0;
|
| - y = 0.0;
|
| - device_manager->ApplyTouchTransformer(kTouchId1, &x, &y);
|
| - EXPECT_NEAR(1920, x, 0.5);
|
| - EXPECT_NEAR(0, y, 0.5);
|
| -}
|
| -
|
| -} // namespace ash
|
|
|