ms-vite-plugin 1.1.2 → 1.1.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/build.js +6 -0
- package/dist/cli.js +91 -1
- package/dist/mcp/device-config.d.ts +55 -0
- package/dist/mcp/device-config.js +183 -0
- package/dist/mcp/docs-service.d.ts +65 -0
- package/dist/mcp/docs-service.js +168 -0
- package/dist/mcp/project.d.ts +16 -0
- package/dist/mcp/project.js +74 -0
- package/dist/mcp/tools.d.ts +18 -0
- package/dist/mcp/tools.js +825 -0
- package/dist/mcp/types.d.ts +32 -0
- package/dist/mcp/types.js +11 -0
- package/dist/mcp-server.d.ts +2 -0
- package/dist/mcp-server.js +86 -0
- package/dist/project.d.ts +89 -0
- package/dist/project.js +306 -0
- package/dist/version.d.ts +12 -0
- package/dist/version.js +63 -0
- package/docs/api/action.md +922 -0
- package/docs/api/appleocr.md +229 -0
- package/docs/api/config.md +122 -0
- package/docs/api/cryptoUtils.md +232 -0
- package/docs/api/device.md +374 -0
- package/docs/api/file.md +516 -0
- package/docs/api/global.md +617 -0
- package/docs/api/hid.md +1032 -0
- package/docs/api/hotUpdate.md +166 -0
- package/docs/api/http.md +548 -0
- package/docs/api/image.md +907 -0
- package/docs/api/ime.md +290 -0
- package/docs/api/logger.md +324 -0
- package/docs/api/media.md +248 -0
- package/docs/api/mysql.md +441 -0
- package/docs/api/netCard.md +200 -0
- package/docs/api/node.md +353 -0
- package/docs/api/paddleocr.md +246 -0
- package/docs/api/pip.md +242 -0
- package/docs/api/system.md +572 -0
- package/docs/api/thread.md +269 -0
- package/docs/api/tomatoocr.md +425 -0
- package/docs/api/tts.md +334 -0
- package/docs/api/ui.md +947 -0
- package/docs/api/utils.md +265 -0
- package/docs/api/yolo.md +310 -0
- package/docs/apicn/action.md +919 -0
- package/docs/apicn/appleocr.md +233 -0
- package/docs/apicn/config.md +120 -0
- package/docs/apicn/device.md +385 -0
- package/docs/apicn/file.md +511 -0
- package/docs/apicn/global.md +613 -0
- package/docs/apicn/hid.md +1033 -0
- package/docs/apicn/hotUpdate.md +170 -0
- package/docs/apicn/http.md +672 -0
- package/docs/apicn/image.md +924 -0
- package/docs/apicn/ime.md +290 -0
- package/docs/apicn/logger.md +332 -0
- package/docs/apicn/media.md +252 -0
- package/docs/apicn/mysql.md +445 -0
- package/docs/apicn/netCard.md +200 -0
- package/docs/apicn/node.md +362 -0
- package/docs/apicn/paddleocr.md +255 -0
- package/docs/apicn/pip.md +242 -0
- package/docs/apicn/system.md +575 -0
- package/docs/apicn/thread.md +269 -0
- package/docs/apicn/tts.md +338 -0
- package/docs/apicn/ui.md +933 -0
- package/docs/apicn/utils.md +265 -0
- package/docs/apicn/yolo.md +314 -0
- package/docs/apipython/action.md +901 -0
- package/docs/apipython/appleocr.md +226 -0
- package/docs/apipython/config.md +126 -0
- package/docs/apipython/cryptoUtils.md +246 -0
- package/docs/apipython/device.md +365 -0
- package/docs/apipython/file.md +476 -0
- package/docs/apipython/g.md +154 -0
- package/docs/apipython/hid.md +1059 -0
- package/docs/apipython/hotUpdate.md +154 -0
- package/docs/apipython/image.md +938 -0
- package/docs/apipython/ime.md +306 -0
- package/docs/apipython/logger.md +330 -0
- package/docs/apipython/media.md +221 -0
- package/docs/apipython/mysql.md +432 -0
- package/docs/apipython/netCard.md +219 -0
- package/docs/apipython/node.md +331 -0
- package/docs/apipython/overview.md +66 -0
- package/docs/apipython/paddleocr.md +211 -0
- package/docs/apipython/pip.md +231 -0
- package/docs/apipython/system.md +458 -0
- package/docs/apipython/tomatoocr.md +444 -0
- package/docs/apipython/tts.md +331 -0
- package/docs/apipython/ui.md +949 -0
- package/docs/apipython/utils.md +284 -0
- package/docs/apipython/yolo.md +281 -0
- package/package.json +8 -4
|
@@ -0,0 +1,922 @@
|
|
|
1
|
+
# 动作模块 (Action)
|
|
2
|
+
|
|
3
|
+
动作模块提供了丰富的触摸和按键操作功能,包括点击、滑动、长按滑动、返回首页、多点触摸等动作。
|
|
4
|
+
|
|
5
|
+
**注意事项**
|
|
6
|
+
|
|
7
|
+
- 此模块仅支持 快点 Agent 模式使用
|
|
8
|
+
- HID 模式,请使用 HID 模块
|
|
9
|
+
|
|
10
|
+
## 抖动值
|
|
11
|
+
|
|
12
|
+
### setJitterValue - 设置动作抖动值
|
|
13
|
+
|
|
14
|
+
默认抖动值为 5 像素,设置后有 jitter 参数的动作会在像素范围 `-value` 到 `value` 随机偏移。
|
|
15
|
+
|
|
16
|
+
```typescript
|
|
17
|
+
function setJitterValue(value: number): void;
|
|
18
|
+
```
|
|
19
|
+
|
|
20
|
+
**参数说明:**
|
|
21
|
+
| 参数名 | 类型 | 是否必填 | 默认值 | 描述 |
|
|
22
|
+
| ---------- | ------- | -------- | ------ | ------------------------------------------------------- |
|
|
23
|
+
| `value` | number | 是 | - | 抖动值,点击、滑动等动作会在像素范围 `-value` 到 `value` 随机偏移 |
|
|
24
|
+
|
|
25
|
+
**示例:**
|
|
26
|
+
|
|
27
|
+
```javascript
|
|
28
|
+
// 设置抖动值为5像素
|
|
29
|
+
action.setJitterValue(5);
|
|
30
|
+
```
|
|
31
|
+
|
|
32
|
+
## 基础触摸操作
|
|
33
|
+
|
|
34
|
+
### click - 点击操作
|
|
35
|
+
|
|
36
|
+
```typescript
|
|
37
|
+
function click(
|
|
38
|
+
x: number, // 坐标x
|
|
39
|
+
y: number, // 坐标y
|
|
40
|
+
duration?: number, // 持续时间(毫秒),默认20ms
|
|
41
|
+
jitter?: boolean, // 抖动(随机偏移),默认false
|
|
42
|
+
): boolean;
|
|
43
|
+
```
|
|
44
|
+
|
|
45
|
+
**参数说明:**
|
|
46
|
+
|
|
47
|
+
| 参数名 | 类型 | 是否必填 | 默认值 | 描述 |
|
|
48
|
+
| ---------- | ------- | -------- | ------ | ---------------------- |
|
|
49
|
+
| `x` | number | 是 | - | 点击的 x 坐标 |
|
|
50
|
+
| `y` | number | 是 | - | 点击的 y 坐标 |
|
|
51
|
+
| `duration` | number | 否 | 20 | 点击持续时间,单位毫秒 |
|
|
52
|
+
| `jitter` | boolean | 否 | false | 启用随机抖动偏移 |
|
|
53
|
+
|
|
54
|
+
**返回值:**
|
|
55
|
+
| 类型 | 描述 |
|
|
56
|
+
| ---------- | ------- |
|
|
57
|
+
| `boolean` | 点击是否成功 |
|
|
58
|
+
|
|
59
|
+
**示例:**
|
|
60
|
+
|
|
61
|
+
```typescript
|
|
62
|
+
// 基础点击
|
|
63
|
+
const success = action.click(100, 100, 20, false);
|
|
64
|
+
if (success) {
|
|
65
|
+
logi("点击成功");
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
// 带抖动的点击(更自然,避免检测)
|
|
69
|
+
action.click(200, 300, 50, true);
|
|
70
|
+
|
|
71
|
+
// 快速点击
|
|
72
|
+
action.click(150, 250, 10, false);
|
|
73
|
+
|
|
74
|
+
// 长按效果(增加持续时间)
|
|
75
|
+
action.click(100, 100, 800, true);
|
|
76
|
+
```
|
|
77
|
+
|
|
78
|
+
### clickRandom - 执行随机点击操作
|
|
79
|
+
|
|
80
|
+
```typescript
|
|
81
|
+
function clickRandom(
|
|
82
|
+
x1: number, // 区域左上角x坐标
|
|
83
|
+
y1: number, // 区域左上角y坐标
|
|
84
|
+
x2: number, // 区域右下角x坐标
|
|
85
|
+
y2: number, // 区域右下角y坐标
|
|
86
|
+
duration?: number, // 持续时间(毫秒),默认20ms
|
|
87
|
+
): boolean;
|
|
88
|
+
```
|
|
89
|
+
|
|
90
|
+
**参数说明:**
|
|
91
|
+
| 参数名 | 类型 | 是否必填 | 默认值 | 描述 |
|
|
92
|
+
| ---------- | ------- | -------- | ------ | ------------------------------------------------------- |
|
|
93
|
+
| `x1` | number | 是 | - | 随机点击区域的左上角 x 坐标 |
|
|
94
|
+
| `y1` | number | 是 | - | 随机点击区域的左上角 y 坐标 |
|
|
95
|
+
| `x2` | number | 是 | - | 随机点击区域的右下角 x 坐标 |
|
|
96
|
+
| `y2` | number | 是 | - | 随机点击区域的右下角 y 坐标 |
|
|
97
|
+
| `duration` | number | 否 | 20 | 点击持续时间,单位毫秒 |
|
|
98
|
+
|
|
99
|
+
**返回值:**
|
|
100
|
+
|
|
101
|
+
| 类型 | 描述 |
|
|
102
|
+
| --------- | ---------------- |
|
|
103
|
+
| `boolean` | 随机点击是否成功 |
|
|
104
|
+
|
|
105
|
+
**示例:**
|
|
106
|
+
|
|
107
|
+
```typescript
|
|
108
|
+
// 在指定矩形区域内随机点击
|
|
109
|
+
action.clickRandom(100, 100, 200, 200, 20);
|
|
110
|
+
|
|
111
|
+
// 在更大区域内随机点击
|
|
112
|
+
action.clickRandom(50, 50, 400, 600, 50);
|
|
113
|
+
|
|
114
|
+
// 快速随机点击
|
|
115
|
+
action.clickRandom(150, 150, 250, 250, 10);
|
|
116
|
+
```
|
|
117
|
+
|
|
118
|
+
### doubleClick - 执行双击操作
|
|
119
|
+
|
|
120
|
+
```typescript
|
|
121
|
+
function doubleClick(
|
|
122
|
+
x: number, // 坐标x
|
|
123
|
+
y: number, // 坐标y
|
|
124
|
+
duration?: number, // 持续时间(毫秒),默认20ms
|
|
125
|
+
interval?: number, // 双击间隔时间(毫秒),默认20ms
|
|
126
|
+
jitter?: boolean, // 抖动(随机偏移),默认false
|
|
127
|
+
): boolean;
|
|
128
|
+
```
|
|
129
|
+
|
|
130
|
+
**参数说明:**
|
|
131
|
+
|
|
132
|
+
| 参数名 | 类型 | 是否必填 | 默认值 | 描述 |
|
|
133
|
+
| ---------- | ------- | -------- | ------ | -------------------------------- |
|
|
134
|
+
| `x` | number | 是 | - | 双击的 x 坐标 |
|
|
135
|
+
| `y` | number | 是 | - | 双击的 y 坐标 |
|
|
136
|
+
| `duration` | number | 否 | 20 | 每次点击的持续时间,单位毫秒 |
|
|
137
|
+
| `interval` | number | 否 | 20 | 两次点击之间的间隔时间,单位毫秒 |
|
|
138
|
+
| `jitter` | boolean | 否 | false | 启用随机抖动偏移 |
|
|
139
|
+
|
|
140
|
+
**返回值:**
|
|
141
|
+
|
|
142
|
+
| 类型 | 描述 |
|
|
143
|
+
| --------- | ------------ |
|
|
144
|
+
| `boolean` | 双击是否成功 |
|
|
145
|
+
|
|
146
|
+
**示例:**
|
|
147
|
+
|
|
148
|
+
```typescript
|
|
149
|
+
// 基础双击
|
|
150
|
+
const success = action.doubleClick(100, 100, 20, 20, false);
|
|
151
|
+
if (success) {
|
|
152
|
+
logi("双击成功");
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
// 带抖动的双击(更自然,避免检测)
|
|
156
|
+
action.doubleClick(200, 300, 50, 20, true);
|
|
157
|
+
|
|
158
|
+
// 慢速双击(增加间隔时间)
|
|
159
|
+
action.doubleClick(100, 100, 30, 300, true);
|
|
160
|
+
```
|
|
161
|
+
|
|
162
|
+
### doubleClickRandom - 执行随机双击操作
|
|
163
|
+
|
|
164
|
+
```typescript
|
|
165
|
+
function doubleClickRandom(
|
|
166
|
+
x1: number, // 区域左上角x坐标
|
|
167
|
+
y1: number, // 区域左上角y坐标
|
|
168
|
+
x2: number, // 区域右下角x坐标
|
|
169
|
+
y2: number, // 区域右下角y坐标
|
|
170
|
+
duration?: number, // 持续时间(毫秒),默认20ms
|
|
171
|
+
interval?: number, // 双击间隔时间(毫秒),默认20ms
|
|
172
|
+
): boolean;
|
|
173
|
+
```
|
|
174
|
+
|
|
175
|
+
**参数说明:**
|
|
176
|
+
|
|
177
|
+
| 参数名 | 类型 | 是否必填 | 默认值 | 描述 |
|
|
178
|
+
| ---------- | ------ | -------- | ------ | -------------------------------- |
|
|
179
|
+
| `x1` | number | 是 | - | 随机双击区域的左上角 x 坐标 |
|
|
180
|
+
| `y1` | number | 是 | - | 随机双击区域的左上角 y 坐标 |
|
|
181
|
+
| `x2` | number | 是 | - | 随机双击区域的右下角 x 坐标 |
|
|
182
|
+
| `y2` | number | 是 | - | 随机双击区域的右下角 y 坐标 |
|
|
183
|
+
| `duration` | number | 否 | 20 | 每次点击的持续时间,单位毫秒 |
|
|
184
|
+
| `interval` | number | 否 | 20 | 两次点击之间的间隔时间,单位毫秒 |
|
|
185
|
+
|
|
186
|
+
**返回值:**
|
|
187
|
+
|
|
188
|
+
| 类型 | 描述 |
|
|
189
|
+
| --------- | ---------------- |
|
|
190
|
+
| `boolean` | 随机双击是否成功 |
|
|
191
|
+
|
|
192
|
+
**示例:**
|
|
193
|
+
|
|
194
|
+
```typescript
|
|
195
|
+
// 在指定矩形区域内随机双击
|
|
196
|
+
action.doubleClickRandom(100, 100, 200, 200, 20, 20);
|
|
197
|
+
|
|
198
|
+
// 慢速随机双击
|
|
199
|
+
action.doubleClickRandom(100, 100, 300, 300, 30, 300);
|
|
200
|
+
```
|
|
201
|
+
|
|
202
|
+
### swipe - 执行滑动操作
|
|
203
|
+
|
|
204
|
+
```typescript
|
|
205
|
+
function swipe(
|
|
206
|
+
startX: number, // 起始坐标x
|
|
207
|
+
startY: number, // 起始坐标y
|
|
208
|
+
endX: number, // 结束坐标x
|
|
209
|
+
endY: number, // 结束坐标y
|
|
210
|
+
duration?: number, // 持续时间(毫秒),默认100ms
|
|
211
|
+
jitter?: boolean, // 抖动(随机偏移),默认false
|
|
212
|
+
steps?: number, // 步数(抖动点数量),默认6
|
|
213
|
+
): boolean;
|
|
214
|
+
```
|
|
215
|
+
|
|
216
|
+
**参数说明:**
|
|
217
|
+
|
|
218
|
+
| 参数名 | 类型 | 是否必填 | 默认值 | 描述 |
|
|
219
|
+
| ---------- | ------- | -------- | ------ | ------------------------------------------------------ |
|
|
220
|
+
| `startX` | number | 是 | - | 滑动起始坐标 x 坐标 |
|
|
221
|
+
| `startY` | number | 是 | - | 滑动起始坐标 y 坐标 |
|
|
222
|
+
| `endX` | number | 是 | - | 滑动结束坐标 x 坐标 |
|
|
223
|
+
| `endY` | number | 是 | - | 滑动结束坐标 y 坐标 |
|
|
224
|
+
| `duration` | number | 否 | 100 | 滑动持续时间,单位毫秒 |
|
|
225
|
+
| `jitter` | boolean | 否 | false | 是否开启抖动,开启后会在滑动路径上随机偏移,默认 false |
|
|
226
|
+
| `steps` | number | 否 | 6 | 生成抖动点的数量,影响滑动的平滑度,默认 6 |
|
|
227
|
+
|
|
228
|
+
**返回值:**
|
|
229
|
+
|
|
230
|
+
| 类型 | 描述 |
|
|
231
|
+
| --------- | ------------ |
|
|
232
|
+
| `boolean` | 滑动是否成功 |
|
|
233
|
+
|
|
234
|
+
**示例:**
|
|
235
|
+
|
|
236
|
+
```typescript
|
|
237
|
+
// 基础滑动(从左到右)
|
|
238
|
+
action.swipe(100, 300, 400, 300, 500, false, 10);
|
|
239
|
+
|
|
240
|
+
// 向上滑动(滚动页面)
|
|
241
|
+
action.swipe(200, 600, 200, 200, 800, true, 15);
|
|
242
|
+
|
|
243
|
+
// 向下滑动
|
|
244
|
+
action.swipe(200, 200, 200, 600, 800, true, 15);
|
|
245
|
+
|
|
246
|
+
// 对角线滑动
|
|
247
|
+
action.swipe(100, 100, 300, 400, 1000, true, 20);
|
|
248
|
+
|
|
249
|
+
// 快速滑动
|
|
250
|
+
action.swipe(150, 500, 150, 100, 300, false, 5);
|
|
251
|
+
|
|
252
|
+
// 慢速精确滑动
|
|
253
|
+
action.swipe(100, 200, 300, 200, 1500, true, 30);
|
|
254
|
+
```
|
|
255
|
+
|
|
256
|
+
### pressAndSwipe - 执行长按滑动操作,适用于拖拽等场景
|
|
257
|
+
|
|
258
|
+
```typescript
|
|
259
|
+
function pressAndSwipe(
|
|
260
|
+
startX: number, // 起始坐标x
|
|
261
|
+
startY: number, // 起始坐标y
|
|
262
|
+
endX: number, // 结束坐标x
|
|
263
|
+
endY: number, // 结束坐标y
|
|
264
|
+
touch_down_duration?: number, // 按下持续时间(毫秒),默认500ms
|
|
265
|
+
touch_move_duration?: number, // 移动持续时间(毫秒),默认1000ms
|
|
266
|
+
touch_up_duration?: number, // 松开持续时间(毫秒),默认500ms
|
|
267
|
+
jitter?: boolean, // 抖动(随机偏移),默认false
|
|
268
|
+
steps?: number, // 步数(抖动点数量),默认6
|
|
269
|
+
): boolean;
|
|
270
|
+
```
|
|
271
|
+
|
|
272
|
+
**参数说明:**
|
|
273
|
+
|
|
274
|
+
| 参数名 | 类型 | 是否必填 | 默认值 | 描述 |
|
|
275
|
+
| --------------------- | ------- | -------- | ------ | ------------------------------------------------------ |
|
|
276
|
+
| `startX` | number | 是 | - | 长按起始坐标 x 坐标 |
|
|
277
|
+
| `startY` | number | 是 | - | 长按起始坐标 y 坐标 |
|
|
278
|
+
| `endX` | number | 是 | - | 拖拽结束坐标 x 坐标 |
|
|
279
|
+
| `endY` | number | 是 | - | 拖拽结束坐标 y 坐标 |
|
|
280
|
+
| `touch_down_duration` | number | 否 | 500 | 按下阶段的持续时间,单位毫秒,默认 500ms |
|
|
281
|
+
| `touch_move_duration` | number | 否 | 1000 | 移动阶段的持续时间,单位毫秒,默认 1000ms |
|
|
282
|
+
| `touch_up_duration` | number | 否 | 500 | 松开阶段的持续时间,默认 500ms |
|
|
283
|
+
| `jitter` | boolean | 否 | false | 是否开启抖动,开启后会在滑动路径上随机偏移,默认 false |
|
|
284
|
+
| `steps` | number | 否 | 6 | 移动过程中的步数,影响滑动的平滑度,默认 6 |
|
|
285
|
+
|
|
286
|
+
**返回值:**
|
|
287
|
+
|
|
288
|
+
| 类型 | 描述 |
|
|
289
|
+
| --------- | ---------------- |
|
|
290
|
+
| `boolean` | 长按滑动是否成功 |
|
|
291
|
+
|
|
292
|
+
**示例:**
|
|
293
|
+
|
|
294
|
+
```typescript
|
|
295
|
+
// 拖拽元素
|
|
296
|
+
action.pressAndSwipe(
|
|
297
|
+
100,
|
|
298
|
+
100, // 起始位置
|
|
299
|
+
300,
|
|
300
|
+
400, // 目标位置
|
|
301
|
+
500, // 按下500ms
|
|
302
|
+
1000, // 移动1000ms
|
|
303
|
+
200, // 松开200ms
|
|
304
|
+
true, // 开启抖动
|
|
305
|
+
20, // 20个步数
|
|
306
|
+
);
|
|
307
|
+
|
|
308
|
+
// 长按拖拽(更长的按下时间)
|
|
309
|
+
action.pressAndSwipe(150, 200, 350, 500, 1000, 800, 300, true, 15);
|
|
310
|
+
|
|
311
|
+
// 精确拖拽(无抖动)
|
|
312
|
+
action.pressAndSwipe(200, 300, 200, 100, 300, 600, 100, false, 25);
|
|
313
|
+
```
|
|
314
|
+
|
|
315
|
+
### swipeCurve - 执行 3 点曲线滑动操作(先快后慢)
|
|
316
|
+
|
|
317
|
+
```typescript
|
|
318
|
+
function swipeCurve(
|
|
319
|
+
startX: number, // 起始x坐标
|
|
320
|
+
startY: number, // 起始y坐标
|
|
321
|
+
midX: number, // 中间点x坐标
|
|
322
|
+
midY: number, // 中间点y坐标
|
|
323
|
+
endX: number, // 目标x坐标
|
|
324
|
+
endY: number, // 目标y坐标
|
|
325
|
+
duration?: number, // 总持续时间(毫秒),默认1000ms
|
|
326
|
+
): boolean;
|
|
327
|
+
```
|
|
328
|
+
|
|
329
|
+
**参数说明:**
|
|
330
|
+
|
|
331
|
+
| 参数名 | 类型 | 是否必填 | 默认值 | 描述 |
|
|
332
|
+
| ---------- | ------ | -------- | ------ | ------------------------------------- |
|
|
333
|
+
| `startX` | number | 是 | - | 滑动起始坐标 x 坐标 |
|
|
334
|
+
| `startY` | number | 是 | - | 滑动起始坐标 y 坐标 |
|
|
335
|
+
| `midX` | number | 是 | - | 曲线中间控制点 x 坐标 |
|
|
336
|
+
| `midY` | number | 是 | - | 曲线中间控制点 y 坐标 |
|
|
337
|
+
| `endX` | number | 是 | - | 滑动结束坐标 x 坐标 |
|
|
338
|
+
| `endY` | number | 是 | - | 滑动结束坐标 y 坐标 |
|
|
339
|
+
| `duration` | number | 否 | 1000 | 总滑动持续时间,单位毫秒,默认 1000ms |
|
|
340
|
+
|
|
341
|
+
**返回值:**
|
|
342
|
+
|
|
343
|
+
| 类型 | 描述 |
|
|
344
|
+
| --------- | ---------------- |
|
|
345
|
+
| `boolean` | 曲线滑动是否成功 |
|
|
346
|
+
|
|
347
|
+
**功能特点:**
|
|
348
|
+
|
|
349
|
+
- 使用二次贝塞尔曲线算法生成平滑的滑动路径
|
|
350
|
+
- 实现先快后慢的滑动效果,模拟真实的手势操作
|
|
351
|
+
- 根据滑动距离自动调整路径点数量,确保滑动平滑度
|
|
352
|
+
- **拟人化轨迹**:添加随机偏移和微抖动,模拟真实人手操作的不稳定性
|
|
353
|
+
- **随机化时间**:每个路径点的时间间隔都有随机变化,避免机械化操作
|
|
354
|
+
- **智能偏移**:中间路径点偏移更大,起点和终点保持精确,更符合人类操作习惯
|
|
355
|
+
- 适用于需要更自然滑动轨迹场景
|
|
356
|
+
|
|
357
|
+
**示例:**
|
|
358
|
+
|
|
359
|
+
```typescript
|
|
360
|
+
// 基础曲线滑动
|
|
361
|
+
action.swipeCurve(100, 100, 200, 150, 300, 200, 1000);
|
|
362
|
+
|
|
363
|
+
// 弧形向上滑动
|
|
364
|
+
action.swipeCurve(200, 500, 150, 300, 200, 100, 800);
|
|
365
|
+
|
|
366
|
+
// S形曲线滑动
|
|
367
|
+
action.swipeCurve(100, 200, 300, 100, 200, 400, 1200);
|
|
368
|
+
|
|
369
|
+
// 快速曲线滑动
|
|
370
|
+
action.swipeCurve(150, 300, 250, 200, 350, 400, 600);
|
|
371
|
+
|
|
372
|
+
// 慢速精确曲线滑动
|
|
373
|
+
action.swipeCurve(100, 100, 200, 50, 300, 100, 1500);
|
|
374
|
+
```
|
|
375
|
+
|
|
376
|
+
## 文本输入操作
|
|
377
|
+
|
|
378
|
+
- 仅输入框聚焦可用,以下方法是在模拟键盘操作
|
|
379
|
+
- 更多高级输入操作,请参考 [IME 模块](ime.md)
|
|
380
|
+
|
|
381
|
+
### input - 输入文本
|
|
382
|
+
|
|
383
|
+
```typescript
|
|
384
|
+
function input(text: string): boolean;
|
|
385
|
+
```
|
|
386
|
+
|
|
387
|
+
**参数说明:**
|
|
388
|
+
|
|
389
|
+
| 参数名 | 类型 | 是否必填 | 默认值 | 描述 |
|
|
390
|
+
| ------ | ------ | -------- | ------ | ---------------- |
|
|
391
|
+
| `text` | string | 是 | - | 要输入的文本内容 |
|
|
392
|
+
|
|
393
|
+
**返回值:**
|
|
394
|
+
|
|
395
|
+
| 类型 | 描述 |
|
|
396
|
+
| --------- | ---------------- |
|
|
397
|
+
| `boolean` | 输入文本是否成功 |
|
|
398
|
+
|
|
399
|
+
**示例:**
|
|
400
|
+
|
|
401
|
+
```javascript
|
|
402
|
+
// 输入文本
|
|
403
|
+
const success = action.input("hello 快点JS");
|
|
404
|
+
if (success) {
|
|
405
|
+
logi("成功输入文本");
|
|
406
|
+
}
|
|
407
|
+
```
|
|
408
|
+
|
|
409
|
+
### backspace - 删除文本
|
|
410
|
+
|
|
411
|
+
```typescript
|
|
412
|
+
function backspace(count?: number): boolean;
|
|
413
|
+
```
|
|
414
|
+
|
|
415
|
+
**参数说明:**
|
|
416
|
+
|
|
417
|
+
| 参数名 | 类型 | 是否必填 | 默认值 | 描述 |
|
|
418
|
+
| ------- | ------ | -------- | ------ | --------------------------- |
|
|
419
|
+
| `count` | number | 否 | 1 | 删除数量,默认删除 1 个字符 |
|
|
420
|
+
|
|
421
|
+
**返回值:**
|
|
422
|
+
|
|
423
|
+
| 类型 | 描述 |
|
|
424
|
+
| --------- | ---------------- |
|
|
425
|
+
| `boolean` | 删除文本是否成功 |
|
|
426
|
+
|
|
427
|
+
**示例:**
|
|
428
|
+
|
|
429
|
+
```typescript
|
|
430
|
+
// 删除最后一个字符
|
|
431
|
+
const success = action.backspace();
|
|
432
|
+
if (success) {
|
|
433
|
+
logi("成功删除最后一个字符");
|
|
434
|
+
}
|
|
435
|
+
|
|
436
|
+
// 删除多个字符
|
|
437
|
+
const success = action.backspace(3);
|
|
438
|
+
if (success) {
|
|
439
|
+
logi("成功删除 3 个字符");
|
|
440
|
+
}
|
|
441
|
+
```
|
|
442
|
+
|
|
443
|
+
### enter - 调用回车
|
|
444
|
+
|
|
445
|
+
```typescript
|
|
446
|
+
function enter(): boolean;
|
|
447
|
+
```
|
|
448
|
+
|
|
449
|
+
**返回值:**
|
|
450
|
+
|
|
451
|
+
| 类型 | 描述 |
|
|
452
|
+
| --------- | ---------------- |
|
|
453
|
+
| `boolean` | 调用回车是否成功 |
|
|
454
|
+
|
|
455
|
+
**示例:**
|
|
456
|
+
|
|
457
|
+
```typescript
|
|
458
|
+
// 调用回车
|
|
459
|
+
const success = action.enter();
|
|
460
|
+
if (success) {
|
|
461
|
+
logi("成功调用回车");
|
|
462
|
+
}
|
|
463
|
+
```
|
|
464
|
+
|
|
465
|
+
## 系统按键操作
|
|
466
|
+
|
|
467
|
+
### homeScreen - 返回到设备主屏幕
|
|
468
|
+
|
|
469
|
+
```typescript
|
|
470
|
+
function homeScreen(): boolean;
|
|
471
|
+
```
|
|
472
|
+
|
|
473
|
+
**返回值:**
|
|
474
|
+
|
|
475
|
+
| 类型 | 描述 |
|
|
476
|
+
| --------- | ---------------- |
|
|
477
|
+
| `boolean` | 返回首页是否成功 |
|
|
478
|
+
|
|
479
|
+
**示例:**
|
|
480
|
+
|
|
481
|
+
```typescript
|
|
482
|
+
// 返回主屏幕
|
|
483
|
+
const success = action.homeScreen();
|
|
484
|
+
if (success) {
|
|
485
|
+
logi("成功返回主屏幕");
|
|
486
|
+
}
|
|
487
|
+
|
|
488
|
+
// 在操作完成后返回主屏幕
|
|
489
|
+
function completeTaskAndGoHome() {
|
|
490
|
+
// 执行一些操作...
|
|
491
|
+
action.click(200, 300, 100, true);
|
|
492
|
+
sleep(1000);
|
|
493
|
+
|
|
494
|
+
// 返回主屏幕
|
|
495
|
+
action.homeScreen();
|
|
496
|
+
}
|
|
497
|
+
```
|
|
498
|
+
|
|
499
|
+
### pressButton - 按下系统按钮
|
|
500
|
+
|
|
501
|
+
```typescript
|
|
502
|
+
function pressButton(button: "home" | "volumeup" | "volumedown"): boolean;
|
|
503
|
+
```
|
|
504
|
+
|
|
505
|
+
**参数说明:**
|
|
506
|
+
|
|
507
|
+
| 参数名 | 类型 | 是否必填 | 默认值 | 描述 |
|
|
508
|
+
| -------- | ------ | -------- | ------ | ------------------------------------------------------------------------------------------ |
|
|
509
|
+
| `button` | string | 是 | - | 按钮类型: <br>-`"home"` Home 键 <br>- `"volumeup"` 音量上键 <br>- `"volumedown"` 音量下键 |
|
|
510
|
+
|
|
511
|
+
**返回值:**
|
|
512
|
+
|
|
513
|
+
| 类型 | 描述 |
|
|
514
|
+
| --------- | ---------------- |
|
|
515
|
+
| `boolean` | 按下按钮是否成功 |
|
|
516
|
+
|
|
517
|
+
**示例:**
|
|
518
|
+
|
|
519
|
+
```typescript
|
|
520
|
+
// 按下 Home 键
|
|
521
|
+
action.pressButton("home");
|
|
522
|
+
|
|
523
|
+
// 调高音量
|
|
524
|
+
action.pressButton("volumeup");
|
|
525
|
+
|
|
526
|
+
// 调低音量
|
|
527
|
+
action.pressButton("volumedown");
|
|
528
|
+
|
|
529
|
+
// 连续调节音量
|
|
530
|
+
for (let i = 0; i < 5; i++) {
|
|
531
|
+
action.pressButton("volumeup");
|
|
532
|
+
sleep(200);
|
|
533
|
+
}
|
|
534
|
+
```
|
|
535
|
+
|
|
536
|
+
## 动作构建器
|
|
537
|
+
|
|
538
|
+
ActionBuilder 提供了更高级的多点触控操作能力,支持链式调用构建复杂的手势动作。
|
|
539
|
+
|
|
540
|
+
### createBuilder - 创建 ActionBuilder 构建器
|
|
541
|
+
|
|
542
|
+
```typescript
|
|
543
|
+
function createBuilder(): ActionBuilder;
|
|
544
|
+
```
|
|
545
|
+
|
|
546
|
+
**返回值:**
|
|
547
|
+
|
|
548
|
+
| 类型 | 描述 |
|
|
549
|
+
| ------------- | ------------------------ |
|
|
550
|
+
| ActionBuilder | ActionBuilder 构建器实例 |
|
|
551
|
+
|
|
552
|
+
**示例:**
|
|
553
|
+
|
|
554
|
+
```javascript
|
|
555
|
+
// 创建构建器
|
|
556
|
+
const builder = action.createBuilder();
|
|
557
|
+
```
|
|
558
|
+
|
|
559
|
+
### ActionBuilder - ActionBuilder 构建器
|
|
560
|
+
|
|
561
|
+
ActionBuilder 构建器支持链式调用,可以构建复杂的多点触控动作。
|
|
562
|
+
|
|
563
|
+
#### addPointer - 添加指针(手指)
|
|
564
|
+
|
|
565
|
+
```typescript
|
|
566
|
+
addPointer(id: number): PointerBuilder;
|
|
567
|
+
```
|
|
568
|
+
|
|
569
|
+
**参数说明:**
|
|
570
|
+
|
|
571
|
+
| 参数名 | 类型 | 是否必填 | 默认值 | 描述 |
|
|
572
|
+
| ------ | ------ | -------- | ------ | ------------------------------------ |
|
|
573
|
+
| `id` | number | 是 | - | 指针编号,1-10,对应设备上的手指编号 |
|
|
574
|
+
|
|
575
|
+
**返回值:**
|
|
576
|
+
|
|
577
|
+
| 类型 | 描述 |
|
|
578
|
+
| ---------------- | -------------------------------- |
|
|
579
|
+
| `PointerBuilder` | 指针构建器,用于配置该指针的动作 |
|
|
580
|
+
|
|
581
|
+
**示例:**
|
|
582
|
+
|
|
583
|
+
```javascript
|
|
584
|
+
const builder = action.createBuilder();
|
|
585
|
+
// 添加第一个手指
|
|
586
|
+
const pointer1 = builder.addPointer(1);
|
|
587
|
+
|
|
588
|
+
// 添加第二个手指
|
|
589
|
+
const pointer2 = builder.addPointer(2);
|
|
590
|
+
```
|
|
591
|
+
|
|
592
|
+
#### singleTap - 快速单点点击
|
|
593
|
+
|
|
594
|
+
```typescript
|
|
595
|
+
singleTap(x: number, y: number, duration?: number): ActionBuilder;
|
|
596
|
+
```
|
|
597
|
+
|
|
598
|
+
**参数说明:**
|
|
599
|
+
|
|
600
|
+
| 参数名 | 类型 | 是否必填 | 默认值 | 描述 |
|
|
601
|
+
| ---------- | ------ | -------- | ------ | ------------------------------------- |
|
|
602
|
+
| `x` | number | 是 | - | X 坐标 |
|
|
603
|
+
| `y` | number | 是 | - | Y 坐标 |
|
|
604
|
+
| `duration` | number | 否 | 20 | 点击持续时间,如果未定义则默认为 20ms |
|
|
605
|
+
|
|
606
|
+
**返回值:**
|
|
607
|
+
|
|
608
|
+
| 类型 | 描述 |
|
|
609
|
+
| --------------- | ---------------------- |
|
|
610
|
+
| `ActionBuilder` | 返回自身,支持链式调用 |
|
|
611
|
+
|
|
612
|
+
**示例:**
|
|
613
|
+
|
|
614
|
+
```javascript
|
|
615
|
+
const builder = action.createBuilder();
|
|
616
|
+
// 快速单点点击
|
|
617
|
+
builder.singleTap(100, 100, 50).execute();
|
|
618
|
+
|
|
619
|
+
// 连续点击
|
|
620
|
+
builder.singleTap(100, 100, 30).singleTap(200, 200, 30).execute();
|
|
621
|
+
```
|
|
622
|
+
|
|
623
|
+
#### multiTap - 快速多点点击
|
|
624
|
+
|
|
625
|
+
```typescript
|
|
626
|
+
multiTap(points: { x: number; y: number }[], duration?: number): ActionBuilder;
|
|
627
|
+
```
|
|
628
|
+
|
|
629
|
+
**参数说明:**
|
|
630
|
+
|
|
631
|
+
| 参数名 | 类型 | 是否必填 | 默认值 | 描述 |
|
|
632
|
+
| ---------- | ------ | -------- | ------ | -------------------------------------- |
|
|
633
|
+
| `points` | array | 是 | - | 点击坐标数组,每个元素包含 x 和 y 坐标 |
|
|
634
|
+
| `duration` | number | 否 | 20 | 点击持续时间,如果未定义则默认为 20ms |
|
|
635
|
+
|
|
636
|
+
**返回值:**
|
|
637
|
+
|
|
638
|
+
| 类型 | 描述 |
|
|
639
|
+
| --------------- | ---------------------- |
|
|
640
|
+
| `ActionBuilder` | 返回自身,支持链式调用 |
|
|
641
|
+
|
|
642
|
+
**示例:**
|
|
643
|
+
|
|
644
|
+
```javascript
|
|
645
|
+
const builder = action.createBuilder();
|
|
646
|
+
// 多点同时点击
|
|
647
|
+
const points = [
|
|
648
|
+
{ x: 100, y: 100 },
|
|
649
|
+
{ x: 200, y: 200 },
|
|
650
|
+
{ x: 300, y: 300 },
|
|
651
|
+
];
|
|
652
|
+
builder.multiTap(points, 50).execute();
|
|
653
|
+
|
|
654
|
+
// 双指点击
|
|
655
|
+
builder
|
|
656
|
+
.multiTap(
|
|
657
|
+
[
|
|
658
|
+
{ x: 150, y: 300 },
|
|
659
|
+
{ x: 250, y: 300 },
|
|
660
|
+
],
|
|
661
|
+
100,
|
|
662
|
+
)
|
|
663
|
+
.execute();
|
|
664
|
+
```
|
|
665
|
+
|
|
666
|
+
#### execute - 执行动作
|
|
667
|
+
|
|
668
|
+
```typescript
|
|
669
|
+
execute(): boolean;
|
|
670
|
+
```
|
|
671
|
+
|
|
672
|
+
**返回值:**
|
|
673
|
+
|
|
674
|
+
| 类型 | 描述 |
|
|
675
|
+
| --------- | ------------ |
|
|
676
|
+
| `boolean` | 执行是否成功 |
|
|
677
|
+
|
|
678
|
+
**示例:**
|
|
679
|
+
|
|
680
|
+
```javascript
|
|
681
|
+
const builder = action.createBuilder();
|
|
682
|
+
// 执行构建的动作
|
|
683
|
+
const success = builder
|
|
684
|
+
.addPointer(1)
|
|
685
|
+
.moveTo(100, 100)
|
|
686
|
+
.tap(200, 200)
|
|
687
|
+
.done()
|
|
688
|
+
.execute();
|
|
689
|
+
|
|
690
|
+
if (success) {
|
|
691
|
+
logi("动作执行成功");
|
|
692
|
+
}
|
|
693
|
+
```
|
|
694
|
+
|
|
695
|
+
### PointerBuilder - 指针构建器
|
|
696
|
+
|
|
697
|
+
指针构建器用于配置单个指针(手指)的动作序列。
|
|
698
|
+
|
|
699
|
+
#### moveTo - 移动到指定坐标
|
|
700
|
+
|
|
701
|
+
```typescript
|
|
702
|
+
moveTo(x: number, y: number, duration?: number): PointerBuilder;
|
|
703
|
+
```
|
|
704
|
+
|
|
705
|
+
**参数说明:**
|
|
706
|
+
|
|
707
|
+
| 参数名 | 类型 | 是否必填 | 默认值 | 描述 |
|
|
708
|
+
| ---------- | ------ | -------- | ------ | ------------------------------------ |
|
|
709
|
+
| `x` | number | 是 | - | X 坐标 |
|
|
710
|
+
| `y` | number | 是 | - | Y 坐标 |
|
|
711
|
+
| `duration` | number | 否 | 0 | 移动持续时间,如果未定义则默认为 0ms |
|
|
712
|
+
|
|
713
|
+
**返回值:**
|
|
714
|
+
|
|
715
|
+
| 类型 | 描述 |
|
|
716
|
+
| ---------------- | ---------------------- |
|
|
717
|
+
| `PointerBuilder` | 返回自身,支持链式调用 |
|
|
718
|
+
|
|
719
|
+
#### down - 按下手指
|
|
720
|
+
|
|
721
|
+
```typescript
|
|
722
|
+
down(): PointerBuilder;
|
|
723
|
+
```
|
|
724
|
+
|
|
725
|
+
**返回值:**
|
|
726
|
+
|
|
727
|
+
| 类型 | 描述 |
|
|
728
|
+
| -------------- | ---------------------- |
|
|
729
|
+
| PointerBuilder | 返回自身,支持链式调用 |
|
|
730
|
+
|
|
731
|
+
#### up - 抬起手指
|
|
732
|
+
|
|
733
|
+
```typescript
|
|
734
|
+
up(): PointerBuilder;
|
|
735
|
+
```
|
|
736
|
+
|
|
737
|
+
**返回值:**
|
|
738
|
+
|
|
739
|
+
| 类型 | 描述 |
|
|
740
|
+
| ---------------- | ---------------------- |
|
|
741
|
+
| `PointerBuilder` | 返回自身,支持链式调用 |
|
|
742
|
+
|
|
743
|
+
#### stay - 停留时间
|
|
744
|
+
|
|
745
|
+
```typescript
|
|
746
|
+
stay(duration?: number): PointerBuilder;
|
|
747
|
+
```
|
|
748
|
+
|
|
749
|
+
**参数说明:**
|
|
750
|
+
|
|
751
|
+
| 参数名 | 类型 | 是否必填 | 默认值 | 描述 |
|
|
752
|
+
| ---------- | ------ | -------- | ------ | ----------------------------------------- |
|
|
753
|
+
| `duration` | number | 否 | 20 | 停留时间(毫秒),如果未定义则默认为 20ms |
|
|
754
|
+
|
|
755
|
+
**返回值:**
|
|
756
|
+
|
|
757
|
+
| 类型 | 描述 |
|
|
758
|
+
| ---------------- | ---------------------- |
|
|
759
|
+
| `PointerBuilder` | 返回自身,支持链式调用 |
|
|
760
|
+
|
|
761
|
+
#### tap - 执行点击动作
|
|
762
|
+
|
|
763
|
+
```typescript
|
|
764
|
+
tap(x: number, y: number, duration?: number): PointerBuilder;
|
|
765
|
+
```
|
|
766
|
+
|
|
767
|
+
**参数说明:**
|
|
768
|
+
|
|
769
|
+
| 参数名 | 类型 | 是否必填 | 默认值 | 描述 |
|
|
770
|
+
| ---------- | ------ | -------- | ------ | ------------------------------------- |
|
|
771
|
+
| `x` | number | 是 | - | X 坐标 |
|
|
772
|
+
| `y` | number | 是 | - | Y 坐标 |
|
|
773
|
+
| `duration` | number | 否 | 20 | 按下持续时间,如果未定义则默认为 20ms |
|
|
774
|
+
|
|
775
|
+
**返回值:**
|
|
776
|
+
|
|
777
|
+
| 类型 | 描述 |
|
|
778
|
+
| ---------------- | ---------------------- |
|
|
779
|
+
| `PointerBuilder` | 返回自身,支持链式调用 |
|
|
780
|
+
|
|
781
|
+
**功能说明:**
|
|
782
|
+
|
|
783
|
+
- 自动执行:移动 -> 按下 -> 暂停 -> 抬起的完整点击序列
|
|
784
|
+
|
|
785
|
+
#### done - 完成指针配置
|
|
786
|
+
|
|
787
|
+
```typescript
|
|
788
|
+
done(): ActionBuilder;
|
|
789
|
+
```
|
|
790
|
+
|
|
791
|
+
**返回值:**
|
|
792
|
+
|
|
793
|
+
| 类型 | 描述 |
|
|
794
|
+
| --------------- | ---------------------------------- |
|
|
795
|
+
| `ActionBuilder` | 返回主构建器,可以继续添加其他指针 |
|
|
796
|
+
|
|
797
|
+
## 高级使用示例
|
|
798
|
+
|
|
799
|
+
### 单指滑动
|
|
800
|
+
|
|
801
|
+
```javascript
|
|
802
|
+
// 单指从左到右滑动
|
|
803
|
+
const builder = action.createBuilder();
|
|
804
|
+
builder
|
|
805
|
+
.addPointer(1)
|
|
806
|
+
.moveTo(100, 300, 0) // 移动到起始位置
|
|
807
|
+
.down() // 按下
|
|
808
|
+
.moveTo(400, 300, 500) // 滑动到结束位置
|
|
809
|
+
.up() // 抬起
|
|
810
|
+
.done()
|
|
811
|
+
.execute();
|
|
812
|
+
```
|
|
813
|
+
|
|
814
|
+
### 双指缩放(放大)
|
|
815
|
+
|
|
816
|
+
```javascript
|
|
817
|
+
// 双指从中心向外扩展
|
|
818
|
+
const builder = action.createBuilder();
|
|
819
|
+
builder
|
|
820
|
+
.addPointer(1)
|
|
821
|
+
.moveTo(200, 300, 0) // 第一个手指起始位置
|
|
822
|
+
.down()
|
|
823
|
+
.moveTo(150, 250, 300) // 向左上移动
|
|
824
|
+
.up()
|
|
825
|
+
.done()
|
|
826
|
+
.addPointer(2)
|
|
827
|
+
.moveTo(200, 300, 0) // 第二个手指起始位置
|
|
828
|
+
.down()
|
|
829
|
+
.moveTo(250, 350, 300) // 向右下移动
|
|
830
|
+
.up()
|
|
831
|
+
.done()
|
|
832
|
+
.execute();
|
|
833
|
+
```
|
|
834
|
+
|
|
835
|
+
### 双指缩放(缩小)
|
|
836
|
+
|
|
837
|
+
```javascript
|
|
838
|
+
// 双指从外向中心收缩
|
|
839
|
+
const builder = action.createBuilder();
|
|
840
|
+
builder
|
|
841
|
+
.addPointer(1)
|
|
842
|
+
.moveTo(150, 250, 0) // 第一个手指起始位置
|
|
843
|
+
.down()
|
|
844
|
+
.moveTo(200, 300, 300) // 向中心移动
|
|
845
|
+
.up()
|
|
846
|
+
.done()
|
|
847
|
+
.addPointer(2)
|
|
848
|
+
.moveTo(250, 350, 0) // 第二个手指起始位置
|
|
849
|
+
.down()
|
|
850
|
+
.moveTo(200, 300, 300) // 向中心移动
|
|
851
|
+
.up()
|
|
852
|
+
.done()
|
|
853
|
+
.execute();
|
|
854
|
+
```
|
|
855
|
+
|
|
856
|
+
### 双指旋转
|
|
857
|
+
|
|
858
|
+
```javascript
|
|
859
|
+
// 双指围绕中心点旋转
|
|
860
|
+
const builder = action.createBuilder();
|
|
861
|
+
const centerX = 200,
|
|
862
|
+
centerY = 300;
|
|
863
|
+
const radius = 50;
|
|
864
|
+
|
|
865
|
+
builder
|
|
866
|
+
.addPointer(1)
|
|
867
|
+
.moveTo(centerX - radius, centerY, 0) // 左侧起始
|
|
868
|
+
.down()
|
|
869
|
+
.moveTo(centerX, centerY - radius, 200) // 向上旋转
|
|
870
|
+
.moveTo(centerX + radius, centerY, 200) // 向右旋转
|
|
871
|
+
.up()
|
|
872
|
+
.done()
|
|
873
|
+
.addPointer(2)
|
|
874
|
+
.moveTo(centerX + radius, centerY, 0) // 右侧起始
|
|
875
|
+
.down()
|
|
876
|
+
.moveTo(centerX, centerY + radius, 200) // 向下旋转
|
|
877
|
+
.moveTo(centerX - radius, centerY, 200) // 向左旋转
|
|
878
|
+
.up()
|
|
879
|
+
.done()
|
|
880
|
+
.execute();
|
|
881
|
+
```
|
|
882
|
+
|
|
883
|
+
### 长按拖拽
|
|
884
|
+
|
|
885
|
+
```javascript
|
|
886
|
+
// 长按后拖拽元素
|
|
887
|
+
const builder = action.createBuilder();
|
|
888
|
+
builder
|
|
889
|
+
.addPointer(1)
|
|
890
|
+
.moveTo(100, 100, 0) // 移动到目标位置
|
|
891
|
+
.down() // 按下
|
|
892
|
+
.stay(800) // 长按 800ms
|
|
893
|
+
.moveTo(300, 400, 1000) // 拖拽到新位置
|
|
894
|
+
.up() // 抬起
|
|
895
|
+
.done()
|
|
896
|
+
.execute();
|
|
897
|
+
```
|
|
898
|
+
|
|
899
|
+
### 复杂手势组合
|
|
900
|
+
|
|
901
|
+
```javascript
|
|
902
|
+
// 先点击,再滑动,最后双击
|
|
903
|
+
const builder = action.createBuilder();
|
|
904
|
+
|
|
905
|
+
// 第一步:单击
|
|
906
|
+
builder.singleTap(100, 100, 50);
|
|
907
|
+
|
|
908
|
+
// 第二步:滑动
|
|
909
|
+
builder
|
|
910
|
+
.addPointer(1)
|
|
911
|
+
.moveTo(200, 200, 0)
|
|
912
|
+
.down()
|
|
913
|
+
.moveTo(400, 200, 600)
|
|
914
|
+
.up()
|
|
915
|
+
.done();
|
|
916
|
+
|
|
917
|
+
// 第三步:双击
|
|
918
|
+
builder.multiTap([{ x: 300, y: 300 }], 30);
|
|
919
|
+
|
|
920
|
+
// 执行所有动作
|
|
921
|
+
builder.execute();
|
|
922
|
+
```
|