-
Notifications
You must be signed in to change notification settings - Fork 0
/
video.js
100 lines (96 loc) · 23.9 KB
/
video.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
/******/ (function(modules) { // webpackBootstrap
/******/ // The module cache
/******/ var installedModules = {};
/******/
/******/ // The require function
/******/ function __webpack_require__(moduleId) {
/******/
/******/ // Check if module is in cache
/******/ if(installedModules[moduleId]) {
/******/ return installedModules[moduleId].exports;
/******/ }
/******/ // Create a new module (and put it into the cache)
/******/ var module = installedModules[moduleId] = {
/******/ i: moduleId,
/******/ l: false,
/******/ exports: {}
/******/ };
/******/
/******/ // Execute the module function
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
/******/
/******/ // Flag the module as loaded
/******/ module.l = true;
/******/
/******/ // Return the exports of the module
/******/ return module.exports;
/******/ }
/******/
/******/
/******/ // expose the modules object (__webpack_modules__)
/******/ __webpack_require__.m = modules;
/******/
/******/ // expose the module cache
/******/ __webpack_require__.c = installedModules;
/******/
/******/ // define getter function for harmony exports
/******/ __webpack_require__.d = function(exports, name, getter) {
/******/ if(!__webpack_require__.o(exports, name)) {
/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
/******/ }
/******/ };
/******/
/******/ // define __esModule on exports
/******/ __webpack_require__.r = function(exports) {
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
/******/ }
/******/ Object.defineProperty(exports, '__esModule', { value: true });
/******/ };
/******/
/******/ // create a fake namespace object
/******/ // mode & 1: value is a module id, require it
/******/ // mode & 2: merge all properties of value into the ns
/******/ // mode & 4: return value when already ns object
/******/ // mode & 8|1: behave like require
/******/ __webpack_require__.t = function(value, mode) {
/******/ if(mode & 1) value = __webpack_require__(value);
/******/ if(mode & 8) return value;
/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
/******/ var ns = Object.create(null);
/******/ __webpack_require__.r(ns);
/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
/******/ return ns;
/******/ };
/******/
/******/ // getDefaultExport function for compatibility with non-harmony modules
/******/ __webpack_require__.n = function(module) {
/******/ var getter = module && module.__esModule ?
/******/ function getDefault() { return module['default']; } :
/******/ function getModuleExports() { return module; };
/******/ __webpack_require__.d(getter, 'a', getter);
/******/ return getter;
/******/ };
/******/
/******/ // Object.prototype.hasOwnProperty.call
/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
/******/
/******/ // __webpack_public_path__
/******/ __webpack_require__.p = "";
/******/
/******/
/******/ // Load entry module and return exports
/******/ return __webpack_require__(__webpack_require__.s = "./app/video.js");
/******/ })
/************************************************************************/
/******/ ({
/***/ "./app/video.js":
/*!**********************!*\
!*** ./app/video.js ***!
\**********************/
/*! no static exports found */
/***/ (function(module, exports) {
eval("!function (window) {\n\n // 验证类型\n const Verify = new Function();\n Verify.prototype = {\n constructor: Verify,\n isWindow(obj) {\n return obj !== null && obj === obj.window;\n },\n isObject(obj) {\n return obj !== null && typeof obj === 'object';\n },\n isFunction(fun) {\n return fun !== null && typeof fun === 'function';\n }\n };\n\n // 实例化\n let inseart = true;\n\n // 方法\n const Methods = function (config) {\n this.verify = new Verify();\n if (!this.verify.isObject(config)) {\n return false;\n }\n return this;\n };\n Methods.prototype = {\n constructor: Methods,\n init(config, canplay, play, update, end) {\n\n this.canvasObj = this.createCanvas(config['el'].offsetWidth, config['el'].offsetHeight);\n\n if (config['imageUrl']) {\n\n const image = this.createImage(config['imageUrl']);\n\n image.onload = () => {\n this.canvasObj['context'].drawImage(image, 0, 0, this.canvasObj['width'], this.canvasObj['height']);\n };\n };\n\n this.createVideo(config, canplay, play, update, end);\n\n config['el'].appendChild(this.canvasObj.canvas);\n },\n createCanvas(width, height) {\n const canvas = document.createElement('canvas');\n const context = canvas.getContext('2d');\n canvas.width = width;\n canvas.height = height;\n context.clearRect(0, 0, canvas.width, canvas.height);\n canvas.style.width = '100%';\n canvas.style.height = '100%';\n return { canvas, context, width: canvas.width, height: canvas.height };\n },\n createImage(imageUrl) {\n const image = new Image();\n image.src = imageUrl;\n return image;\n },\n createVideo(config, canplay, play, update, end) {\n const video = document.createElement('video');\n video.setAttribute('src', config['videoUrl']);\n video.setAttribute('webkit-playsinline', 'true');\n video.setAttribute('controls', 'controls');\n video.setAttribute('playsinline', 'true');\n video.setAttribute('x-webkit-airplay', 'true');\n video.setAttribute('x5-video-player-type', 'h5');\n video.setAttribute('x5-video-player-fullscreen', 'true');\n video.setAttribute('x5-video-ignore-metadata', 'true');\n video.style.objectFit = 'cover';\n video.style.objectPosition = 'center';\n video.style.width = '100%';\n if (config['audioUrl']) {\n this.createAudio();\n video.muted = true;\n }\n\n let time = '';\n\n const videoHandler = {\n play: video.play.bind(video),\n pause: video.pause.bind(video),\n load: video.load.bind(video),\n setAudio: this.setAudio.bind(this),\n currentTime: sec => {\n video.currentTime = sec;\n this.audio.currentTime = sec;\n }\n };\n\n video.addEventListener('canplaythrough', () => {\n if (this.verify.isFunction(canplay)) {\n canplay(videoHandler);\n }\n });\n\n video.addEventListener('play', () => {\n if (this.verify.isFunction(play)) {\n play(videoHandler);\n }\n\n this.setAudio(config['audioUrl']);\n time = setInterval(() => {\n this.canvasObj['context'].drawImage(video, 0, 0, this.canvasObj['width'], this.canvasObj['height']);\n }, 20);\n });\n\n video.addEventListener(\"timeupdate\", () => {\n const plan = video.currentTime;\n if (this.verify.isFunction(update)) {\n update(videoHandler, plan);\n }\n }, false);\n\n video.addEventListener('ended', () => {\n clearInterval(time);\n if (this.verify.isFunction(end)) {\n end(videoHandler);\n }\n });\n },\n createAudio() {\n this.audio = document.createElement('audio');\n },\n setAudio(audioUrl) {\n this.audio.setAttribute('src', audioUrl);\n this.audio.play();\n }\n };\n\n const mobVideo = function (config) {\n\n this.verify = new Verify();\n\n if (!this.verify.isWindow(window)) {\n return false;\n };\n\n if (!inseart) {\n throw new Error('只能创建一次');\n return false;\n } else {\n inseart = false;\n };\n\n if (!this.verify.isObject(config)) {\n throw new Error('第一个参数必须是对象');\n };\n\n if (!config['el'] || document.getElementById(config['el']) === null) {\n throw new Error('没有配置id或没有找到id元素');\n };\n\n if (!config['videoUrl']) {\n throw new Error('没有配置视频地址');\n };\n\n config['el'] = document.getElementById(config['el']);\n\n this.config = config;\n\n this.initInseart = true;\n\n return this;\n };\n\n mobVideo.prototype = {\n constructor: mobVideo,\n init(canplay, play, update, end) {\n\n if (!this.initInseart) {\n throw new Error('只能初始化一次');\n return false;\n }\n\n this.initInseart = false;\n\n const methods = new Methods();\n methods.init(this.config, canplay, play, update, end);\n }\n };\n\n window.mobVideo = mobVideo;\n}(window);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./app/video.js?65a4"],"names":["window","Verify","Function","prototype","constructor","isWindow","obj","isObject","isFunction","fun","inseart","Methods","config","verify","init","canplay","play","update","end","canvasObj","createCanvas","offsetWidth","offsetHeight","image","createImage","onload","drawImage","createVideo","appendChild","canvas","width","height","document","createElement","context","getContext","clearRect","style","imageUrl","Image","src","video","setAttribute","objectFit","objectPosition","createAudio","muted","time","videoHandler","bind","pause","load","setAudio","currentTime","sec","audio","addEventListener","setInterval","plan","clearInterval","audioUrl","mobVideo","Error","getElementById","initInseart","methods"],"mappings":"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","file":"./app/video.js.js","sourcesContent":["!(function (window) {\r\n\r\n  // 验证类型\r\n  const Verify = new Function();\r\n  Verify.prototype = {\r\n    constructor: Verify,\r\n    isWindow (obj) {\r\n      return obj !== null && obj === obj.window;\r\n    },\r\n    isObject (obj) {\r\n      return obj !== null && typeof obj === 'object';\r\n    },\r\n    isFunction (fun) {\r\n      return fun !== null && typeof fun === 'function';\r\n    }\r\n  }\r\n\r\n  // 实例化\r\n  let inseart = true;\r\n\r\n  // 方法\r\n  const Methods = function (config) {\r\n    this.verify = new Verify();\r\n    if (!this.verify.isObject(config)) {\r\n      return false;\r\n    }\r\n    return this;\r\n  };\r\n  Methods.prototype = {\r\n    constructor: Methods,\r\n    init (config, canplay, play, update, end) {\r\n      \r\n      this.canvasObj = this.createCanvas(config['el'].offsetWidth, config['el'].offsetHeight);\r\n\r\n      if (config['imageUrl']) {\r\n\r\n        const image = this.createImage(config['imageUrl']);\r\n\r\n        image.onload = () => {\r\n          this.canvasObj['context'].drawImage(image, 0, 0, this.canvasObj['width'], this.canvasObj['height']);\r\n        }\r\n\r\n      };\r\n\r\n      this.createVideo(config, canplay, play, update, end)\r\n\r\n      config['el'].appendChild(this.canvasObj.canvas);\r\n    },\r\n    createCanvas (width, height) {\r\n      const canvas = document.createElement('canvas');\r\n      const context = canvas.getContext('2d');\r\n      canvas.width = width;\r\n      canvas.height = height;\r\n      context.clearRect(0, 0, canvas.width, canvas.height)\r\n      canvas.style.width = '100%';\r\n      canvas.style.height = '100%';\r\n      return {canvas, context, width: canvas.width, height: canvas.height}\r\n    },\r\n    createImage  (imageUrl) {\r\n      const image = new Image();\r\n      image.src = imageUrl;\r\n      return image\r\n    },\r\n    createVideo (config, canplay, play, update, end) {\r\n      const video = document.createElement('video');\r\n      video.setAttribute('src', config['videoUrl']);\r\n      video.setAttribute('webkit-playsinline', 'true');\r\n      video.setAttribute('controls', 'controls');\r\n      video.setAttribute('playsinline', 'true');\r\n      video.setAttribute('x-webkit-airplay', 'true');\r\n      video.setAttribute('x5-video-player-type', 'h5');\r\n      video.setAttribute('x5-video-player-fullscreen', 'true');\r\n      video.setAttribute('x5-video-ignore-metadata', 'true');\r\n      video.style.objectFit = 'cover'\r\n      video.style.objectPosition = 'center'\r\n      video.style.width = '100%';\r\n      if (config['audioUrl']) {\r\n        this.createAudio()\r\n        video.muted = true\r\n      }\r\n\r\n      let time = ''\r\n\r\n      const videoHandler = {\r\n        play: video.play.bind(video),\r\n        pause: video.pause.bind(video),\r\n        load: video.load.bind(video),\r\n        setAudio: this.setAudio.bind(this),\r\n        currentTime: (sec) => {\r\n          video.currentTime = sec\r\n          this.audio.currentTime = sec\r\n        }\r\n      }\r\n\r\n      video.addEventListener('canplaythrough', () => {\r\n        if (this.verify.isFunction(canplay)) {\r\n          canplay(videoHandler);\r\n        }\r\n      });\r\n\r\n      video.addEventListener('play', () => {\r\n        if (this.verify.isFunction(play)) {\r\n          play(videoHandler);\r\n        }\r\n\r\n        this.setAudio(config['audioUrl'])\r\n        time = setInterval(() => {\r\n          this.canvasObj['context'].drawImage(video, 0, 0, this.canvasObj['width'], this.canvasObj['height']);\r\n        }, 20)\r\n      })\r\n\r\n      video.addEventListener(\"timeupdate\", () => {\r\n        const plan = video.currentTime;\r\n        if (this.verify.isFunction(update)) {\r\n          update(videoHandler, plan);\r\n        }\r\n      }, false);\r\n\r\n      video.addEventListener('ended', () => {\r\n        clearInterval(time);\r\n        if (this.verify.isFunction(end)) {\r\n          end(videoHandler);\r\n        }\r\n      })\r\n    },\r\n    createAudio () {\r\n      this.audio = document.createElement('audio');\r\n    },\r\n    setAudio (audioUrl) {\r\n      this.audio.setAttribute('src', audioUrl);\r\n      this.audio.play()\r\n    }\r\n  }\r\n\r\n  const mobVideo = function (config) {\r\n\r\n    this.verify = new Verify();\r\n\r\n    if (!this.verify.isWindow(window)) {\r\n      return false;\r\n    };\r\n\r\n    if (!inseart) {\r\n      throw new Error('只能创建一次');\r\n      return false;\r\n    } else {\r\n      inseart = false\r\n    };\r\n\r\n    if (!this.verify.isObject(config)) {\r\n      throw new Error('第一个参数必须是对象');\r\n    };\r\n\r\n    if (!config['el'] || document.getElementById(config['el']) === null) {\r\n      throw new Error('没有配置id或没有找到id元素');\r\n    };\r\n\r\n    if (!config['videoUrl']) {\r\n      throw new Error('没有配置视频地址');\r\n    };\r\n\r\n    config['el'] = document.getElementById(config['el']);\r\n\r\n    this.config = config;\r\n\r\n    this.initInseart = true;\r\n\r\n    return this;\r\n    \r\n  };\r\n\r\n  mobVideo.prototype = {\r\n    constructor: mobVideo,\r\n    init (canplay, play, update, end) {\r\n\r\n      if (!this.initInseart) {\r\n        throw new Error('只能初始化一次');\r\n        return false;\r\n      }\r\n\r\n      this.initInseart = false;\r\n\r\n      const methods = new Methods();\r\n      methods.init(this.config, canplay, play, update, end);\r\n\r\n    }\r\n  }\r\n\r\n  window.mobVideo = mobVideo;\r\n\r\n})(window);"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./app/video.js\n");
/***/ })
/******/ });