如何获取触摸事件点相对于目标元素的x坐标?

时间:2017-03-03 08:45:52

标签: javascript touch-event

所以我的图像看起来像这样:



var elem = document.getElementById("bt");
elem.addEventListener("touchstart", handleStart, false);

function handleStart(e) {
  e.preventDefault();
  var touch = e.targetTouches[0];
  X = touch.pageX;
  Y = touch.pageY;
  return [X, Y];
}

<img src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/142996/sections-3.jpg" id="bt" width="900" height="600">
&#13;
&#13;
&#13;

我想要做的是获取触摸事件相对于图像本身的x坐标和y坐标。

2 个答案:

答案 0 :(得分:0)

将图像位置设置为绝对并设置其起始坐标(此处我将其设置为左上角)

#bt{
  position:absolute;
  left:0px;
  top:0px;
}

现在触摸坐标是图像像素坐标。您可能需要考虑可用的页面大小和窗口大小和比例。

您也可以通过

获取元素坐标
var rect = elem.getBoundingClientRect();
console.log(rect.top, rect.right, rect.bottom, rect.left);

然后您可以将这些值用作touch.x - rect.left等。

答案 1 :(得分:0)

您可以使用Jquery轻松实现这一点。在我的代码中,我使用click事件显示,因为我使用的是桌面,但您可以替换点击触摸事件。

FIDDLE

以下是代码:

&#13;
&#13;
$('.clickable').bind('click', function(ev) {
  var $div = $(ev.target);
  var $display = $div.find('.display');

  var offset = $div.offset();
  var x = ev.clientX - offset.left;
  var y = ev.clientY - offset.top;

  $display.text('x: ' + x + ', y: ' + y);
});
&#13;
.clickable {
  border: 1px solid #333;
  background: #eee;
  height: 200px;
  width: 200px;
  margin: 15px;
  position: absolute;
}

.display {
  display: block;
  height: 16px;
  position: absolute;
  text-align: center;
  vertical-align: middle;
  width: 100%;
  top: 50%;
  margin-top: -8px;
}
&#13;
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class='clickable'>
  <span class='display'></span>
</div>
&#13;
&#13;
&#13;