aboutsummaryrefslogtreecommitdiff
path: root/files/zh-cn/web/api/touch/index.html
blob: 87976b9822fb483ae2e2ad2a800395861c7dcb74 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
---
title: Touch
slug: Web/API/Touch
tags:
  - API
  - TouchEvent
  - touch
  - 参考
  - 接口
translation_of: Web/API/Touch
---
<p>{{ ApiRef("Touch Events") }}</p>

<p><strong><code>Touch</code> </strong>对象表示在触控设备上的触摸点。通常是指手指或者触控笔在触屏设备或者触摸板上的操作。</p>

<p>对象属性 {{ domxref("Touch.radiusX") }}, {{ domxref("Touch.radiusY") }}, 和 {{ domxref("Touch.rotationAngle") }} 表示用户触摸操作所作用的区域,即<em>触摸区域</em>。这些属性对于处理类似于手指触摸之类的不精确操作很有帮助。这些属性可以表示出一个尽可能匹配触控区域的椭圆形(例如用户的指尖触控)。 {{experimental_inline}}</p>

<div class="note"><strong>注意:</strong> 以下很多属性的值需要依赖硬件设备去获取,例如,如果设备本身不支持侦测压感,那么 <code>force</code> 属性的值将始终是0,对于 <code>radiusX</code><code>radiusY</code> 来说同样可能有这种情况,如果设备认为触点只是一个点而不是一个面, 它们始终为1。 </div>

<h2 id="构造函数">构造函数</h2>

<dl>
 <dt>{{domxref("Touch.Touch", "Touch()")}} {{experimental_inline}}</dt>
 <dd>创建一个Touch对象。</dd>
 <dt></dt>
</dl>

<h2 id="属性">属性</h2>

<p><em>这个接口没有父类,不继承任何属性。</em></p>

<h3 id="基本属性">基本属性</h3>

<dl>
 <dt>{{ domxref("Touch.identifier") }}{{readonlyInline}}</dt>
 <dd><code>Touch</code> 对象的唯一标识符。 一次触摸动作(例如手指触摸)在平面上移动的整个过程中, 该标识符不变。可以根据它来判断跟踪的是否是同一次触摸过程。</dd>
 <dt><strong>{{ domxref("Touch.screenX") }}</strong>{{readonlyInline}}</dt>
 <dd>触点相对于屏幕左边缘的X坐标。</dd>
 <dt><strong>{{ domxref("Touch.screenY") }}</strong>{{readonlyInline}}</dt>
 <dd>触点相对于屏幕上边缘的Y坐标。</dd>
 <dt><strong>{{ domxref("Touch.clientX") }}</strong>{{readonlyInline}}</dt>
 <dd>触点相对于可见视区(<a href="http://www.quirksmode.org/mobile/viewports2.html">visual viewport</a>)左边缘的X坐标。不包括任何滚动偏移。</dd>
 <dt><strong>{{ domxref("Touch.clientY") }}</strong>{{readonlyInline}}</dt>
 <dd>触点相对于可见视区(<a href="http://www.quirksmode.org/mobile/viewports2.html">visual viewport</a>)上边缘的Y坐标。不包括任何滚动偏移。</dd>
 <dt>{{ domxref("Touch.pageX") }}{{readonlyInline}}</dt>
 <dd>触点相对于HTML文档左边缘的X坐标。当存在水平滚动的偏移时, 这个值包含了水平滚动的偏移。</dd>
 <dt>{{ domxref("Touch.pageY") }}{{readonlyInline}}</dt>
 <dd>触点相对于HTML文档上边缘的Y坐标。当存在垂直滚动的偏移时, 这个值包含了垂直滚动的偏移。</dd>
 <dt>{{ domxref("Touch.target") }}{{readonlyInline}}</dt>
 <dd>返回触摸点最初接触的 {{ domxref("Element")}},即使这个触摸点已经移出那个元素的交互区域。需要注意的是, 如果这个元素在触摸过程中被移除, 这个事件仍然会指向它, 因此这个事件也不会冒泡到 <code>window</code><code>document</code> 对象。因此, 如果有元素在触摸过程中可能被移除, 最佳实践是将触摸事件的监听器绑定到这个元素本身, 防止元素被移除后, 无法再从它的上一级元素上侦测到从该元素冒泡的事件。</dd>
</dl>

<h3 id="触摸区域">触摸区域</h3>

<p>{{SeeCompatTable}}</p>

<dl>
 <dt>{{ domxref("Touch.radiusX") }}{{readonlyInline}}{{experimental_inline}}</dt>
 <dd>返回能够包围接触区域的最小椭圆的水平轴(X轴)半径。这个值的单位和 <code>screenX</code> 相同<strong></strong></dd>
 <dt>{{ domxref("Touch.radiusY") }}{{readonlyInline}}{{experimental_inline}}</dt>
 <dd>返回能够包围接触区域的最小椭圆的垂直轴(Y轴)半径。这个值的单位和 <code>screenY</code> 相同。</dd>
 <dt>{{ domxref("Touch.rotationAngle") }}{{readonlyInline}}{{experimental_inline}}</dt>
 <dd>返回一个角度值,表示上述由<code>radiusX</code><code>radiusY</code> 描述的椭圆为了尽可能精确地覆盖用户与平面之间的接触区域而需要顺时针旋转的角度。</dd>
 <dt>{{ domxref("Touch.force") }}{{readonlyInline}}{{experimental_inline}}</dt>
 <dd>返回用户对触摸平面的压力大小,是一个从0.0(没有压力)到1.0(最大压力)的浮点数。</dd>
</dl>

<dl>
</dl>

<h2 id="Methods">Methods</h2>

<p><em>这个接口没有方法,也没有父类,不继承任何方法。</em></p>

<h2 id="示例">示例</h2>

<p>请看 <a href="/en/DOM/Touch_events#Example" title="en/DOM/Touch events#Example">example on the main Touch events article</a></p>

<dl>
</dl>

<h2 id="规范">规范</h2>

<table class="standard-table">
 <tbody>
  <tr>
   <th scope="col">规范</th>
   <th scope="col">状态</th>
   <th scope="col">注释</th>
  </tr>
  <tr>
   <td>{{SpecName('Touch Events 2', '#touch-interface', 'Touch')}}</td>
   <td>{{Spec2('Touch Events 2')}}</td>
   <td>加入 <code>radiusX</code><code>radiusY</code><code>rotationAngle</code><code>force</code> 属性,和 <code>Touch()</code> 构造函数。</td>
  </tr>
  <tr>
   <td>{{SpecName('Touch Events', '#touch-interface', 'Touch')}}</td>
   <td>{{Spec2('Touch Events')}}</td>
   <td>初始定义。</td>
  </tr>
 </tbody>
</table>

<h2 id="浏览器兼容性">浏览器兼容性</h2>

<p>{{Compat("api.Touch")}}</p>

<h2 id="相关链接">相关链接</h2>

<ul>
 <li><a href="/en/DOM/Touch_events" title="en/DOM/Touch events">Touch events</a></li>
 <li>{{domxref("Touch_events","Touch Events Overview")}}</li>
 <li>{{ domxref("Document.createTouch()") }}</li>
 <li>{{ domxref("Touch") }}</li>
 <li>{{ domxref("TouchList") }}</li>
 <li>{{ domxref("TouchEvent") }}</li>
</ul>