tcic-electron-sdk 1.5.245 → 1.5.248

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.
@@ -1,402 +1 @@
1
- /******/ (() => { // webpackBootstrap
2
- /******/ "use strict";
3
- /******/ var __webpack_modules__ = ({
4
-
5
- /***/ "./src/boardRenderer.ts":
6
- /*!******************************!*\
7
- !*** ./src/boardRenderer.ts ***!
8
- \******************************/
9
- /***/ (function(__unused_webpack_module, exports, __webpack_require__) {
10
-
11
-
12
- // This file is required by the board.html file and will
13
- // be executed in the renderer process for that window.
14
- // No Node.js APIs are available in this process because
15
- // `nodeIntegration` is turned off. Use `preload.js` to
16
- // selectively enable features needed in the rendering
17
- // process.
18
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
19
- if (k2 === undefined) k2 = k;
20
- Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
21
- }) : (function(o, m, k, k2) {
22
- if (k2 === undefined) k2 = k;
23
- o[k2] = m[k];
24
- }));
25
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
26
- Object.defineProperty(o, "default", { enumerable: true, value: v });
27
- }) : function(o, v) {
28
- o["default"] = v;
29
- });
30
- var __importStar = (this && this.__importStar) || function (mod) {
31
- if (mod && mod.__esModule) return mod;
32
- var result = {};
33
- if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
34
- __setModuleDefault(result, mod);
35
- return result;
36
- };
37
- Object.defineProperty(exports, "__esModule", ({ value: true }));
38
- const electron_1 = __webpack_require__(/*! electron */ "electron");
39
- const rendererUtil = __importStar(__webpack_require__(/*! ./rendererUtil */ "./src/rendererUtil.ts"));
40
- // import { tcicSdkVersion } from './sentry'; // 用于初始化异常捕获,切勿删除
41
- // console.log('version', tcicSdkVersion);
42
- class BoardRender {
43
- static setVisibleRect(bounds) {
44
- if (bounds) {
45
- if (BoardRender.screenHeight === 0 || BoardRender.screenWidth === 0) {
46
- BoardRender.screenHeight = screen.height;
47
- BoardRender.screenWidth = screen.width;
48
- BoardRender.boardElement.style.width = `${screen.width}px`;
49
- BoardRender.boardElement.style.height = `${screen.height}px`;
50
- }
51
- BoardRender.boardWrapElement.style.width = `${bounds.width}px`;
52
- BoardRender.boardWrapElement.style.height = `${bounds.height}px`;
53
- BoardRender.boardWrapElement.style.left = `${bounds.x}px`;
54
- BoardRender.boardWrapElement.style.top = `${bounds.y}px`;
55
- BoardRender.boardWrapElement.style.position = 'absolute';
56
- }
57
- else {
58
- BoardRender.boardWrapElement.removeAttribute('style');
59
- BoardRender.boardElement.removeAttribute('style');
60
- }
61
- }
62
- ;
63
- static updateCursor() {
64
- if (!BoardRender.teduBoard)
65
- return;
66
- const toolType = BoardRender.teduBoard.getToolType();
67
- const brushColor = BoardRender.teduBoard.getBrushColor();
68
- if (toolType === BoardRender.TEduBoard.TEduBoardToolType.TEDU_BOARD_TOOL_TYPE_PEN) {
69
- const cursorSvg = `<?xml version="1.0" encoding="UTF-8"?><svg width="40px" height="40px" viewBox="0 0 40 40" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"><title>mouse_pen</title>
70
- <g id="页面-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
71
- <g id="光标及状态栏状态" transform="translate(-89.000000, -268.000000)">
72
- <g id="mouse_pen" transform="translate(89.000000, 268.000000)">
73
- <rect id="矩形" x="0" y="0" width="40" height="40"></rect>
74
- <g id="编组-13" transform="translate(8.000000, 3.000000)" fill="${brushColor}" stroke="#182E25">
75
- <path d="M0.756984031,32.1383216 L3.68816089e-13,26.5292023 L17.8941729,7.81597009e-14 L24.5264735,4.47354323 L6.63230058,31.0027455 L0.756984031,32.1383216 Z" id="形状结合"></path>
76
- </g>
77
- </g>
78
- </g>
79
- </g>
80
- </svg>`;
81
- const cursorBase64 = `data:image/svg+xml;charset=utf-8,${escape(cursorSvg)}`;
82
- BoardRender.teduBoard.setCursorIcon(toolType, {
83
- cursor: 'url',
84
- url: cursorBase64,
85
- offsetX: 10,
86
- offsetY: 40,
87
- });
88
- }
89
- else if (toolType === BoardRender.TEduBoard.TEduBoardToolType.TEDU_BOARD_TOOL_TYPE_LINE) {
90
- const cursorSvg = `<?xml version="1.0" encoding="UTF-8"?>
91
- <svg width="40px" height="40px" viewBox="0 0 40 40" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
92
- <title>mouse_line</title>
93
- <g id="页面-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
94
- <g id="光标及状态栏状态" transform="translate(-785.000000, -272.000000)">
95
- <g id="mouse_line" transform="translate(785.000000, 272.000000)">
96
- <g id="编组-3">
97
- <rect id="矩形" x="0" y="0" width="40" height="40"></rect>
98
- <g id="编组" transform="translate(2.628157, 2.500000)" fill="#000000" stroke="#FFFFFF">
99
- <path d="M19.6574089,0 L19.657,15.5 L34.6259534,15.5 L34.6259534,19.5 L19.657,19.5 L19.6574089,35 L15.6574089,35 L15.657,19.5 L-1.13686838e-13,19.5 L-1.13686838e-13,15.5 L15.657,15.5 L15.6574089,0 L19.6574089,0 Z" id="形状结合"></path>
100
- </g>
101
- </g>
102
- <line x1="28.5" y1="7.5" x2="36.5" y2="7.5" id="直线-6" stroke="${brushColor}" stroke-width="2" stroke-linecap="square"></line>
103
- </g>
104
- </g>
105
- </g>
106
- </svg>`;
107
- const cursorBase64 = `data:image/svg+xml;base64,${window.btoa(unescape(encodeURIComponent(cursorSvg)))}`;
108
- BoardRender.teduBoard.setCursorIcon(toolType, {
109
- cursor: 'url',
110
- url: cursorBase64,
111
- offsetX: 20,
112
- offsetY: 20,
113
- });
114
- }
115
- else if (toolType === BoardRender.TEduBoard.TEduBoardToolType.TEDU_BOARD_TOOL_TYPE_RECT) {
116
- const cursorSvg = `<?xml version="1.0" encoding="UTF-8"?>
117
- <svg width="40px" height="40px" viewBox="0 0 40 40" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
118
- <title>mouse_rectangle</title>
119
- <g id="页面-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
120
- <g id="光标及状态栏状态" transform="translate(-551.000000, -272.000000)">
121
- <g id="mouse_rectangle" transform="translate(551.000000, 272.000000)">
122
- <g id="编组-3">
123
- <rect id="矩形" x="0" y="0" width="40" height="40"></rect>
124
- <g id="编组" transform="translate(2.628157, 2.500000)" fill="#000000" stroke="#FFFFFF">
125
- <path d="M19.6574089,0 L19.657,15.5 L34.6259534,15.5 L34.6259534,19.5 L19.657,19.5 L19.6574089,35 L15.6574089,35 L15.657,19.5 L-1.13686838e-13,19.5 L-1.13686838e-13,15.5 L15.657,15.5 L15.6574089,0 L19.6574089,0 Z" id="形状结合"></path>
126
- </g>
127
- </g>
128
- <rect id="矩形" stroke="${brushColor}" stroke-width="2" x="28" y="3" width="8" height="8"></rect>
129
- </g>
130
- </g>
131
- </g>
132
- </svg>`;
133
- const cursorBase64 = `data:image/svg+xml;base64,${window.btoa(unescape(encodeURIComponent(cursorSvg)))}`;
134
- BoardRender.teduBoard.setCursorIcon(toolType, {
135
- cursor: 'url',
136
- url: cursorBase64,
137
- offsetX: 20,
138
- offsetY: 20,
139
- });
140
- // 矩形也设置一下(当按住shift键的时候,工具会切换为矩形)
141
- BoardRender.teduBoard.setCursorIcon(BoardRender.TEduBoard.TEduBoardToolType.TEDU_BOARD_TOOL_TYPE_SQUARE, {
142
- cursor: 'url',
143
- url: cursorBase64,
144
- offsetX: 20,
145
- offsetY: 20,
146
- });
147
- }
148
- else if (toolType === BoardRender.TEduBoard.TEduBoardToolType.TEDU_BOARD_TOOL_TYPE_OVAL) {
149
- const cursorSvg = `<?xml version="1.0" encoding="UTF-8"?>
150
- <svg width="40px" height="40px" viewBox="0 0 40 40" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
151
- <title>mouse_circle</title>
152
- <g id="页面-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
153
- <g id="光标及状态栏状态" transform="translate(-323.000000, -272.000000)">
154
- <g id="mouse_circle" transform="translate(323.000000, 272.000000)">
155
- <g id="编组-3">
156
- <rect id="矩形" x="0" y="0" width="40" height="40"></rect>
157
- <g id="编组" transform="translate(2.628157, 2.500000)" fill="#000000" stroke="#FFFFFF">
158
- <path d="M19.6574089,0 L19.657,15.5 L34.6259534,15.5 L34.6259534,19.5 L19.657,19.5 L19.6574089,35 L15.6574089,35 L15.657,19.5 L-1.13686838e-13,19.5 L-1.13686838e-13,15.5 L15.657,15.5 L15.6574089,0 L19.6574089,0 Z" id="形状结合"></path>
159
- </g>
160
- </g>
161
- <circle id="椭圆形" stroke="${brushColor}" stroke-width="2" cx="32" cy="7" r="4"></circle>
162
- </g>
163
- </g>
164
- </g>
165
- </svg>`;
166
- const cursorBase64 = `data:image/svg+xml;base64,${window.btoa(unescape(encodeURIComponent(cursorSvg)))}`;
167
- BoardRender.teduBoard.setCursorIcon(toolType, {
168
- cursor: 'url',
169
- url: cursorBase64,
170
- offsetX: 20,
171
- offsetY: 20,
172
- });
173
- // 正圆也设置一下(当按住shift键的时候,工具会切换为正圆)
174
- BoardRender.teduBoard.setCursorIcon(BoardRender.TEduBoard.TEduBoardToolType.TEDU_BOARD_TOOL_TYPE_CIRCLE, {
175
- cursor: 'url',
176
- url: cursorBase64,
177
- offsetX: 20,
178
- offsetY: 20,
179
- });
180
- }
181
- BoardRender.teduBoard.setToolType(toolType); // 马上再更新一下工具,保证光标生效(白板bug)
182
- }
183
- ;
184
- static callBoardMethod(arg) {
185
- console.log('callBoardMethod', BoardRender.teduBoard, JSON.stringify(arg));
186
- if (BoardRender.teduBoard) {
187
- // eslint-disable-next-line prefer-spread
188
- BoardRender.teduBoard[arg.method].apply(BoardRender.teduBoard, arg.params);
189
- BoardRender.updateCursor();
190
- // if (arg.method === 'setToolType') {
191
- // const toolType = arg.params[0];
192
- // // 系统光标对阴影滤镜支持不好,激光笔渐变部分会出现黑色阴影,目前先将激光笔用模拟的方式来实现,其他工具继续使用系统光标(同时在touch设备下系统光标也不会出现)
193
- // if (toolType === BoardRender.teduBoard.TEduBoardToolType.TEDU_BOARD_TOOL_TYPE_LASER) {
194
- // BoardRender.teduBoard.setSystemCursorEnable(false);
195
- // } else {
196
- // BoardRender.teduBoard.setSystemCursorEnable(true);
197
- // }
198
- // }
199
- }
200
- }
201
- ;
202
- }
203
- BoardRender.TEduBoard = window.TEduBoard;
204
- BoardRender.teduBoard = null;
205
- BoardRender.boardElement = null;
206
- BoardRender.boardWrapElement = null;
207
- BoardRender.screenWidth = 0;
208
- BoardRender.screenHeight = 0;
209
- BoardRender.callMethodCache = []; // 缓存白板初始化完成前的指令
210
- BoardRender.isBoardReady = false;
211
- ;
212
- window.BoardRender = BoardRender;
213
- electron_1.ipcRenderer.on('initBoard', (event, params) => {
214
- const BoardRender = window.BoardRender;
215
- if (BoardRender.teduBoard) {
216
- return;
217
- }
218
- const initParams = {
219
- id: 'board',
220
- sdkAppId: params.sdkAppId,
221
- classId: params.roomId,
222
- userId: params.userId,
223
- userSig: params.userSig,
224
- ratio: `${screen.width}:${screen.height}`,
225
- systemCursorEnable: false,
226
- enableLocalMode: true,
227
- styleConfig: {
228
- globalBackgroundColor: 'rgba(0, 0, 0, 0.01)',
229
- textColor: '#ff0000',
230
- selectBoxColor: '#727272',
231
- cursorSize: [40, 40],
232
- brushThin: 50,
233
- selectAnchorColor: '#006eff',
234
- },
235
- };
236
- BoardRender.teduBoard = new BoardRender.TEduBoard(initParams);
237
- // 监听白板错误事件
238
- BoardRender.teduBoard.on(BoardRender.TEduBoard.EVENT.TEB_ERROR, (code, msg) => {
239
- });
240
- // 监听白板告警事件
241
- BoardRender.teduBoard.on(BoardRender.TEduBoard.EVENT.TEB_WARNING, (code, msg) => {
242
- });
243
- BoardRender.teduBoard.on(BoardRender.TEduBoard.EVENT.TEB_HISTROYDATA_SYNCCOMPLETED, () => {
244
- // 默认使用鼠标工具
245
- BoardRender.teduBoard.setToolType(BoardRender.TEduBoard.TEduBoardToolType.TEDU_BOARD_TOOL_TYPE_MOUSE);
246
- // 启用笔锋特性
247
- BoardRender.teduBoard.setHandwritingEnable(true);
248
- // 设置橡皮擦自定义图标
249
- BoardRender.teduBoard.setCursorIcon(BoardRender.TEduBoard.TEduBoardToolType.TEDU_BOARD_TOOL_TYPE_ERASER, {
250
- cursor: 'url',
251
- url: 'https://res.qcloudtiw.com/board/icons/xkt/eraser.svg',
252
- offsetX: 7,
253
- offsetY: 25,
254
- });
255
- BoardRender.updateCursor();
256
- if (BoardRender.callMethodCache.length === 0) {
257
- // 没有指令,则默认设置未鼠标工具
258
- BoardRender.teduBoard.setToolType(0);
259
- }
260
- else {
261
- // 执行缓存指令
262
- BoardRender.callMethodCache.forEach((arg) => {
263
- BoardRender.callBoardMethod(arg);
264
- });
265
- BoardRender.callMethodCache = [];
266
- }
267
- BoardRender.isBoardReady = true;
268
- });
269
- // 监听事件,image为截图内容的base64数据
270
- BoardRender.teduBoard.on(BoardRender.TEduBoard.EVENT.TEB_SNAPSHOT, (data) => {
271
- electron_1.ipcRenderer.send('onScreenShareSnapshot', data);
272
- });
273
- BoardRender.teduBoard.on(BoardRender.TEduBoard.EVENT.TEB_OPERATE_CANREDO_STATUS_CHANGED, (status) => {
274
- electron_1.ipcRenderer.send('onBoardCanRedoChange', status);
275
- });
276
- BoardRender.teduBoard.on(BoardRender.TEduBoard.EVENT.TEB_OPERATE_CANUNDO_STATUS_CHANGED, (status) => {
277
- electron_1.ipcRenderer.send('onBoardCanUndoChange', status);
278
- });
279
- BoardRender.setVisibleRect(params.shareWindowBounds);
280
- });
281
- electron_1.ipcRenderer.on('onShareWindowBoundsChanged', (event, bounds) => {
282
- const BoardRender = window.BoardRender;
283
- BoardRender.setVisibleRect(bounds);
284
- });
285
- electron_1.ipcRenderer.on('callMethod', (event, arg) => {
286
- const BoardRender = window.BoardRender;
287
- if (!BoardRender.isBoardReady) { // 白板为初始化完成,缓存白板指令
288
- BoardRender.callMethodCache.push(arg);
289
- return;
290
- }
291
- BoardRender.callBoardMethod(arg);
292
- });
293
- const events = ['touchstart', 'touchend'];
294
- electron_1.ipcRenderer.on('enableWatchMouseMoveEvent', (event, enabled) => {
295
- rendererUtil.watchEvents(document, events, enabled);
296
- });
297
- window.onload = () => {
298
- BoardRender.boardWrapElement = document.getElementById('board-wrap');
299
- BoardRender.boardElement = document.getElementById('board');
300
- };
301
-
302
-
303
- /***/ }),
304
-
305
- /***/ "./src/rendererUtil.ts":
306
- /*!*****************************!*\
307
- !*** ./src/rendererUtil.ts ***!
308
- \*****************************/
309
- /***/ ((__unused_webpack_module, exports, __webpack_require__) => {
310
-
311
-
312
- Object.defineProperty(exports, "__esModule", ({ value: true }));
313
- exports.watchEvents = void 0;
314
- const electron_1 = __webpack_require__(/*! electron */ "electron");
315
- function createMouseMoveProcessor() {
316
- const lastX = 0;
317
- const lastY = 0;
318
- return (e) => {
319
- let x;
320
- let y;
321
- if (e instanceof TouchEvent) { // 触摸事件
322
- x = Math.round(e.changedTouches[0].screenX);
323
- y = Math.round(e.changedTouches[0].screenY);
324
- }
325
- else { // 鼠标事件
326
- x = e.screenX;
327
- y = e.screenY;
328
- }
329
- if (x !== lastX || y !== lastY) { // 只有位置发生变化时才发送消息,减少资源消耗
330
- const args = { type: e.type, x, y };
331
- electron_1.ipcRenderer.send('onMouseEvent', args);
332
- console.log('onMouseEvent', args);
333
- }
334
- };
335
- }
336
- const eventProcessor = createMouseMoveProcessor();
337
- function watchEvents(target, events, enabled) {
338
- events.forEach((event) => {
339
- if (enabled) {
340
- target.addEventListener(event, eventProcessor, {
341
- capture: true,
342
- passive: false,
343
- });
344
- }
345
- else {
346
- target.removeEventListener(event, eventProcessor, {
347
- capture: true,
348
- });
349
- }
350
- });
351
- }
352
- exports.watchEvents = watchEvents;
353
-
354
-
355
- /***/ }),
356
-
357
- /***/ "electron":
358
- /*!***************************!*\
359
- !*** external "electron" ***!
360
- \***************************/
361
- /***/ ((module) => {
362
-
363
- module.exports = require("electron");
364
-
365
- /***/ })
366
-
367
- /******/ });
368
- /************************************************************************/
369
- /******/ // The module cache
370
- /******/ var __webpack_module_cache__ = {};
371
- /******/
372
- /******/ // The require function
373
- /******/ function __webpack_require__(moduleId) {
374
- /******/ // Check if module is in cache
375
- /******/ var cachedModule = __webpack_module_cache__[moduleId];
376
- /******/ if (cachedModule !== undefined) {
377
- /******/ return cachedModule.exports;
378
- /******/ }
379
- /******/ // Create a new module (and put it into the cache)
380
- /******/ var module = __webpack_module_cache__[moduleId] = {
381
- /******/ // no module.id needed
382
- /******/ // no module.loaded needed
383
- /******/ exports: {}
384
- /******/ };
385
- /******/
386
- /******/ // Execute the module function
387
- /******/ __webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);
388
- /******/
389
- /******/ // Return the exports of the module
390
- /******/ return module.exports;
391
- /******/ }
392
- /******/
393
- /************************************************************************/
394
- /******/
395
- /******/ // startup
396
- /******/ // Load entry module and return exports
397
- /******/ // This entry module is referenced by other modules so it can't be inlined
398
- /******/ var __webpack_exports__ = __webpack_require__("./src/boardRenderer.ts");
399
- /******/
400
- /******/ })()
401
- ;
402
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://tcic-electron-sdk/./src/boardRenderer.ts","webpack://tcic-electron-sdk/./src/rendererUtil.ts","webpack://tcic-electron-sdk/external \"electron\"","webpack://tcic-electron-sdk/webpack/bootstrap","webpack://tcic-electron-sdk/webpack/startup"],"names":[],"mappings":"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","file":"boardRenderer.bundle.js","sourcesContent":["// This file is required by the board.html file and will\n// be executed in the renderer process for that window.\n// No Node.js APIs are available in this process because\n// `nodeIntegration` is turned off. Use `preload.js` to\n// selectively enable features needed in the rendering\n// process.\n\nimport { ipcRenderer } from 'electron';\nimport * as rendererUtil from './rendererUtil';\n// import { tcicSdkVersion } from './sentry'; // 用于初始化异常捕获，切勿删除\n\n// console.log('version', tcicSdkVersion);\n\nclass BoardRender {\n  public static TEduBoard: any = (window as any).TEduBoard;\n  public static teduBoard: any = null;\n  public static boardElement: any = null;\n  public static boardWrapElement: any = null;\n  public static screenWidth = 0;\n  public static screenHeight = 0;\n  public static callMethodCache: any = []; // 缓存白板初始化完成前的指令\n  public static isBoardReady = false;\n  public static setVisibleRect(bounds: any) {\n    if (bounds) {\n      if (BoardRender.screenHeight === 0 || BoardRender.screenWidth === 0) {\n        BoardRender.screenHeight = screen.height;\n        BoardRender.screenWidth = screen.width;\n        BoardRender.boardElement.style.width = `${screen.width}px`;\n        BoardRender.boardElement.style.height = `${screen.height}px`;\n      }\n      BoardRender.boardWrapElement.style.width = `${bounds.width}px`;\n      BoardRender.boardWrapElement.style.height = `${bounds.height}px`;\n      BoardRender.boardWrapElement.style.left = `${bounds.x}px`;\n      BoardRender.boardWrapElement.style.top = `${bounds.y}px`;\n      BoardRender.boardWrapElement.style.position = 'absolute';\n    } else {\n      BoardRender.boardWrapElement.removeAttribute('style');\n      BoardRender.boardElement.removeAttribute('style');\n    }\n  };\n  public static updateCursor() {\n    if (!BoardRender.teduBoard) return;\n    const toolType = BoardRender.teduBoard.getToolType();\n    const brushColor = BoardRender.teduBoard.getBrushColor();\n    if (toolType === BoardRender.TEduBoard.TEduBoardToolType.TEDU_BOARD_TOOL_TYPE_PEN) {\n      const cursorSvg = `<?xml version=\"1.0\" encoding=\"UTF-8\"?><svg width=\"40px\" height=\"40px\" viewBox=\"0 0 40 40\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\"><title>mouse_pen</title>\n              <g id=\"页面-1\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n                  <g id=\"光标及状态栏状态\" transform=\"translate(-89.000000, -268.000000)\">\n                      <g id=\"mouse_pen\" transform=\"translate(89.000000, 268.000000)\">\n                          <rect id=\"矩形\" x=\"0\" y=\"0\" width=\"40\" height=\"40\"></rect>\n                          <g id=\"编组-13\" transform=\"translate(8.000000, 3.000000)\" fill=\"${brushColor}\" stroke=\"#182E25\">\n                              <path d=\"M0.756984031,32.1383216 L3.68816089e-13,26.5292023 L17.8941729,7.81597009e-14 L24.5264735,4.47354323 L6.63230058,31.0027455 L0.756984031,32.1383216 Z\" id=\"形状结合\"></path>\n                          </g>\n                      </g>\n                  </g>\n              </g>\n          </svg>`;\n      const cursorBase64 = `data:image/svg+xml;charset=utf-8,${escape(cursorSvg)}`;\n      BoardRender.teduBoard.setCursorIcon(toolType, {\n        cursor: 'url',\n        url: cursorBase64,\n        offsetX: 10,\n        offsetY: 40,\n      });\n    } else if (toolType === BoardRender.TEduBoard.TEduBoardToolType.TEDU_BOARD_TOOL_TYPE_LINE) {\n      const cursorSvg = `<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n            <svg width=\"40px\" height=\"40px\" viewBox=\"0 0 40 40\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n                <title>mouse_line</title>\n                <g id=\"页面-1\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n                    <g id=\"光标及状态栏状态\" transform=\"translate(-785.000000, -272.000000)\">\n                        <g id=\"mouse_line\" transform=\"translate(785.000000, 272.000000)\">\n                            <g id=\"编组-3\">\n                                <rect id=\"矩形\" x=\"0\" y=\"0\" width=\"40\" height=\"40\"></rect>\n                                <g id=\"编组\" transform=\"translate(2.628157, 2.500000)\" fill=\"#000000\" stroke=\"#FFFFFF\">\n                                    <path d=\"M19.6574089,0 L19.657,15.5 L34.6259534,15.5 L34.6259534,19.5 L19.657,19.5 L19.6574089,35 L15.6574089,35 L15.657,19.5 L-1.13686838e-13,19.5 L-1.13686838e-13,15.5 L15.657,15.5 L15.6574089,0 L19.6574089,0 Z\" id=\"形状结合\"></path>\n                                </g>\n                            </g>\n                            <line x1=\"28.5\" y1=\"7.5\" x2=\"36.5\" y2=\"7.5\" id=\"直线-6\" stroke=\"${brushColor}\" stroke-width=\"2\" stroke-linecap=\"square\"></line>\n                        </g>\n                    </g>\n                </g>\n            </svg>`;\n      const cursorBase64 = `data:image/svg+xml;base64,${window.btoa(unescape(encodeURIComponent(cursorSvg)))}`;\n      BoardRender.teduBoard.setCursorIcon(toolType, {\n        cursor: 'url',\n        url: cursorBase64,\n        offsetX: 20,\n        offsetY: 20,\n      });\n    } else if (toolType === BoardRender.TEduBoard.TEduBoardToolType.TEDU_BOARD_TOOL_TYPE_RECT) {\n      const cursorSvg = `<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n  <svg width=\"40px\" height=\"40px\" viewBox=\"0 0 40 40\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n      <title>mouse_rectangle</title>\n      <g id=\"页面-1\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n          <g id=\"光标及状态栏状态\" transform=\"translate(-551.000000, -272.000000)\">\n              <g id=\"mouse_rectangle\" transform=\"translate(551.000000, 272.000000)\">\n                  <g id=\"编组-3\">\n                      <rect id=\"矩形\" x=\"0\" y=\"0\" width=\"40\" height=\"40\"></rect>\n                      <g id=\"编组\" transform=\"translate(2.628157, 2.500000)\" fill=\"#000000\" stroke=\"#FFFFFF\">\n                          <path d=\"M19.6574089,0 L19.657,15.5 L34.6259534,15.5 L34.6259534,19.5 L19.657,19.5 L19.6574089,35 L15.6574089,35 L15.657,19.5 L-1.13686838e-13,19.5 L-1.13686838e-13,15.5 L15.657,15.5 L15.6574089,0 L19.6574089,0 Z\" id=\"形状结合\"></path>\n                      </g>\n                  </g>\n                  <rect id=\"矩形\" stroke=\"${brushColor}\" stroke-width=\"2\" x=\"28\" y=\"3\" width=\"8\" height=\"8\"></rect>\n              </g>\n          </g>\n      </g>\n  </svg>`;\n      const cursorBase64 = `data:image/svg+xml;base64,${window.btoa(unescape(encodeURIComponent(cursorSvg)))}`;\n      BoardRender.teduBoard.setCursorIcon(toolType, {\n        cursor: 'url',\n        url: cursorBase64,\n        offsetX: 20,\n        offsetY: 20,\n      });\n      // 矩形也设置一下(当按住shift键的时候，工具会切换为矩形)\n      BoardRender.teduBoard.setCursorIcon(BoardRender.TEduBoard.TEduBoardToolType.TEDU_BOARD_TOOL_TYPE_SQUARE, {\n        cursor: 'url',\n        url: cursorBase64,\n        offsetX: 20,\n        offsetY: 20,\n      });\n    } else if (toolType === BoardRender.TEduBoard.TEduBoardToolType.TEDU_BOARD_TOOL_TYPE_OVAL) {\n      const cursorSvg = `<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n  <svg width=\"40px\" height=\"40px\" viewBox=\"0 0 40 40\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n      <title>mouse_circle</title>\n      <g id=\"页面-1\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n          <g id=\"光标及状态栏状态\" transform=\"translate(-323.000000, -272.000000)\">\n              <g id=\"mouse_circle\" transform=\"translate(323.000000, 272.000000)\">\n                  <g id=\"编组-3\">\n                      <rect id=\"矩形\" x=\"0\" y=\"0\" width=\"40\" height=\"40\"></rect>\n                      <g id=\"编组\" transform=\"translate(2.628157, 2.500000)\" fill=\"#000000\" stroke=\"#FFFFFF\">\n                          <path d=\"M19.6574089,0 L19.657,15.5 L34.6259534,15.5 L34.6259534,19.5 L19.657,19.5 L19.6574089,35 L15.6574089,35 L15.657,19.5 L-1.13686838e-13,19.5 L-1.13686838e-13,15.5 L15.657,15.5 L15.6574089,0 L19.6574089,0 Z\" id=\"形状结合\"></path>\n                      </g>\n                  </g>\n                  <circle id=\"椭圆形\" stroke=\"${brushColor}\" stroke-width=\"2\" cx=\"32\" cy=\"7\" r=\"4\"></circle>\n              </g>\n          </g>\n      </g>\n  </svg>`;\n      const cursorBase64 = `data:image/svg+xml;base64,${window.btoa(unescape(encodeURIComponent(cursorSvg)))}`;\n      BoardRender.teduBoard.setCursorIcon(toolType, {\n        cursor: 'url',\n        url: cursorBase64,\n        offsetX: 20,\n        offsetY: 20,\n      });\n      // 正圆也设置一下(当按住shift键的时候，工具会切换为正圆)\n      BoardRender.teduBoard.setCursorIcon(BoardRender.TEduBoard.TEduBoardToolType.TEDU_BOARD_TOOL_TYPE_CIRCLE, {\n        cursor: 'url',\n        url: cursorBase64,\n        offsetX: 20,\n        offsetY: 20,\n      });\n    }\n    BoardRender.teduBoard.setToolType(toolType);  // 马上再更新一下工具，保证光标生效（白板bug）\n  };\n\n  public static callBoardMethod(arg: any) {\n    console.log('callBoardMethod', BoardRender.teduBoard, JSON.stringify(arg));\n    if (BoardRender.teduBoard) {\n      // eslint-disable-next-line prefer-spread\n      BoardRender.teduBoard[arg.method].apply(BoardRender.teduBoard, arg.params);\n      BoardRender.updateCursor();\n      // if (arg.method === 'setToolType') {\n      //   const toolType = arg.params[0];\n      //   // 系统光标对阴影滤镜支持不好，激光笔渐变部分会出现黑色阴影，目前先将激光笔用模拟的方式来实现，其他工具继续使用系统光标(同时在touch设备下系统光标也不会出现)\n      //   if (toolType === BoardRender.teduBoard.TEduBoardToolType.TEDU_BOARD_TOOL_TYPE_LASER) {\n      //     BoardRender.teduBoard.setSystemCursorEnable(false);\n      //   } else {\n      //     BoardRender.teduBoard.setSystemCursorEnable(true);\n      //   }\n      // }\n    }\n  };\n};\n\n(window as any).BoardRender = BoardRender;\n\nipcRenderer.on('initBoard', (event: any, params: any) => {\n  const BoardRender = (window as any).BoardRender;\n  if (BoardRender.teduBoard) {\n    return;\n  }\n\n  const initParams = {\n    id: 'board', // dom节点id\n    sdkAppId: params.sdkAppId, // 整数\n    classId: params.roomId, // 课堂 ID，32位整型，取值范围[1, 4294967294]\n    userId: params.userId, // 字符串\n    userSig: params.userSig,\n    ratio: `${screen.width}:${screen.height}`,\n    systemCursorEnable: false,\n    enableLocalMode: true,\n    styleConfig: {\n      globalBackgroundColor: 'rgba(0, 0, 0, 0.01)',\n      textColor: '#ff0000',\n      selectBoxColor: '#727272',\n      cursorSize: [40, 40],\n      brushThin: 50,\n      selectAnchorColor: '#006eff',\n    },\n  };\n  BoardRender.teduBoard = new BoardRender.TEduBoard(initParams);\n\n  // 监听白板错误事件\n  BoardRender.teduBoard.on(BoardRender.TEduBoard.EVENT.TEB_ERROR, (code: number, msg: string) => {\n  });\n\n  // 监听白板告警事件\n  BoardRender.teduBoard.on(BoardRender.TEduBoard.EVENT.TEB_WARNING, (code: number, msg: string) => {\n  });\n\n  BoardRender.teduBoard.on(BoardRender.TEduBoard.EVENT.TEB_HISTROYDATA_SYNCCOMPLETED, () => {\n    // 默认使用鼠标工具\n    BoardRender.teduBoard.setToolType(BoardRender.TEduBoard.TEduBoardToolType.TEDU_BOARD_TOOL_TYPE_MOUSE);\n\n    // 启用笔锋特性\n    BoardRender.teduBoard.setHandwritingEnable(true);\n\n    // 设置橡皮擦自定义图标\n    BoardRender.teduBoard.setCursorIcon(BoardRender.TEduBoard.TEduBoardToolType.TEDU_BOARD_TOOL_TYPE_ERASER, {\n      cursor: 'url',\n      url: 'https://res.qcloudtiw.com/board/icons/xkt/eraser.svg',\n      offsetX: 7,\n      offsetY: 25,\n    });\n\n    BoardRender.updateCursor();\n\n    if (BoardRender.callMethodCache.length === 0) {\n      // 没有指令，则默认设置未鼠标工具\n      BoardRender.teduBoard.setToolType(0);\n    } else {\n      // 执行缓存指令\n      BoardRender.callMethodCache.forEach((arg: any) => {\n        BoardRender.callBoardMethod(arg);\n      });\n      BoardRender.callMethodCache = [];\n    }\n    BoardRender.isBoardReady = true;\n  });\n\n  // 监听事件，image为截图内容的base64数据\n  BoardRender.teduBoard.on(BoardRender.TEduBoard.EVENT.TEB_SNAPSHOT, (data: any) => {\n    ipcRenderer.send('onScreenShareSnapshot', data);\n  });\n\n  BoardRender.teduBoard.on(BoardRender.TEduBoard.EVENT.TEB_OPERATE_CANREDO_STATUS_CHANGED, (status: any) => {\n    ipcRenderer.send('onBoardCanRedoChange', status);\n  });\n\n  BoardRender.teduBoard.on(BoardRender.TEduBoard.EVENT.TEB_OPERATE_CANUNDO_STATUS_CHANGED, (status: any) => {\n    ipcRenderer.send('onBoardCanUndoChange', status);\n  });\n\n  BoardRender.setVisibleRect(params.shareWindowBounds);\n});\n\n\nipcRenderer.on('onShareWindowBoundsChanged', (event, bounds) => {\n  const BoardRender = (window as any).BoardRender;\n  BoardRender.setVisibleRect(bounds);\n});\n\nipcRenderer.on('callMethod', (event, arg) => {\n  const BoardRender = (window as any).BoardRender;\n  if (!BoardRender.isBoardReady) { // 白板为初始化完成，缓存白板指令\n    BoardRender.callMethodCache.push(arg);\n    return;\n  }\n  BoardRender.callBoardMethod(arg);\n});\n\nconst events = ['touchstart', 'touchend'];\nipcRenderer.on('enableWatchMouseMoveEvent', (event, enabled) => {\n  rendererUtil.watchEvents(document, events, enabled);\n});\n\nwindow.onload = () => {\n  BoardRender.boardWrapElement = document.getElementById('board-wrap');\n  BoardRender.boardElement = document.getElementById('board');\n};\n","import { ipcRenderer } from 'electron';\n\nfunction createMouseMoveProcessor() {\n  const lastX = 0;\n  const lastY = 0;\n  return (e: any) => {\n    let x; let y;\n    if (e instanceof TouchEvent) {  // 触摸事件\n      x = Math.round(e.changedTouches[0].screenX);\n      y = Math.round(e.changedTouches[0].screenY);\n    } else {  // 鼠标事件\n      x = e.screenX;\n      y = e.screenY;\n    }\n    if (x !== lastX || y !== lastY) {  // 只有位置发生变化时才发送消息，减少资源消耗\n      const args = { type: e.type, x, y };\n      ipcRenderer.send('onMouseEvent', args);\n      console.log('onMouseEvent', args);\n    }\n  };\n}\n\nconst eventProcessor = createMouseMoveProcessor();\n\nexport function watchEvents(target: EventTarget, events: string[], enabled: boolean) {\n  events.forEach((event) => {\n    if (enabled) {\n      target.addEventListener(event, eventProcessor, {\n        capture: true,\n        passive: false,\n      });\n    } else {\n      target.removeEventListener(event, eventProcessor, {\n        capture: true,\n      });\n    }\n  });\n}\n","module.exports = require(\"electron\");","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// startup\n// Load entry module and return exports\n// This entry module is referenced by other modules so it can't be inlined\nvar __webpack_exports__ = __webpack_require__(\"./src/boardRenderer.ts\");\n"],"sourceRoot":""}
1
+ (()=>{"use strict";var e={761:function(e,t,o){var r=this&&this.__createBinding||(Object.create?function(e,t,o,r){void 0===r&&(r=o),Object.defineProperty(e,r,{enumerable:!0,get:function(){return t[o]}})}:function(e,t,o,r){void 0===r&&(r=o),e[r]=t[o]}),n=this&&this.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),d=this&&this.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var o in e)"default"!==o&&Object.hasOwnProperty.call(e,o)&&r(t,e,o);return n(t,e),t};Object.defineProperty(t,"__esModule",{value:!0});const s=o(933),a=d(o(280));class i{static setVisibleRect(e){e?(0!==i.screenHeight&&0!==i.screenWidth||(i.screenHeight=screen.height,i.screenWidth=screen.width,i.boardElement.style.width=`${screen.width}px`,i.boardElement.style.height=`${screen.height}px`),i.boardWrapElement.style.width=`${e.width}px`,i.boardWrapElement.style.height=`${e.height}px`,i.boardWrapElement.style.left=`${e.x}px`,i.boardWrapElement.style.top=`${e.y}px`,i.boardWrapElement.style.position="absolute"):(i.boardWrapElement.removeAttribute("style"),i.boardElement.removeAttribute("style"))}static updateCursor(){if(!i.teduBoard)return;const e=i.teduBoard.getToolType(),t=i.teduBoard.getBrushColor();if(e===i.TEduBoard.TEduBoardToolType.TEDU_BOARD_TOOL_TYPE_PEN){const o=`data:image/svg+xml;charset=utf-8,${escape(`<?xml version="1.0" encoding="UTF-8"?><svg width="40px" height="40px" viewBox="0 0 40 40" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"><title>mouse_pen</title>\n <g id="页面-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">\n <g id="光标及状态栏状态" transform="translate(-89.000000, -268.000000)">\n <g id="mouse_pen" transform="translate(89.000000, 268.000000)">\n <rect id="矩形" x="0" y="0" width="40" height="40"></rect>\n <g id="编组-13" transform="translate(8.000000, 3.000000)" fill="${t}" stroke="#182E25">\n <path d="M0.756984031,32.1383216 L3.68816089e-13,26.5292023 L17.8941729,7.81597009e-14 L24.5264735,4.47354323 L6.63230058,31.0027455 L0.756984031,32.1383216 Z" id="形状结合"></path>\n </g>\n </g>\n </g>\n </g>\n </svg>`)}`;i.teduBoard.setCursorIcon(e,{cursor:"url",url:o,offsetX:10,offsetY:40})}else if(e===i.TEduBoard.TEduBoardToolType.TEDU_BOARD_TOOL_TYPE_LINE){const o=`<?xml version="1.0" encoding="UTF-8"?>\n <svg width="40px" height="40px" viewBox="0 0 40 40" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">\n <title>mouse_line</title>\n <g id="页面-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">\n <g id="光标及状态栏状态" transform="translate(-785.000000, -272.000000)">\n <g id="mouse_line" transform="translate(785.000000, 272.000000)">\n <g id="编组-3">\n <rect id="矩形" x="0" y="0" width="40" height="40"></rect>\n <g id="编组" transform="translate(2.628157, 2.500000)" fill="#000000" stroke="#FFFFFF">\n <path d="M19.6574089,0 L19.657,15.5 L34.6259534,15.5 L34.6259534,19.5 L19.657,19.5 L19.6574089,35 L15.6574089,35 L15.657,19.5 L-1.13686838e-13,19.5 L-1.13686838e-13,15.5 L15.657,15.5 L15.6574089,0 L19.6574089,0 Z" id="形状结合"></path>\n </g>\n </g>\n <line x1="28.5" y1="7.5" x2="36.5" y2="7.5" id="直线-6" stroke="${t}" stroke-width="2" stroke-linecap="square"></line>\n </g>\n </g>\n </g>\n </svg>`,r=`data:image/svg+xml;base64,${window.btoa(unescape(encodeURIComponent(o)))}`;i.teduBoard.setCursorIcon(e,{cursor:"url",url:r,offsetX:20,offsetY:20})}else if(e===i.TEduBoard.TEduBoardToolType.TEDU_BOARD_TOOL_TYPE_RECT){const o=`<?xml version="1.0" encoding="UTF-8"?>\n <svg width="40px" height="40px" viewBox="0 0 40 40" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">\n <title>mouse_rectangle</title>\n <g id="页面-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">\n <g id="光标及状态栏状态" transform="translate(-551.000000, -272.000000)">\n <g id="mouse_rectangle" transform="translate(551.000000, 272.000000)">\n <g id="编组-3">\n <rect id="矩形" x="0" y="0" width="40" height="40"></rect>\n <g id="编组" transform="translate(2.628157, 2.500000)" fill="#000000" stroke="#FFFFFF">\n <path d="M19.6574089,0 L19.657,15.5 L34.6259534,15.5 L34.6259534,19.5 L19.657,19.5 L19.6574089,35 L15.6574089,35 L15.657,19.5 L-1.13686838e-13,19.5 L-1.13686838e-13,15.5 L15.657,15.5 L15.6574089,0 L19.6574089,0 Z" id="形状结合"></path>\n </g>\n </g>\n <rect id="矩形" stroke="${t}" stroke-width="2" x="28" y="3" width="8" height="8"></rect>\n </g>\n </g>\n </g>\n </svg>`,r=`data:image/svg+xml;base64,${window.btoa(unescape(encodeURIComponent(o)))}`;i.teduBoard.setCursorIcon(e,{cursor:"url",url:r,offsetX:20,offsetY:20}),i.teduBoard.setCursorIcon(i.TEduBoard.TEduBoardToolType.TEDU_BOARD_TOOL_TYPE_SQUARE,{cursor:"url",url:r,offsetX:20,offsetY:20})}else if(e===i.TEduBoard.TEduBoardToolType.TEDU_BOARD_TOOL_TYPE_OVAL){const o=`<?xml version="1.0" encoding="UTF-8"?>\n <svg width="40px" height="40px" viewBox="0 0 40 40" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">\n <title>mouse_circle</title>\n <g id="页面-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">\n <g id="光标及状态栏状态" transform="translate(-323.000000, -272.000000)">\n <g id="mouse_circle" transform="translate(323.000000, 272.000000)">\n <g id="编组-3">\n <rect id="矩形" x="0" y="0" width="40" height="40"></rect>\n <g id="编组" transform="translate(2.628157, 2.500000)" fill="#000000" stroke="#FFFFFF">\n <path d="M19.6574089,0 L19.657,15.5 L34.6259534,15.5 L34.6259534,19.5 L19.657,19.5 L19.6574089,35 L15.6574089,35 L15.657,19.5 L-1.13686838e-13,19.5 L-1.13686838e-13,15.5 L15.657,15.5 L15.6574089,0 L19.6574089,0 Z" id="形状结合"></path>\n </g>\n </g>\n <circle id="椭圆形" stroke="${t}" stroke-width="2" cx="32" cy="7" r="4"></circle>\n </g>\n </g>\n </g>\n </svg>`,r=`data:image/svg+xml;base64,${window.btoa(unescape(encodeURIComponent(o)))}`;i.teduBoard.setCursorIcon(e,{cursor:"url",url:r,offsetX:20,offsetY:20}),i.teduBoard.setCursorIcon(i.TEduBoard.TEduBoardToolType.TEDU_BOARD_TOOL_TYPE_CIRCLE,{cursor:"url",url:r,offsetX:20,offsetY:20})}i.teduBoard.setToolType(e)}static callBoardMethod(e){console.log("callBoardMethod",i.teduBoard,JSON.stringify(e)),i.teduBoard&&(i.teduBoard[e.method].apply(i.teduBoard,e.params),i.updateCursor())}}i.TEduBoard=window.TEduBoard,i.teduBoard=null,i.boardElement=null,i.boardWrapElement=null,i.screenWidth=0,i.screenHeight=0,i.callMethodCache=[],i.isBoardReady=!1,window.BoardRender=i,s.ipcRenderer.on("initBoard",((e,t)=>{const o=window.BoardRender;if(o.teduBoard)return;const r={id:"board",sdkAppId:t.sdkAppId,classId:t.roomId,userId:t.userId,userSig:t.userSig,ratio:`${screen.width}:${screen.height}`,systemCursorEnable:!1,enableLocalMode:!0,styleConfig:{globalBackgroundColor:"rgba(0, 0, 0, 0.01)",textColor:"#ff0000",selectBoxColor:"#727272",cursorSize:[40,40],brushThin:50,selectAnchorColor:"#006eff"}};o.teduBoard=new o.TEduBoard(r),o.teduBoard.on(o.TEduBoard.EVENT.TEB_ERROR,((e,t)=>{})),o.teduBoard.on(o.TEduBoard.EVENT.TEB_WARNING,((e,t)=>{})),o.teduBoard.on(o.TEduBoard.EVENT.TEB_HISTROYDATA_SYNCCOMPLETED,(()=>{o.teduBoard.setToolType(o.TEduBoard.TEduBoardToolType.TEDU_BOARD_TOOL_TYPE_MOUSE),o.teduBoard.setHandwritingEnable(!0),o.teduBoard.setCursorIcon(o.TEduBoard.TEduBoardToolType.TEDU_BOARD_TOOL_TYPE_ERASER,{cursor:"url",url:"https://res.qcloudtiw.com/board/icons/xkt/eraser.svg",offsetX:7,offsetY:25}),o.updateCursor(),0===o.callMethodCache.length?o.teduBoard.setToolType(0):(o.callMethodCache.forEach((e=>{o.callBoardMethod(e)})),o.callMethodCache=[]),o.isBoardReady=!0})),o.teduBoard.on(o.TEduBoard.EVENT.TEB_SNAPSHOT,(e=>{s.ipcRenderer.send("onScreenShareSnapshot",e)})),o.teduBoard.on(o.TEduBoard.EVENT.TEB_OPERATE_CANREDO_STATUS_CHANGED,(e=>{s.ipcRenderer.send("onBoardCanRedoChange",e)})),o.teduBoard.on(o.TEduBoard.EVENT.TEB_OPERATE_CANUNDO_STATUS_CHANGED,(e=>{s.ipcRenderer.send("onBoardCanUndoChange",e)})),o.setVisibleRect(t.shareWindowBounds)})),s.ipcRenderer.on("onShareWindowBoundsChanged",((e,t)=>{window.BoardRender.setVisibleRect(t)})),s.ipcRenderer.on("callMethod",((e,t)=>{const o=window.BoardRender;o.isBoardReady?o.callBoardMethod(t):o.callMethodCache.push(t)}));const l=["touchstart","touchend"];s.ipcRenderer.on("enableWatchMouseMoveEvent",((e,t)=>{a.watchEvents(document,l,t)})),window.onload=()=>{i.boardWrapElement=document.getElementById("board-wrap"),i.boardElement=document.getElementById("board")}},280:(e,t,o)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.watchEvents=void 0;const r=o(933),n=e=>{let t,o;if(e instanceof TouchEvent?(t=Math.round(e.changedTouches[0].screenX),o=Math.round(e.changedTouches[0].screenY)):(t=e.screenX,o=e.screenY),0!==t||0!==o){const n={type:e.type,x:t,y:o};r.ipcRenderer.send("onMouseEvent",n),console.log("onMouseEvent",n)}};t.watchEvents=function(e,t,o){t.forEach((t=>{o?e.addEventListener(t,n,{capture:!0,passive:!1}):e.removeEventListener(t,n,{capture:!0})}))}},933:e=>{e.exports=require("electron")}},t={};!function o(r){var n=t[r];if(void 0!==n)return n.exports;var d=t[r]={exports:{}};return e[r].call(d.exports,d,d.exports,o),d.exports}(761)})();
@@ -1,112 +1 @@
1
- /******/ (() => { // webpackBootstrap
2
- /******/ "use strict";
3
- /******/ var __webpack_modules__ = ({
4
-
5
- /***/ "electron":
6
- /*!***************************!*\
7
- !*** external "electron" ***!
8
- \***************************/
9
- /***/ ((module) => {
10
-
11
- module.exports = require("electron");
12
-
13
- /***/ })
14
-
15
- /******/ });
16
- /************************************************************************/
17
- /******/ // The module cache
18
- /******/ var __webpack_module_cache__ = {};
19
- /******/
20
- /******/ // The require function
21
- /******/ function __webpack_require__(moduleId) {
22
- /******/ // Check if module is in cache
23
- /******/ var cachedModule = __webpack_module_cache__[moduleId];
24
- /******/ if (cachedModule !== undefined) {
25
- /******/ return cachedModule.exports;
26
- /******/ }
27
- /******/ // Create a new module (and put it into the cache)
28
- /******/ var module = __webpack_module_cache__[moduleId] = {
29
- /******/ // no module.id needed
30
- /******/ // no module.loaded needed
31
- /******/ exports: {}
32
- /******/ };
33
- /******/
34
- /******/ // Execute the module function
35
- /******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
36
- /******/
37
- /******/ // Return the exports of the module
38
- /******/ return module.exports;
39
- /******/ }
40
- /******/
41
- /************************************************************************/
42
- var __webpack_exports__ = {};
43
- // This entry need to be wrapped in an IIFE because it need to be isolated against other modules in the chunk.
44
- (() => {
45
- var exports = __webpack_exports__;
46
- /*!*******************************!*\
47
- !*** ./src/cameraRenderer.ts ***!
48
- \*******************************/
49
-
50
- Object.defineProperty(exports, "__esModule", ({ value: true }));
51
- const electron_1 = __webpack_require__(/*! electron */ "electron");
52
- class CameraController {
53
- constructor() {
54
- this._videoElement = document.getElementById('camera');
55
- this._videoElement.addEventListener('timeupdate', () => {
56
- });
57
- this._videoElement.addEventListener('durationchange', () => {
58
- });
59
- this._videoElement.addEventListener('seeked', () => {
60
- });
61
- this._videoElement.addEventListener('playing', () => {
62
- electron_1.ipcRenderer.send('playing', {
63
- width: this._params.width,
64
- height: this._params.height,
65
- });
66
- });
67
- }
68
- static get instance() {
69
- if (this._instance === null) {
70
- this._instance = new CameraController();
71
- }
72
- return this._instance;
73
- }
74
- start(params) {
75
- return new Promise((resolve, reject) => {
76
- this._params = params;
77
- navigator.mediaDevices.enumerateDevices()
78
- .then((devices) => {
79
- const cameraDevices = devices.filter(device => device.kind === 'videoinput');
80
- navigator.mediaDevices.getUserMedia({
81
- video: {
82
- deviceId: cameraDevices[params.deviceIndex].deviceId,
83
- aspectRatio: 1.7777777778,
84
- width: params.width,
85
- height: params.height,
86
- },
87
- audio: false,
88
- })
89
- .then((stream) => {
90
- this._videoElement.srcObject = stream;
91
- this._videoElement.play();
92
- })
93
- .catch((error) => {
94
- reject(error);
95
- });
96
- });
97
- });
98
- }
99
- stop() {
100
- this._videoElement.stop();
101
- }
102
- }
103
- CameraController._instance = null;
104
- electron_1.ipcRenderer.on('start', (event, params) => {
105
- CameraController.instance.start(params);
106
- });
107
-
108
- })();
109
-
110
- /******/ })()
111
- ;
112
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly90Y2ljLWVsZWN0cm9uLXNkay9leHRlcm5hbCBcImVsZWN0cm9uXCIiLCJ3ZWJwYWNrOi8vdGNpYy1lbGVjdHJvbi1zZGsvd2VicGFjay9ib290c3RyYXAiLCJ3ZWJwYWNrOi8vdGNpYy1lbGVjdHJvbi1zZGsvLi9zcmMvY2FtZXJhUmVuZGVyZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7OztBQUFBLHFDOzs7Ozs7VUNBQTtVQUNBOztVQUVBO1VBQ0E7VUFDQTtVQUNBO1VBQ0E7VUFDQTtVQUNBO1VBQ0E7VUFDQTtVQUNBO1VBQ0E7VUFDQTtVQUNBOztVQUVBO1VBQ0E7O1VBRUE7VUFDQTtVQUNBOzs7Ozs7Ozs7Ozs7QUN0QkEsbUVBQXVDO0FBRXZDLE1BQU0sZ0JBQWdCO0lBVXBCO1FBQ0UsSUFBSSxDQUFDLGFBQWEsR0FBRyxRQUFRLENBQUMsY0FBYyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBQ3ZELElBQUksQ0FBQyxhQUFhLENBQUMsZ0JBQWdCLENBQUMsWUFBWSxFQUFFLEdBQUcsRUFBRTtRQUN2RCxDQUFDLENBQUMsQ0FBQztRQUNILElBQUksQ0FBQyxhQUFhLENBQUMsZ0JBQWdCLENBQUMsZ0JBQWdCLEVBQUUsR0FBRyxFQUFFO1FBQzNELENBQUMsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxDQUFDLGFBQWEsQ0FBQyxnQkFBZ0IsQ0FBQyxRQUFRLEVBQUUsR0FBRyxFQUFFO1FBQ25ELENBQUMsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxDQUFDLGFBQWEsQ0FBQyxnQkFBZ0IsQ0FBQyxTQUFTLEVBQUUsR0FBRyxFQUFFO1lBQ2xELHNCQUFXLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRTtnQkFDMUIsS0FBSyxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSztnQkFDekIsTUFBTSxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsTUFBTTthQUM1QixDQUFDLENBQUM7UUFDTCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUF2Qk0sTUFBTSxLQUFLLFFBQVE7UUFDeEIsSUFBSSxJQUFJLENBQUMsU0FBUyxLQUFLLElBQUksRUFBRTtZQUMzQixJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksZ0JBQWdCLEVBQUUsQ0FBQztTQUN6QztRQUNELE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQztJQUN4QixDQUFDO0lBbUJNLEtBQUssQ0FBQyxNQUFXO1FBQ3RCLE9BQU8sSUFBSSxPQUFPLENBQUMsQ0FBQyxPQUFPLEVBQUUsTUFBTSxFQUFFLEVBQUU7WUFDckMsSUFBSSxDQUFDLE9BQU8sR0FBRyxNQUFNLENBQUM7WUFDdEIsU0FBUyxDQUFDLFlBQVksQ0FBQyxnQkFBZ0IsRUFBRTtpQkFDdEMsSUFBSSxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUU7Z0JBQ2hCLE1BQU0sYUFBYSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxNQUFNLENBQUMsSUFBSSxLQUFLLFlBQVksQ0FBQyxDQUFDO2dCQUM3RSxTQUFTLENBQUMsWUFBWSxDQUFDLFlBQVksQ0FBQztvQkFDbEMsS0FBSyxFQUFFO3dCQUNMLFFBQVEsRUFBRSxhQUFhLENBQUMsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDLFFBQVE7d0JBQ3BELFdBQVcsRUFBRSxZQUFZO3dCQUN6QixLQUFLLEVBQUUsTUFBTSxDQUFDLEtBQUs7d0JBQ25CLE1BQU0sRUFBRSxNQUFNLENBQUMsTUFBTTtxQkFDdEI7b0JBQ0QsS0FBSyxFQUFFLEtBQUs7aUJBQ2IsQ0FBQztxQkFDQyxJQUFJLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBRTtvQkFDZixJQUFJLENBQUMsYUFBYSxDQUFDLFNBQVMsR0FBRyxNQUFNLENBQUM7b0JBQ3RDLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLENBQUM7Z0JBQzVCLENBQUMsQ0FBQztxQkFDRCxLQUFLLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRTtvQkFDZixNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7Z0JBQ2hCLENBQUMsQ0FBQyxDQUFDO1lBQ1AsQ0FBQyxDQUFDLENBQUM7UUFDUCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFDTSxJQUFJO1FBQ1QsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUM1QixDQUFDOztBQTdDYywwQkFBUyxHQUFxQixJQUFJLENBQUM7QUFnRHBELHNCQUFXLENBQUMsRUFBRSxDQUFDLE9BQU8sRUFBRSxDQUFDLEtBQUssRUFBRSxNQUFNLEVBQUUsRUFBRTtJQUN4QyxnQkFBZ0IsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0FBQzFDLENBQUMsQ0FBQyxDQUFDIiwiZmlsZSI6ImNhbWVyYVJlbmRlcmVyLmJ1bmRsZS5qcyIsInNvdXJjZXNDb250ZW50IjpbIm1vZHVsZS5leHBvcnRzID0gcmVxdWlyZShcImVsZWN0cm9uXCIpOyIsIi8vIFRoZSBtb2R1bGUgY2FjaGVcbnZhciBfX3dlYnBhY2tfbW9kdWxlX2NhY2hlX18gPSB7fTtcblxuLy8gVGhlIHJlcXVpcmUgZnVuY3Rpb25cbmZ1bmN0aW9uIF9fd2VicGFja19yZXF1aXJlX18obW9kdWxlSWQpIHtcblx0Ly8gQ2hlY2sgaWYgbW9kdWxlIGlzIGluIGNhY2hlXG5cdHZhciBjYWNoZWRNb2R1bGUgPSBfX3dlYnBhY2tfbW9kdWxlX2NhY2hlX19bbW9kdWxlSWRdO1xuXHRpZiAoY2FjaGVkTW9kdWxlICE9PSB1bmRlZmluZWQpIHtcblx0XHRyZXR1cm4gY2FjaGVkTW9kdWxlLmV4cG9ydHM7XG5cdH1cblx0Ly8gQ3JlYXRlIGEgbmV3IG1vZHVsZSAoYW5kIHB1dCBpdCBpbnRvIHRoZSBjYWNoZSlcblx0dmFyIG1vZHVsZSA9IF9fd2VicGFja19tb2R1bGVfY2FjaGVfX1ttb2R1bGVJZF0gPSB7XG5cdFx0Ly8gbm8gbW9kdWxlLmlkIG5lZWRlZFxuXHRcdC8vIG5vIG1vZHVsZS5sb2FkZWQgbmVlZGVkXG5cdFx0ZXhwb3J0czoge31cblx0fTtcblxuXHQvLyBFeGVjdXRlIHRoZSBtb2R1bGUgZnVuY3Rpb25cblx0X193ZWJwYWNrX21vZHVsZXNfX1ttb2R1bGVJZF0obW9kdWxlLCBtb2R1bGUuZXhwb3J0cywgX193ZWJwYWNrX3JlcXVpcmVfXyk7XG5cblx0Ly8gUmV0dXJuIHRoZSBleHBvcnRzIG9mIHRoZSBtb2R1bGVcblx0cmV0dXJuIG1vZHVsZS5leHBvcnRzO1xufVxuXG4iLCJpbXBvcnQgeyBpcGNSZW5kZXJlciB9IGZyb20gJ2VsZWN0cm9uJztcblxuY2xhc3MgQ2FtZXJhQ29udHJvbGxlciB7XG4gIHB1YmxpYyBzdGF0aWMgZ2V0IGluc3RhbmNlKCk6IENhbWVyYUNvbnRyb2xsZXIge1xuICAgIGlmICh0aGlzLl9pbnN0YW5jZSA9PT0gbnVsbCkge1xuICAgICAgdGhpcy5faW5zdGFuY2UgPSBuZXcgQ2FtZXJhQ29udHJvbGxlcigpO1xuICAgIH1cbiAgICByZXR1cm4gdGhpcy5faW5zdGFuY2U7XG4gIH1cbiAgcHJpdmF0ZSBzdGF0aWMgX2luc3RhbmNlOiBDYW1lcmFDb250cm9sbGVyID0gbnVsbDtcbiAgcHJpdmF0ZSBfdmlkZW9FbGVtZW50OiBhbnk7XG4gIHByaXZhdGUgX3BhcmFtczogYW55O1xuICBwdWJsaWMgY29uc3RydWN0b3IoKSB7XG4gICAgdGhpcy5fdmlkZW9FbGVtZW50ID0gZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoJ2NhbWVyYScpO1xuICAgIHRoaXMuX3ZpZGVvRWxlbWVudC5hZGRFdmVudExpc3RlbmVyKCd0aW1ldXBkYXRlJywgKCkgPT4ge1xuICAgIH0pO1xuICAgIHRoaXMuX3ZpZGVvRWxlbWVudC5hZGRFdmVudExpc3RlbmVyKCdkdXJhdGlvbmNoYW5nZScsICgpID0+IHtcbiAgICB9KTtcbiAgICB0aGlzLl92aWRlb0VsZW1lbnQuYWRkRXZlbnRMaXN0ZW5lcignc2Vla2VkJywgKCkgPT4ge1xuICAgIH0pO1xuICAgIHRoaXMuX3ZpZGVvRWxlbWVudC5hZGRFdmVudExpc3RlbmVyKCdwbGF5aW5nJywgKCkgPT4ge1xuICAgICAgaXBjUmVuZGVyZXIuc2VuZCgncGxheWluZycsIHtcbiAgICAgICAgd2lkdGg6IHRoaXMuX3BhcmFtcy53aWR0aCxcbiAgICAgICAgaGVpZ2h0OiB0aGlzLl9wYXJhbXMuaGVpZ2h0LFxuICAgICAgfSk7XG4gICAgfSk7XG4gIH1cbiAgcHVibGljIHN0YXJ0KHBhcmFtczogYW55KSB7XG4gICAgcmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICAgIHRoaXMuX3BhcmFtcyA9IHBhcmFtcztcbiAgICAgIG5hdmlnYXRvci5tZWRpYURldmljZXMuZW51bWVyYXRlRGV2aWNlcygpXG4gICAgICAgIC50aGVuKChkZXZpY2VzKSA9PiB7XG4gICAgICAgICAgY29uc3QgY2FtZXJhRGV2aWNlcyA9IGRldmljZXMuZmlsdGVyKGRldmljZSA9PiBkZXZpY2Uua2luZCA9PT0gJ3ZpZGVvaW5wdXQnKTtcbiAgICAgICAgICBuYXZpZ2F0b3IubWVkaWFEZXZpY2VzLmdldFVzZXJNZWRpYSh7XG4gICAgICAgICAgICB2aWRlbzoge1xuICAgICAgICAgICAgICBkZXZpY2VJZDogY2FtZXJhRGV2aWNlc1twYXJhbXMuZGV2aWNlSW5kZXhdLmRldmljZUlkLFxuICAgICAgICAgICAgICBhc3BlY3RSYXRpbzogMS43Nzc3Nzc3Nzc4LFxuICAgICAgICAgICAgICB3aWR0aDogcGFyYW1zLndpZHRoLFxuICAgICAgICAgICAgICBoZWlnaHQ6IHBhcmFtcy5oZWlnaHQsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgYXVkaW86IGZhbHNlLFxuICAgICAgICAgIH0pXG4gICAgICAgICAgICAudGhlbigoc3RyZWFtKSA9PiB7XG4gICAgICAgICAgICAgIHRoaXMuX3ZpZGVvRWxlbWVudC5zcmNPYmplY3QgPSBzdHJlYW07XG4gICAgICAgICAgICAgIHRoaXMuX3ZpZGVvRWxlbWVudC5wbGF5KCk7XG4gICAgICAgICAgICB9KVxuICAgICAgICAgICAgLmNhdGNoKChlcnJvcikgPT4ge1xuICAgICAgICAgICAgICByZWplY3QoZXJyb3IpO1xuICAgICAgICAgICAgfSk7XG4gICAgICAgIH0pO1xuICAgIH0pO1xuICB9XG4gIHB1YmxpYyBzdG9wKCkge1xuICAgIHRoaXMuX3ZpZGVvRWxlbWVudC5zdG9wKCk7XG4gIH1cbn1cblxuaXBjUmVuZGVyZXIub24oJ3N0YXJ0JywgKGV2ZW50LCBwYXJhbXMpID0+IHtcbiAgQ2FtZXJhQ29udHJvbGxlci5pbnN0YW5jZS5zdGFydChwYXJhbXMpO1xufSk7XG4iXSwic291cmNlUm9vdCI6IiJ9
1
+ (()=>{"use strict";var e={933:e=>{e.exports=require("electron")}},t={};function i(n){var s=t[n];if(void 0!==s)return s.exports;var r=t[n]={exports:{}};return e[n](r,r.exports,i),r.exports}(()=>{const e=i(933);class t{constructor(){this._videoElement=document.getElementById("camera"),this._videoElement.addEventListener("timeupdate",(()=>{})),this._videoElement.addEventListener("durationchange",(()=>{})),this._videoElement.addEventListener("seeked",(()=>{})),this._videoElement.addEventListener("playing",(()=>{e.ipcRenderer.send("playing",{width:this._params.width,height:this._params.height})}))}static get instance(){return null===this._instance&&(this._instance=new t),this._instance}start(e){return new Promise(((t,i)=>{this._params=e,navigator.mediaDevices.enumerateDevices().then((t=>{const n=t.filter((e=>"videoinput"===e.kind));navigator.mediaDevices.getUserMedia({video:{deviceId:n[e.deviceIndex].deviceId,aspectRatio:1.7777777778,width:e.width,height:e.height},audio:!1}).then((e=>{this._videoElement.srcObject=e,this._videoElement.play()})).catch((e=>{i(e)}))}))}))}stop(){this._videoElement.stop()}}t._instance=null,e.ipcRenderer.on("start",((e,i)=>{t.instance.start(i)}))})()})();
package/dist/config.json CHANGED
@@ -1,10 +1,10 @@
1
1
  {
2
2
  "resources": [
3
3
  {
4
- "version": "dc315e8af8eec26e1135b77b545a8a7586b911d5",
4
+ "version": "756187788c31c589c15e4c40bc1f2b601d09e7dc",
5
5
  "sdkAppId": "0",
6
6
  "schoolId": "0",
7
- "url": "https://class.qcloudclass.com/1.5.0/cache/offline_dc315e8af8eec26e1135b77b545a8a7586b911d5.zip",
7
+ "url": "https://class.qcloudclass.com/1.5.0/cache/offline_756187788c31c589c15e4c40bc1f2b601d09e7dc.zip",
8
8
  "files": {
9
9
  },
10
10
  "regexes": {
@@ -25,7 +25,7 @@
25
25
  "supportFomats": "mp4|rmvb|avi|mov|flv|wmv|m3u8|mpeg|mp3|wav|pcm|aac|ogg"
26
26
  },
27
27
  "expired": 200,
28
- "devBuildTime": 1638533502,
28
+ "devBuildTime": 1639550920,
29
29
  "domains": {
30
30
  "www.xxx.com": [
31
31
  "www.aaa.com"