@cloud-app-dev/vidc 3.0.11 → 3.0.12

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.
@@ -142,7 +142,7 @@ export function FrontendPlayerWithExt(_ref) {
142
142
  return;
143
143
  }
144
144
 
145
- var endTime = moment(segments[segments.length - 1].endTime).unix();
145
+ var endTime = moment().unix();
146
146
  var beginTime = moment(time).unix();
147
147
  var videoUrl = new URL(state.url);
148
148
  videoUrl.searchParams.set('begin', "".concat(beginTime));
@@ -152,7 +152,7 @@ export function FrontendPlayerWithExt(_ref) {
152
152
  url: videoUrl.toString()
153
153
  });
154
154
  });
155
- }, [segments, state.url]);
155
+ }, [state.url]);
156
156
  var ref = useRef();
157
157
  var update = useCallback(function () {
158
158
  return updatePlayer(ref);
@@ -413,7 +413,7 @@ function RecordPlayer(_ref) {
413
413
  }), /*#__PURE__*/React.createElement(SegmentTimeLine, {
414
414
  begin: timeBegin,
415
415
  updateState: updateState,
416
- timeCell: segmentItem.segments,
416
+ segments: segmentItem.segments,
417
417
  key: state.selectIndex,
418
418
  onTimeChange: onTimeChange,
419
419
  timeMode: state.timeMode
@@ -2,12 +2,12 @@
2
2
  import { ISegmentType } from '../Player/player';
3
3
  interface ISegmentTimeLineProps {
4
4
  begin?: number;
5
- timeCell?: ISegmentType[];
5
+ segments?: ISegmentType[];
6
6
  onTimeChange?: (time: number) => void;
7
7
  timeMode: number;
8
8
  updateState: (state: {
9
9
  timeMode: number;
10
10
  }) => void;
11
11
  }
12
- declare function SegmentTimeLine({ begin, timeCell, onTimeChange, timeMode, updateState }: ISegmentTimeLineProps): JSX.Element;
12
+ declare function SegmentTimeLine({ begin, segments, onTimeChange, timeMode, updateState }: ISegmentTimeLineProps): JSX.Element;
13
13
  export default SegmentTimeLine;
@@ -1,59 +1,40 @@
1
- import _useUnmount from "ahooks/es/useUnmount";
2
- import _useUpdateEffect from "ahooks/es/useUpdateEffect";
3
1
  import _useThrottleFn2 from "ahooks/es/useThrottleFn";
4
- import _useSize from "ahooks/es/useSize";
5
2
  import moment from 'moment';
6
- import React, { useEffect, useRef } from 'react';
7
- import TimeSlider from './TimeSlider';
3
+ import React, { useMemo, useRef } from 'react';
4
+ import useTimeSlider from './useTimeSlider';
8
5
 
9
6
  function SegmentTimeLine(_ref) {
10
7
  var begin = _ref.begin,
11
- timeCell = _ref.timeCell,
8
+ segments = _ref.segments,
12
9
  onTimeChange = _ref.onTimeChange,
13
10
  timeMode = _ref.timeMode,
14
11
  updateState = _ref.updateState;
15
12
  var ref = useRef();
16
- var timeSliderRef = useRef();
17
-
18
- var size = _useSize(ref);
19
13
 
20
14
  var _useThrottleFn = _useThrottleFn2(onTimeChange, {
21
15
  wait: 300
22
16
  }),
23
17
  run = _useThrottleFn.run;
24
18
 
25
- useEffect(function () {
26
- var time = begin !== null && begin !== void 0 ? begin : moment().set({
19
+ var time = useMemo(function () {
20
+ return begin !== null && begin !== void 0 ? begin : moment().set({
27
21
  hours: 0,
28
22
  minutes: 0,
29
23
  seconds: 0
30
24
  }).valueOf();
31
- timeSliderRef.current = new TimeSlider(ref.current, {
32
- onTimeChange: run,
33
- start_timestamp: time - timeMode / 2 * 3600 * 1000,
34
- current_timestamp: time,
35
- timecell: timeCell,
36
- hours_per_ruler: timeMode,
37
- onHoursPerChange: function onHoursPerChange(hour) {
38
- return updateState({
39
- timeMode: hour
40
- });
41
- }
42
- });
43
- }, [begin, timeCell, size === null || size === void 0 ? void 0 : size.width, run]);
44
- /**
45
- * hour变化更新时间轴而不是重绘
46
- */
47
-
48
- _useUpdateEffect(function () {
49
- return timeSliderRef.current.drawHourChange(timeMode);
50
- }, [timeMode]);
51
-
52
- _useUnmount(function () {
53
- timeSliderRef.current.destory();
54
- timeSliderRef.current = null;
25
+ }, [begin]);
26
+ useTimeSlider(ref, {
27
+ begin: time - timeMode / 2 * 3600 * 1000,
28
+ currentTime: time,
29
+ onTimeChange: run,
30
+ segments: segments,
31
+ hoursPer: timeMode,
32
+ onHoursPerChange: function onHoursPerChange(hour) {
33
+ return updateState({
34
+ timeMode: hour
35
+ });
36
+ }
55
37
  });
56
-
57
38
  return /*#__PURE__*/React.createElement("div", {
58
39
  className: "record-time-line"
59
40
  }, /*#__PURE__*/React.createElement("canvas", {
@@ -91,11 +91,11 @@ export default class TimeSlider {
91
91
  */
92
92
  mousemoveFunc2: (e: MouseEvent) => void;
93
93
  /**
94
- * 拖动/点击 mouseup事件
94
+ * 点击 mouseup事件
95
95
  */
96
96
  mouseupFunc: (e: MouseEvent) => void;
97
97
  /**
98
- * 拖动/点击 mouseup事件
98
+ * 拖动停止 mouseup事件
99
99
  */
100
100
  mouseupFunc2: () => void;
101
101
  /**
@@ -48,8 +48,9 @@ var TimeSlider = /*#__PURE__*/function () {
48
48
  _this.g_isMousedown = true;
49
49
  _this.g_mousedownCursor = _this.get_cursor_x_position(e); //记住mousedown的位置
50
50
 
51
- document.addEventListener('mousemove', _this.mousemoveFunc);
52
- document.addEventListener('mouseup', _this.mouseupFunc2);
51
+ document.addEventListener('mousemove', _this.mousemoveFunc); //拖动
52
+
53
+ document.addEventListener('mouseup', _this.mouseupFunc2); //停止拖动
53
54
  };
54
55
  /**
55
56
  * 鼠标移出隐藏时间 mouseout事件
@@ -112,16 +113,12 @@ var TimeSlider = /*#__PURE__*/function () {
112
113
  }
113
114
  };
114
115
  /**
115
- * 拖动/点击 mouseup事件
116
+ * 点击 mouseup事件
116
117
  */
117
118
 
118
119
 
119
120
  this.mouseupFunc = function (e) {
120
- if (_this.g_isMousemove) {
121
- //拖动 事件
122
- _this.g_isMousemove = false;
123
- _this.g_isMousedown = false; // this.returnTime = this.start_timestamp + (this.hours_per_ruler * 3600 * 1000) / 2;
124
- } else {
121
+ if (!_this.g_isMousemove) {
125
122
  // click 事件
126
123
  _this.g_isMousedown = false;
127
124
 
@@ -144,11 +141,9 @@ var TimeSlider = /*#__PURE__*/function () {
144
141
 
145
142
  _this.options.onTimeChange && _this.options.onTimeChange(current_timestamp, outTimeline);
146
143
  }
147
-
148
- document.removeEventListener('mousemove', _this.mousemoveFunc);
149
144
  };
150
145
  /**
151
- * 拖动/点击 mouseup事件
146
+ * 拖动停止 mouseup事件
152
147
  */
153
148
 
154
149
 
@@ -466,10 +461,14 @@ var TimeSlider = /*#__PURE__*/function () {
466
461
  }, {
467
462
  key: "add_events",
468
463
  value: function add_events() {
469
- this.canvas.addEventListener('mousewheel', this.mousewheelFunc);
470
- this.canvas.addEventListener('mousedown', this.mousedownFunc);
471
- this.canvas.addEventListener('mousemove', this.mousemoveFunc2);
472
- this.canvas.addEventListener('mouseup', this.mouseupFunc);
464
+ this.canvas.addEventListener('mousewheel', this.mousewheelFunc); // 调整刻度范围
465
+
466
+ this.canvas.addEventListener('mousedown', this.mousedownFunc); // 触发 拖动或者点击标记
467
+
468
+ this.canvas.addEventListener('mousemove', this.mousemoveFunc2); //hover 提示当前刻度时间
469
+
470
+ this.canvas.addEventListener('mouseup', this.mouseupFunc); // 点击触发
471
+
473
472
  this.canvas.addEventListener('mouseout', this.mouseoutFunc);
474
473
  }
475
474
  }, {
@@ -484,6 +483,7 @@ var TimeSlider = /*#__PURE__*/function () {
484
483
  }, {
485
484
  key: "destory",
486
485
  value: function destory() {
486
+ this.clearCanvas();
487
487
  this.remove_events();
488
488
  this.canvas = null;
489
489
  this.options = null;
@@ -3,16 +3,16 @@ import _ConfigProvider from "antd/lib/config-provider";
3
3
  import React from 'react';
4
4
  import LivePlayer from './Live';
5
5
  var list = [{
6
- url: 'https://6a75ef90-3-server.antelopecloud.cn/flv_live?app=live&token=542446023_3356491776_1693469173_b34efba891f35a66b227642f66272534',
6
+ url: 'https://6a75ef90-3-server.antelopecloud.cn/flv_live?app=live&token=542446023_3356491776_1693558509_61374ba6efe326a4cb8b6bae86917a25',
7
7
  type: 'flv'
8
8
  }, {
9
- url: 'https://6a75ef90-3-server.antelopecloud.cn/flv_live?app=live&token=542446023_3356491776_1693469173_b34efba891f35a66b227642f66272534',
9
+ url: 'https://6a75ef89-1-server.antelopecloud.cn/flv_live?app=live&token=542446501_3356491776_1693535295_37062417b87df4be7dd5c02b01d87248',
10
10
  type: 'flv'
11
11
  }, {
12
12
  url: 'https://6a75ef90-1-server.antelopecloud.cn/flv_live?app=live&token=542453821_3356491776_1693535323_3a90f54c141b9a246d5679678ebafe90',
13
13
  type: 'flv'
14
14
  }, {
15
- url: 'https://6a75ef88-6-server.antelopecloud.cn/flv_live?app=live&token=542449206_3356491776_1693535342_803846974f04eb02e8115d10432d062f',
15
+ url: 'https://6a75ef90-6-server.antelopecloud.cn/flv_live?app=live&token=542449206_3356491776_1693535342_803846974f04eb02e8115d10432d062f',
16
16
  type: 'flv'
17
17
  }];
18
18
  export default function App() {
@@ -0,0 +1,22 @@
1
+ /// <reference types="react" />
2
+ import type { ISegmentType } from '../Player/player';
3
+ export interface ITimeSliderOptions {
4
+ hoursPer?: number;
5
+ begin?: number;
6
+ segments?: TimeCellItem[];
7
+ currentTime?: number;
8
+ onTimeChange?: (time: number, outTimeline?: boolean) => void;
9
+ onHoursPerChange?: (hour: number) => void;
10
+ }
11
+ export declare type ITimeSliderState = {
12
+ hoursPer: number;
13
+ begin: number;
14
+ currentTime: number;
15
+ hover: {
16
+ x: number;
17
+ time: number;
18
+ };
19
+ };
20
+ export declare type TimeCellItem = ISegmentType;
21
+ declare function useTimeSlider(canvasRef: React.MutableRefObject<HTMLCanvasElement>, { hoursPer, begin, currentTime, segments, onTimeChange, onHoursPerChange }: ITimeSliderOptions): void;
22
+ export default useTimeSlider;
@@ -0,0 +1,485 @@
1
+ import _nextTick from "@cloud-app-dev/utils/es/nextTick";
2
+ import _useEventListener from "ahooks/es/useEventListener";
3
+ import _useUpdateEffect from "ahooks/es/useUpdateEffect";
4
+ import _useSize from "ahooks/es/useSize";
5
+
6
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
7
+
8
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
9
+
10
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
11
+
12
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
13
+
14
+ function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
15
+
16
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
17
+
18
+ import moment from 'moment';
19
+ import { useCallback, useEffect, useMemo, useRef, useState } from 'react';
20
+ var hours = [1, 6, 12, 24];
21
+ var currentColor = '#FF000A';
22
+ var normalLineColor = '#ffffff';
23
+ var hoverLineColor = '#319BFF';
24
+ var minPerStep = [1, 2, 5, 10, 15, 20, 30, 60, 120, 180, 240, 360, 720, 1440];
25
+ var minStepSize = 20;
26
+ var distance_between_gtitle = 80;
27
+ /**
28
+ * 下一个刻度
29
+ */
30
+
31
+ function ms_to_next_step(timestamp, step) {
32
+ var remainder = timestamp % step;
33
+ return remainder ? step - remainder : 0;
34
+ }
35
+ /**
36
+ * 返回 2018-01-01 10:00:00 格式时间
37
+ * @param {*} time
38
+ */
39
+
40
+
41
+ function formartTimestemp(time) {
42
+ return moment(time).format('YYYY-MM-DD HH:mm:ss');
43
+ }
44
+ /**
45
+ * 返回时间轴上刻度的时间
46
+ * @param {*} datetime new Date 格式
47
+ */
48
+
49
+
50
+ function graduation_title(datetime) {
51
+ var mom = moment(datetime);
52
+ var h = mom.get('hours');
53
+ var m = mom.get('minutes');
54
+ var s = mom.get('seconds');
55
+
56
+ if (h === 0 && m === 0 && s === 0) {
57
+ return mom.format('YYYY.MM.DD');
58
+ }
59
+
60
+ return mom.format('HH:mm');
61
+ }
62
+ /**
63
+ * 绘制线条
64
+ */
65
+
66
+
67
+ function drawLine(ctx, beginX, beginY, endX, endY, color, width) {
68
+ ctx.beginPath();
69
+ ctx.moveTo(beginX, beginY);
70
+ ctx.lineTo(endX, endY);
71
+ ctx.strokeStyle = color;
72
+ ctx.lineWidth = width;
73
+ ctx.stroke();
74
+ }
75
+
76
+ function drawText(ctx, _ref) {
77
+ var fillStyle = _ref.fillStyle,
78
+ font = _ref.font,
79
+ text = _ref.text,
80
+ x = _ref.x,
81
+ y = _ref.y;
82
+ ctx.fillStyle = fillStyle;
83
+ ctx.font = font;
84
+ ctx.fillText(text, x, y);
85
+ }
86
+
87
+ function useTimeSlider(canvasRef, _ref2) {
88
+ var hoursPer = _ref2.hoursPer,
89
+ begin = _ref2.begin,
90
+ currentTime = _ref2.currentTime,
91
+ _ref2$segments = _ref2.segments,
92
+ segments = _ref2$segments === void 0 ? [] : _ref2$segments,
93
+ onTimeChange = _ref2.onTimeChange,
94
+ onHoursPerChange = _ref2.onHoursPerChange;
95
+
96
+ var _useState = useState({
97
+ hoursPer: hoursPer,
98
+ begin: begin,
99
+ currentTime: currentTime,
100
+ hover: {
101
+ x: 0,
102
+ time: null
103
+ }
104
+ }),
105
+ _useState2 = _slicedToArray(_useState, 2),
106
+ state = _useState2[0],
107
+ setState = _useState2[1];
108
+
109
+ var extRef = useRef({
110
+ mousedownTime: null,
111
+ mousedownX: 0
112
+ });
113
+
114
+ var size = _useSize(canvasRef);
115
+
116
+ var canvas = canvasRef.current;
117
+
118
+ var _useMemo = useMemo(function () {
119
+ return size ? size : {
120
+ width: 0,
121
+ height: 0
122
+ };
123
+ }, [size]),
124
+ width = _useMemo.width,
125
+ height = _useMemo.height;
126
+
127
+ var ctx = canvas === null || canvas === void 0 ? void 0 : canvas.getContext('2d');
128
+
129
+ var update = function update() {
130
+ var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
131
+ return setState(function (old) {
132
+ return Object.assign(Object.assign({}, old), params);
133
+ });
134
+ };
135
+
136
+ var clearCanvas = useCallback(function () {
137
+ return ctx.clearRect(0, 0, width, height);
138
+ }, [ctx, width, height]);
139
+ var drawOverlay = useCallback(function () {
140
+ segments.forEach(function (item) {
141
+ var _a;
142
+
143
+ var px_ms = width / (state.hoursPer * 60 * 60 * 1000); // px/ms
144
+
145
+ var beginX = (item.beginTime - state.begin) * px_ms;
146
+ var scale_width = (item.endTime - item.beginTime) * px_ms;
147
+ ctx.fillStyle = item.url ? ((_a = item.style) === null || _a === void 0 ? void 0 : _a.background) || hoverLineColor : '#242C3D';
148
+ ctx.fillRect(beginX, height - 10, scale_width + 1, height);
149
+ });
150
+ }, [ctx, segments, height, width, state.begin, state.hoursPer]);
151
+ /**
152
+ * 绘制刻度相关的
153
+ */
154
+
155
+ var drawScale = useCallback(function () {
156
+ var px_per_min = width / (state.hoursPer * 60); // px/min
157
+
158
+ var px_per_ms = width / (state.hoursPer * 60 * 60 * 1000); // px/ms
159
+
160
+ var px_per_step = minStepSize; // px/格 默认最小值20px
161
+
162
+ var min_per_step = px_per_step / px_per_min; // min/格
163
+
164
+ for (var i = 0; i < minPerStep.length; i++) {
165
+ if (min_per_step <= minPerStep[i]) {
166
+ //让每格时间在minutes_per_step规定的范围内
167
+ min_per_step = minPerStep[i];
168
+ px_per_step = px_per_min * min_per_step;
169
+ break;
170
+ }
171
+ }
172
+
173
+ var medium_step = 30;
174
+
175
+ for (var _i2 = 0; _i2 < minPerStep.length; _i2++) {
176
+ if (distance_between_gtitle / px_per_min <= minPerStep[_i2]) {
177
+ medium_step = minPerStep[_i2];
178
+ break;
179
+ }
180
+ }
181
+
182
+ var num_steps = width / px_per_step; //总格数
183
+
184
+ var ms_offset = ms_to_next_step(state.begin, min_per_step * 60 * 1000); //开始的偏移时间 ms
185
+
186
+ var px_offset = ms_offset * px_per_ms; //开始的偏移距离 px
187
+
188
+ var ms_per_step = px_per_step / px_per_ms; // ms/step
189
+
190
+ var graduation_left, graduation_time, lineH;
191
+
192
+ for (var _i3 = 0; _i3 < num_steps; _i3++) {
193
+ graduation_left = px_offset + _i3 * px_per_step; // 距离=开始的偏移距离+格数*px/格
194
+
195
+ graduation_time = state.begin + ms_offset + _i3 * ms_per_step; //时间=左侧开始时间+偏移时间+格数*ms/格
196
+
197
+ var date = moment(graduation_time);
198
+
199
+ if (date.get('hours') === 0 && date.get('minutes') === 0) {
200
+ lineH = 10;
201
+ var big_date = graduation_title(date.valueOf());
202
+ var x = graduation_left - 12;
203
+ drawText(ctx, {
204
+ fillStyle: normalLineColor,
205
+ font: '10px Arial',
206
+ x: x,
207
+ y: 30,
208
+ text: big_date
209
+ });
210
+ } else if (graduation_time / (60 * 1000) % medium_step === 0) {
211
+ lineH = 10;
212
+ var middle_date = graduation_title(date.valueOf());
213
+
214
+ var _x = graduation_left - (middle_date.length > 5 ? 24 : 12);
215
+
216
+ drawText(ctx, {
217
+ fillStyle: normalLineColor,
218
+ font: '10px Arial',
219
+ x: _x,
220
+ y: 30,
221
+ text: middle_date
222
+ });
223
+ } else {
224
+ lineH = 5;
225
+ }
226
+
227
+ drawLine(ctx, graduation_left, height - lineH, graduation_left, height, normalLineColor, 2);
228
+ }
229
+ }, [ctx, height, width, state.begin, state.hoursPer]);
230
+ /**
231
+ * 绘制当前刻度
232
+ * @returns
233
+ */
234
+
235
+ var drawCurrentLine = useCallback(function () {
236
+ var currentTime = state.currentTime,
237
+ begin = state.begin,
238
+ hoursPer = state.hoursPer;
239
+ var time = currentTime;
240
+ var range = [begin, currentTime + hoursPer * 3600 * 1000];
241
+
242
+ if (time < range[0] || time > range[1]) {
243
+ return;
244
+ }
245
+
246
+ var ms_current = time - begin;
247
+ var px_per_ms = width / (hoursPer * 60 * 60 * 1000); // px/ms
248
+
249
+ var left = px_per_ms * ms_current;
250
+ drawText(ctx, {
251
+ fillStyle: '#ffffff',
252
+ font: '12px Arial',
253
+ x: left - 64,
254
+ y: 14,
255
+ text: formartTimestemp(time)
256
+ });
257
+ drawLine(ctx, left, 20, left, height, currentColor, 2); //中间当前点线
258
+ // eslint-disable-next-line react-hooks/exhaustive-deps
259
+ }, [ctx, height, width, state.currentTime, state.begin, state.hoursPer]);
260
+ /**
261
+ * 绘制提示时间
262
+ */
263
+
264
+ var drawHoverLine = useCallback(function () {
265
+ drawText(ctx, {
266
+ fillStyle: hoverLineColor,
267
+ font: '12px Arial',
268
+ x: state.hover.x - 50,
269
+ y: 12,
270
+ text: formartTimestemp(state.hover.time)
271
+ });
272
+ drawLine(ctx, state.hover.x, 20, state.hover.x, height, hoverLineColor, 1);
273
+ }, [ctx, height, state.hover.time, state.hover.x]);
274
+ /**
275
+ * 获取鼠标posx
276
+ * @param {*} e
277
+ */
278
+
279
+ var get_cursor_x_position = function get_cursor_x_position(e) {
280
+ var posx = 0;
281
+
282
+ var _canvas$getBoundingCl = canvas.getBoundingClientRect(),
283
+ left = _canvas$getBoundingCl.left;
284
+
285
+ if (!e) {
286
+ e = window.event;
287
+ }
288
+
289
+ if (e.pageX || e.pageY) {
290
+ posx = e.pageX - left;
291
+ } else if (e.clientX || e.clientY) {
292
+ posx = e.clientX + document.body.scrollLeft + document.documentElement.scrollLeft;
293
+ }
294
+
295
+ return posx;
296
+ };
297
+ /**
298
+ * 更新画布大小
299
+ */
300
+
301
+
302
+ _useUpdateEffect(function () {
303
+ if (canvas) {
304
+ canvas.width = width;
305
+ canvas.height = height;
306
+ }
307
+ }, [canvas, height, width]);
308
+
309
+ useEffect(function () {
310
+ if (canvas) {
311
+ clearCanvas();
312
+ drawOverlay();
313
+ drawScale();
314
+ drawCurrentLine();
315
+ state.hover.time && drawHoverLine();
316
+ }
317
+ }, [canvas, state.begin, state.currentTime, state.hoursPer, segments, state.hover, clearCanvas, drawOverlay, drawScale, drawCurrentLine, drawHoverLine]);
318
+
319
+ _useUpdateEffect(function () {
320
+ return update({
321
+ begin: begin
322
+ });
323
+ }, [begin]);
324
+
325
+ _useUpdateEffect(function () {
326
+ return update({
327
+ hoursPer: hoursPer
328
+ });
329
+ }, [hoursPer]);
330
+
331
+ _useUpdateEffect(function () {
332
+ return update({
333
+ currentTime: currentTime
334
+ });
335
+ }, [currentTime]);
336
+
337
+ _useEventListener('mousewheel', function (event) {
338
+ event.preventDefault();
339
+ var delta = Math.max(-1, Math.min(1, event.wheelDelta || -event.detail));
340
+ var middle_time = state.begin + state.hoursPer * 3600 * 1000 / 2; //ms 记住当前中间的时间
341
+
342
+ var new_hoursPer = state.hoursPer;
343
+ var index = hours.indexOf(new_hoursPer);
344
+
345
+ if (delta < 0) {
346
+ // 缩小
347
+ if (index === hours.length - 1) {
348
+ new_hoursPer = hours[index];
349
+ } else {
350
+ new_hoursPer = hours[index + 1];
351
+ }
352
+ } else if (delta > 0) {
353
+ // 放大
354
+ if (index === 0) {
355
+ new_hoursPer = hours[0];
356
+ } else {
357
+ new_hoursPer = hours[index - 1];
358
+ }
359
+ }
360
+
361
+ var new_begin = middle_time - state.hoursPer * 3600 * 1000 / 2; //start_timestamp = 当前中间的时间 - zoom/2
362
+
363
+ setState(function (old) {
364
+ return Object.assign(Object.assign({}, old), {
365
+ begin: new_begin,
366
+ hoursPer: new_hoursPer
367
+ });
368
+ });
369
+
370
+ _nextTick(function () {
371
+ return onHoursPerChange && onHoursPerChange(new_hoursPer);
372
+ });
373
+ }, {
374
+ target: canvasRef
375
+ });
376
+
377
+ _useEventListener('mouseout', function () {
378
+ return setState(function (old) {
379
+ return Object.assign(Object.assign({}, old), {
380
+ hover: {
381
+ x: 0,
382
+ time: null
383
+ }
384
+ });
385
+ });
386
+ }, {
387
+ target: canvasRef
388
+ });
389
+
390
+ _useEventListener('mousemove', function (e) {
391
+ if (extRef.current.mousedownTime) {
392
+ setState(function (old) {
393
+ return Object.assign(Object.assign({}, old), {
394
+ hover: old.hover.time ? {
395
+ x: 0,
396
+ time: null
397
+ } : old.hover
398
+ });
399
+ });
400
+ } else {
401
+ // 触发绘制hover tips
402
+ var pos_x = get_cursor_x_position(e);
403
+ var ms_per_px = state.hoursPer * 3600 * 1000 / width; // ms/px
404
+
405
+ var current_timestamp = state.begin + pos_x * ms_per_px;
406
+ setState(function (old) {
407
+ return Object.assign(Object.assign({}, old), {
408
+ hover: {
409
+ x: pos_x,
410
+ time: current_timestamp
411
+ }
412
+ });
413
+ });
414
+ }
415
+ }, {
416
+ target: canvasRef
417
+ });
418
+
419
+ _useEventListener('mousedown', function (e) {
420
+ extRef.current.mousedownTime = Date.now();
421
+ extRef.current.mousedownX = get_cursor_x_position(e); //记住mousedown的位置
422
+ }, {
423
+ target: canvasRef
424
+ });
425
+
426
+ _useEventListener('mouseup', function (e) {
427
+ if (!extRef.current.mousedownTime) {
428
+ return;
429
+ }
430
+
431
+ var clickDelay = Date.now() - extRef.current.mousedownTime;
432
+
433
+ if (clickDelay < 300 && e.target === canvas) {
434
+ // click 事件
435
+ var pos_x = get_cursor_x_position(e); //鼠标距离 px
436
+
437
+ var ms_per_px = state.hoursPer * 3600 * 1000 / width; // ms/px
438
+
439
+ var new_current = state.begin + pos_x * ms_per_px;
440
+ var segmentItem = segments.find(function (v) {
441
+ return new_current >= v.beginTime && new_current < v.endTime;
442
+ }); // 当前片段没有录像的时候
443
+
444
+ var outTimeline = segmentItem && !segmentItem.url;
445
+ var new_begin = new_current - state.hoursPer * 60 * 60 * 1000 / 2;
446
+ setState(function (old) {
447
+ return Object.assign(Object.assign({}, old), {
448
+ begin: new_begin,
449
+ current: new_current
450
+ });
451
+ });
452
+
453
+ _nextTick(function () {
454
+ return onTimeChange && onTimeChange(new_current, outTimeline);
455
+ });
456
+ } // 清楚拖拽关联信息
457
+
458
+
459
+ extRef.current.mousedownTime = null;
460
+ extRef.current.mousedownX = 0;
461
+ }, {
462
+ target: document
463
+ });
464
+
465
+ _useEventListener('mousemove', function (e) {
466
+ if (!extRef.current.mousedownTime) {
467
+ return;
468
+ } // 触发拖动
469
+
470
+
471
+ var pos_x = get_cursor_x_position(e);
472
+ var px_per_ms = width / (state.hoursPer * 60 * 60 * 1000); // px/ms
473
+
474
+ var diff_x = pos_x - extRef.current.mousedownX;
475
+ var new_begin = state.begin - Math.round(diff_x / px_per_ms);
476
+ extRef.current.mousedownX = pos_x;
477
+ update({
478
+ begin: new_begin
479
+ });
480
+ }, {
481
+ target: document
482
+ });
483
+ }
484
+
485
+ export default useTimeSlider;
package/package.json CHANGED
@@ -2,7 +2,7 @@
2
2
  "private": false,
3
3
  "name": "@cloud-app-dev/vidc",
4
4
  "description": "Video Image Data Componennts",
5
- "version": "3.0.11",
5
+ "version": "3.0.12",
6
6
  "scripts": {
7
7
  "start": "dumi dev",
8
8
  "docs:build": "dumi build",