mand-mobile
Version:
A Vue.js 2.0 Mobile UI Toolkit
92 lines (80 loc) • 2.25 kB
JavaScript
/**
* Read Image In Web Worker or main thread
*
* STATUS
* 0: success
* 100: 'browser does not support',
* 101: 'picture size is beyond the preset',
* 102: 'picture read failure',
* 103: 'the number of pictures exceeds the limit'
*/
export default function(global) {
/**
* Constructor
* @param{*} [Array]files 图片文件
* @param{*} [Boolean]isWebWorker 是否为webwork模式调用
* @param{*} [Number]size 单张图片大小限制
* @param{*} [Function]complete 非webwork模式时 回调 res { errorCode: '0', file, dataUrl }
*/
function ImageReader(options) {
/* istanbul ignore if */
if (!options.files) {
return
}
this.files = options.files
this.index = 0
this.size = options.size || 0
if (!options.isWebWorker && options.complete) {
this.callback = options.complete
}
this.readImage(options.files[this.index])
}
ImageReader.prototype.readImage = function(file) {
// iterator
const next =
this.files && this.index < this.files.length - 1
? () => {
this.index += 1
this.readImage(this.files[this.index])
}
: null
const onReadImageComplete = (msg = {}) => {
/* istanbul ignore else */
if (this.callback) {
this.callback(msg)
} else {
postMessage(msg)
}
next && next()
}
if (!this.size || file.size <= this.size) {
const reader = new FileReader()
reader.onload = readerEvt => {
const dataUrl = readerEvt.target.result
onReadImageComplete({errorCode: 0, file, dataUrl})
}
reader.onerror = () => {
/* istanbul ignore next */
onReadImageComplete({errorCode: 102})
}
reader.readAsDataURL(file)
} else {
onReadImageComplete({errorCode: 101})
}
}
const onmessageCallback = function(workerEvt) {
const imageReader = new ImageReader(workerEvt.data)
return imageReader
}
if (global) {
return function(data) {
return onmessageCallback({data})
}
} else {
/* global onmessage */
/* eslint no-unused-vars: 0 */
/* eslint no-global-assign: 0 */
/* istanbul ignore next */
onmessage = onmessageCallback
}
}